闽江学院2015-2016学年下学期《软件测试》课程-第三次博客作业

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) 写出问题所在

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

(3) 给出修改后的代码

 

题目一:

1、问题:

  问题一:

 public String getPhoneNumber(String strPhoneNum){
        if((strPhoneNum==null) || "".equals(strPhoneNum)){
            return  “”      
}

  问题二:

    区号-电话号码—分机号输入应为数字且长度为11位

  问题三:

    区号-电话号码—分机号的格式为3-4位区号,7-8位直播号码,1-4位分机号

2.原因:

  原因一:问题一中输入的电话为空值,但是却返回""

  原因二:系统需求中代码不够完善、不严格

3.修改:

   public String getPhoneNumber(String strPhoneNum)

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

    System.out.println("输入的电话不能为空!");
        return false       

      }     

 

  if (strPhoneNum.length() != 11) {
     throw new Exception("电话号码必须长11位");
    }

  for (int i = 2; i < strPhoneNum.length(); i++) {
     char p = strPhoneNum.charAt(i);
     if (p < '0' || p > '9') {
      throw new Exception("电话号码必须由数字组成!");
     }

    }

     String format="((\d{11})|^((\d{7,8})|(\d{4}|\d{3})-(\d{7,8})|(\d{4}|\d{3})-(\d{7,8})-(\d{4}|\d{3}|\d{2}|\d{1})|(\d{7,8})-(\d{4}|\d{3}|\d{2}|\d{1}))$)";

  if(strPhoneNum.matches(format))

        {

      return true;// 电话名合法,返回true

        }

      else{

      return false;// 电话名不合法,返回false

      System.out.println("输入的电话格式不合格!");

        }

    }

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

split("-") 方法得到的数字结果为

0591

83279988

002

返还arrPhone[1]则表示返还为第二个数组 所以结果得到83279988

 

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

要求:

(1) 写出代码,并符合代码规范(命名要规范,不可直接写在main方法中,需要有类注释、方法注释、以及适当的行注释)

(2) 说明你的设计思路

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

(4) 编写JUnit单元测试,将前面给出的可能出错的测试数据放入单元测试进行测试

题目二:

一、代码:

 

package cn.VV.demo;

public class VV {
 /**
  * @param args
  * 插入排序
  */
 public int[] V(int[] arr){
  // 定义数组arr;
  for (int i = 1; i < arr.length; i++)
   for (int j = i; j > 0; j--) {
   if (arr[j] > arr[j - 1]) {
   int temp = arr[j - 1];//第一个起,依次和后边的比较,如果大于后边的往后移动
   arr[j - 1] = arr[j];
   arr[j] = temp;
   } else
   break;
   }
   return arr; //返还arr
}
 
}

 

package cn.VV.demo;

import org.junit.Test;

public class GodEater {

 @Test
 public void test() {
  VV  lsw= new VV();
  int[] arr={4,8,55,3,9,41}; //数组arr赋值
  int[] b=lsw.V(arr);
        for(int i = 0;i<b.length;i++){
            System.out.println(b[i]);
         }
    }
}

 

二:设计思路

假定这个数组的序是排好的,然后从头往后,如果有数比当前外层元素的值大,则将这个数的位置往后挪,直到当前外层元素的值大于或等于它前面的位置为止。算法在排完前n个数之后,可以保证a[1…n]是局部有序的,保证了插入过程的正确性。

 

三:可能出错的情况

1、数组没有数字

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

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

4、数组数字0开头(如:0,19,6,4)

5、数组各个数字由一个数字组成且有负数(如:33,3,3333,-33)

截图如下

 

 

总结:

通过本实验的学习,学习到了很多,不仅通过学过的测试技术和方法,找出代码中存在的问题,并且靠自己分析出现问题的原因,同时给出自己的解决方案。虽然过程中费了点时间,但是真的学到很多。特别是split方法,可能以前学过没有注意或者教过忘记了,但是这次实验我学会了split方法的使用。所以这次实验不仅只是份作业,也是让我学到split方法的偶然吧。(split() 方法用于把一个字符串分割成字符串数组。http://www.w3school.com.cn/jsref/jsref_split.asp

posted on 2016-04-26 22:45  友人V  阅读(162)  评论(0编辑  收藏  举报

导航