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) 写出问题产生的原因

  代码中没有限制电话号码的长度和是否是int类型

(3) 给出修改后的代码

 public String getPhoneNumber(String strPhoneNum){
          
            if((strPhoneNum==null) || "".equals(strPhoneNum)){
                return "没有输入!!!";
             }
     
            }
              if(strPhoneNum.lenth>=17){
                   System.out.println("输入不符规则!");
                   System.exit(0);
               }
            String[] arrPhone=strPhoneNum.split("-");
            for(int i = 0; i < array.legth; i++){
                try{
                    Integer.parseInt(arrPhone[i]);
                }catch(Exception e){
                    System.out.println("输入的不是数字!!!");
                    break;
                }
            return arrPhone[1];
     
        }

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

要求:

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

 /**

  * 整形数组排序

  * @author linbobai

  * 更新时间:2016/4/29

  */

 import java.util.Scanner;

 

 public class unit2 {

 

     /**

      * @param args

      */

     public static void main(String[] args) {

         // TODO Auto-generated method stub

         unit2 unit2 = new unit2();

         unit2.bai();

     }

     //冒泡排序法

     public  void bai() {

         Scanner in = new Scanner(System.in);

         System.out.println("请输入你要排序的数组,同时按空格键隔开每个数字:");

         String str = in.nextLine();

         

         //首字符是空格或TAB删除首字符

         for(int i = 0; i <str.length(); i++){

             if(str.charAt(0)==' '||str.charAt(0)==' '){

                 str=str.substring(1);

             }

         }

         

         //假设传入的参数已经确定为整型数组,转换成整形数组

         String[] array = str.split(" ");

         int[] num = new int[array.length];

         for(int i = 0; i < array.length; i++){

             num[i] = Integer.parseInt(array[i]);

         }

         for (int m = 0; m < num.length; m++) {

             for (int n = 0; n < num.length-1; n++) {

                 if(num[n]>num[n+1]){

                     num[n]=num[n+1]+num[n];

                     num[n+1]=num[n]-num[n+1];

                     num[n]=num[n]-num[n+1];

                 }

             }

         }  

         for(int i = 0; i < array.length; i++){

             System.out.print(num[i]+" ");

         }

     }

 }  

(2) 说明你的设计思路

   采用冒泡排序法对输入的数组进行从小到大排序。

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

      ①负整数排序;

  ②正整数排序;

  ③正负整数混合排序;

  ④数组里含有大小相同的负整数的排序;

  ⑤数组里含有大小相同的正整数的排序;

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