实验四

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、电话号码没有输入控制(如:输入的只能是数字,位数有限制)

 

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

此代码要求用户号码输入的格式必须正确,却没有对用户电话号码输入的格式进行提示,用户容易输入不正确的格式,导致返回的电话号码错误。

   

(3) 给出修改后的代码

 

/**

     * 3137102227 林炳钦

     * 该方法根据用户输入取出中间的电话号码部分

     * @param strPhoneNum  电话号码,如:“0591-83279988—002”

     * @return  返回号码部分,如:“83279988”

     */

public class Test {

    public String getPhoneNumber(String strPhoneNum){

         String way = null;

//提示输入的格式

        System.out.println("输入(区号-电话号码-分机号)");

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

               return "";

           }

//输入控制

 if (strPhoneNum.length() != 15) {

      System.out.println ("电话号码必须是15位");

        return "";

    }

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

     char p = strPhoneNum.charAt(i);

     if (p < '0' || p > '9') {

       System.out.println ("电话号码必须由数字组成!");

         return "";

     }

    }

 

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

要求:

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

 

/*

 * 对数组进行排序的原理是:先比出最大的,再找到第二大的,直到最小的

* 将它们依次赋值给数组

 */

import java.util.Arrays;

import java.util.InputMismatchException;

import java.util.Scanner;

 

 

public class rank {

 

    /**

     * @3137102227_林炳钦

     */

   

        static void count(int[] arr){

          

       int p,q,s;

       System.out.println("排序后:");

            for(int i=0;i<arr.length-1;i++)

            {

            p = i;q=arr[i];

                for(int j=i+1;j<arr.length;j++)

                {

                    if(arr[j]> q)

                    {

                        p = j;q = arr[j];

                    }

                }

                 if(p != i)

                 {

                  s = arr[i];

                  arr[i] = arr[p];

                  arr[p] = s;  

                 }

                

             }

            for(int k=0;k<arr.length;k++)

            {

            System.out.println( +arr[k]);

            }

       }

           

   

 

    public static void main(String[] args) {

       // TODO Auto-generated method stub

       rank p = new rank();

         final int length = 5;

         int[] a = new int[length];

         int i = 0;

        System.out.println("请输入5个数:");

            while(i<a.length)

            {

            try {

                    Scanner scanner = new Scanner(System.in);

                    a[i] = scanner.nextInt();

                    i++;

                }catch (InputMismatchException e)

                {

                    System.out.println("Invalid digit number in format, please input again!");

                }

         }  

            p.count(a);

               

          } 

           

    }

 

   

 

 

(2) 说明你的设计思路

  对数组进行排序的原理是:先比出最大的,再找到第二大的,直到最小的

将它们依次赋值给数组。  封装这个函数,在main方法调用这个函数

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

1、当输入不是数字时,程序是否会报错。

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

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

  4、 数组为空的情况

  5、数组已按逆序排好

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

    测试用例1:对出错情况1,测试用例为输入  k,实验结果有错误提示

 

测试用例2:对出错情况2和3的测试用例

Int a = {12345678,-2,-48,555,8}

实验结果ok

 

 

  测试用例3:对出错情况5的测试用例,实验结果ok

posted @ 2016-04-29 11:10  一个侠的孤单  阅读(199)  评论(0编辑  收藏  举报