第三次博客作业

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、没有判断没空的情况。

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

  代码中只固定了用户3种号码都必须输入,没有对用户输入的电话号码进行提示,用户有时没法输入正确的格式,因此程序会出现错误。   

(3) 给出修改后的代码

/*
 * 改方法根据用户输入进来的电话号码字符串的长度来判断用户输入的是否正确
 * 根据中间号码的位置来获得
 */
public class LoginTest {
    public String getPhoneNumber(String strPhoneNum){
         String way = null;
           if((strPhoneNum == null)|| "".equals(strPhoneNum)){
               return "";
           }
           //固定用户输入电话号码的字符串的长度,然后根据根据电话号码的所在位置得到电话号码
           if(strPhoneNum.length() == 17){
               for(int i=0;i<=17;i++){
                  way = strPhoneNum.substring(5, 13);
               }  
            }else{
               return way = "你输入的电话号码的格式是错误的!";
           }
           return way;
        }   
}

 

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

要求:

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

package cn.deng;
/*
 * 对数组进行排序使用的是冒泡排序按数字从小到大进行排序
 */
public class ArraySort {
    public void way(int[] arr){
        System.out.println("你输入的数组为:");
        for(int i = 0;i<arr.length;i++){
            System.out.println(arr[i] + " ");
        }
        for(int i=0;i<arr.length-1;i++){
            for(int j=0;j<arr.length-1-i;j++){
                if(arr[j]> arr[j + 1]){
                    int temp = arr[j];
                    arr[j] = arr[j + 1];
                    arr[j + 1] = temp;
                }
            }
        }
        for (int i = 0; i < arr.length; i++)
            System.out.print(arr[i] + " ");
        }
}

 

(2) 说明你的设计思路

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

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

  1、当输入的的数组数字一样时,是否能够正确的排序。

  2、当输入其他字符时,程序是否会报错。

  3、当所输入的数组很大时,程序是否能够正常运行。

  4、当输入的数是字符型时是否会排序。

  5、当所输入的数是负数时,是否会正确的排序。

  6、 数组为空的情况

  7、数组已经排好了顺序

  8、数组已按逆序排好

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

   测试用例  int[] arr = { 3,3, 1, 2, 3, 3,43, 8, 1, 10, 7, 5,11,76};

测试用例  int[] arr = {};

 

int[] arr = {'a','b','c','g'};

int[] arr = {1,2,3,4,5,6,7,8};

 

int[] arr = {8,7,6,5,4,3,2,1};

 


posted @ 2016-04-28 19:43  邓春增  阅读(213)  评论(0编辑  收藏  举报