码迷,mamicode.com
首页 > 其他好文 > 详细

软件学院《软件测试》课程第三次博客作业

时间:2016-04-30 23:49:04      阅读:208      评论:0      收藏:0      [点我收藏+]

标签:

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

  ①输入正确的0591-83279988—002格式并无法输出电话号码

  ②输入包含字母空格等错误信息仍然能够被输出

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

  ①jsp中电话号码的输入格式为“区号-电话号码—分机号”,仅使用split("-")无法区分电话号码和分机号

  ②没有添加对输入是否为数字的判断

(3) 给出修改后的代码

public String getPhoneNumber(String strPhoneNum){
        if((strPhoneNum==null) || "".equals(strPhoneNum)){
            return "输入不能为空";
        }
        String[] arrPhone=strPhoneNum.split("[-——]");
            if(!arrPhone[1].matches("[0-9]+")){
              return "输入必须为数字";
            }else{
                return arrPhone[1];
            }
    }

 

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

要求:

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

public class Test2 {
    /*
      *@author:谢黎明
      *2016-04-26
      *对输入的整数进行升序排序
      */
    @Test
    public void test(){  //实现方法
        System.out.println("请输入需要排序的整数并用逗号隔开:");
        Scanner sc=new Scanner(System.in);
        String inputString=sc.next().toString().trim();  
        String Array[]=inputString.split(",");
        int num[]=new int[Array.length];
        for(int i=0;i<Array.length;i++){
            num[i]=Integer.parseInt(Array[i]);            
        }
        Arrays.sort(num);      //利用Arrays类的sort方法对num数组进行升序排序
        for(int j=0;j<Array.length;j++){
            System.out.print(num[j]+" ");            
        }
    }
}

(2) 说明你的设计思路

  Arrays类的sort()方法可以很方便地对数组内的内容进行升序排序,这个方法完全能够满足题目的需求,所以只需先获得用户输入的整数字符串,再将其分开存入数组,用sort方法即可完成对

其排序。

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

①输入的整数包含负数  测试用例:11,1,10,-1,25 

②输入的整数包含0       测试用例:20,0,1,21,100

③输入的整数有两个或两个以上相同  测试用例:50,99,2,2,4

④输入的整数已经被排序好   测试用例:1,2,3,4,5

⑤输入的整数全部相同    测试用例:1,1,1,1,1

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

技术分享

技术分享

技术分享

技术分享

技术分享

技术分享

 

 

软件学院《软件测试》课程第三次博客作业

标签:

原文地址:http://www.cnblogs.com/XIELIMING/p/5449600.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!