软件测试_实验三

1、  某网站管理系统,用户注册时,电话号码为可选输入项,输入格式为:区号-电话号码—分机号,中间用“-”隔开。以下为jsp页面上的设计,且并未对输入做任何控制。

假设系统现在需要取出中间的电话号码部分,代码如下:

复制代码
/**
     * 
     * 该方法根据用户输入取出中间的电话号码部分
     * @param strPhoneNum  电话号码,如:“0591-83279988—002”
     * @return  返回号码部分,如:“83279988”
     */
    public String getPhoneNumber(String strPhoneNum){
        if((strPhoneNum==null) || "".equals(strPhoneNum)){
            return "";
        }
        String[] arrPhone=strPhoneNum.split("-");
        return arrPhone[1];
    }
复制代码

请用你学过的测试技术和方法,找出该方法中存在的问题,并且分析出现该问题的原因,同时给出你的解决方案。(提示:存在的问题不止一个)

要求:

(1) 写出问题所在

  问题:1、当输入号码区号、电话号码、分机号时没有用-隔开程序会报错。

     2、号码输入不完整时,系统会报错

     3、没有判断输入字符类别

     4、没有限制输入号码位数

(2)写出问题产生的原因

代码定了三种号码都必须输入,没有限制输入的号码位数和限制输入的字符,没有强制限制输入号码必须完整。因此程序会出错

(3) 给出修改后的代码

 public String getPhoneNumber(String strPhoneNum){

        if((strPhoneNum==null) || "".equals(strPhoneNum)){

            if(strPhoneNum.lenth==17){

                    return "true";

         }else{

         return "false";

         System.out.println("输入的号码格式不正确!!!");

         }

        }

        String[] arrPhone=strPhoneNum.split("-");

        return arrPhone[1];

    }

2、  请写一段用于整型数组排序的代码,说明你的设计思路,并利用错误推测法给出可能出错的情况(至少5种),设计出测试用例,并利用JUnit编写单元测试进行测试。(假设传入的参数已经确定为整型数组)

(1) 写出代码,并符合代码规范

package com.Demo;
import java.util.*;
public class Array
{int a[] = {4,32,45,32,65,32,2} ;
public static void main(int[] a)
{

System.out.print("数组排序前的顺序:");
for(int i=0;i<a.length;i++)
System.out.print(a[i]+" ");
Arrays.sort(a);//数组的排序方法
System.out.print("\n数组排序后的顺序:");
for(int i=0;i<a.length;i++)
System.out.print(a[i]+" ");
System.out.print("\n");
}
}

(2) 说明你的设计思路

Arrays类可以实现数组的排序,不管数组的元素是引用类型还是值类型

对整型数组排序进行排序使用的是降序排序,再类中定义一个带参数的方法,在main方法中输出。

(3) 写出可能出错的情况(至少五种)

1、数组数字全部相同(如:1,1,1,1,1,1)

2、数组数字0开头(如:00,012,034,004)

3、数组各个数字由一个数字组成且有负数(如:22,222,2,-222,-22)

4、数组有数字为负数(如:3,-4,6,-5)

5、数组没有数字

6、数组按顺序排列(如:78,60,41,12,41,21)

运行结果:

 

 

 

  int a[] = {1,1,1,1,1,1};

  

  int a[] = {00,012,034,004};

  

  int a[] = {22,222,2,-222,-22};

  

 

   int a[] = {3,-4,6,-5};

  

  int a[] = {};

 

  

  int a[] = {78,60,41,12,41,21};

  

转载于:https://www.cnblogs.com/tuweixue1112/p/5446293.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值