四_测试网站管理系统
闽江学院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) 给出修改后的代码
答:
/** * 3137102236
* @author 林*旺 * 2016/4/30 * 该方法根据用户输入取出中间的电话号码部分 * @param strPhoneNum 电话号码,如:“0591-83279988—002” * @return 返回号码部分,如:“83279988” */ public String getPhoneNumber(String strPhoneNum){ //判断输入的电话号码是否多是由数字组成的 boolean result=strPhoneNum.matches("[0-9]+"); if (result == false){ return "false"; }else{ if((strPhoneNum==null) || "".equals(strPhoneNum)){ return ""; } String[] arrPhone=strPhoneNum.split("-"); //判断电话号码的长度是否正确,区号不是4位,电话号码不是8位,分机号不是3位的多将报错。 if(arrPhone[0].length()!=4){ return "false"; }else if(arrPhone[1].length()!=8){ return "false"; }else if(arrPhone[2].length()!=3){ return "false"; }else{ return arrPhone[1]; } } }
2、 请写一段用于整型数组排序的代码,说明你的设计思路,并利用错误推测法给出可能出错的情况(至少5种),设计出测试用例,并利用JUnit编写单元测试进行测试。(假设传入的参数已经确定为整型数组)
要求:
(1) 写出代码,并符合代码规范(命名要规范,不可直接写在main方法中,需要有类注释、方法注释、以及适当的行注释)
package com.lin.action; import java.util.Scanner; public class PaiXu { /** * 冒泡排序 * 2016/04/30 * @author 林*旺 */ public void MaoPao(){ /* * 排序的实现 * 通过手动输入需要排序的数字进行冒泡排序 */ System.out.print("请您输入要进行排序的数字个数m:"); Scanner sca=new Scanner(System.in); int m=sca.nextInt(); int i,j,tmp; int [] a = new int [m]; System.out.println("请您输入m个数:"); //得到排序前的整型数组的排列顺序的方法实现 for(i=0;i<a.length;i++) { a[i]=sca.nextInt(); } System.out.print("排序前的数:"); //得到排序后的整型数组的排列顺序的方法实现 for(i=0;i<a.length;i++) { System.out.print(a[i]+" "); } System.out.println(); for(i=0;i<m;i++) { for(j=m-1;j>i;j--) { if(a[j-1]>a[j]) { tmp=a[j]; a[j]=a[j-1]; a[j-1]=tmp; } } } System.out.print("排序后的数:"); for(i=0;i<a.length;i++) System.out.print(a[i]+" "); System.out.println(); } //对MaoPao()方法进行调用 public static void main(String [] args) { PaiXu paixu = new PaiXu(); paixu.MaoPao(); } }
(2) 说明你的设计思路
答:1.针对冒泡排序,首先要先获得数组,所以可以根据Scanner方法来自由定义要进行排列的数组里的数字个数
2.通过输入数字的先后顺序a[i]=sca.nextInt()得到数组经过冒泡排序前的数字排列顺序
3.对冒泡排序进行代码编写得到冒泡排序后数组里数字的排列顺序(具体冒泡排序方法说明就是前两个数字先进行比较得到较大的数字调到后面来,较小的数字调到前面去,然后依次比较直到最大的数字被移动到最后面。然后再重新进行第二轮比较得到第二大的数字移动到倒二的位置,以此类推最后得到各个数字由小到大依次排序,冒泡排序就算完成了。)
4.在main中对以上方法进行调用就能实现需要排序的数组的冒泡排序了
(3) 写出可能出错的情况(至少五种)
答:1.要进行排序的数组为空数组
2.进行排序的数组里的数字多是一样的
3.进行排序的数组里的数字只有一个
4.进行排序的数组里的数字已经是按照从小到大的顺序依次排列了
5.进行排序的数组里有一些数字的大小是一样的
6.进行排序的数组里的数字是按从大到小的顺序排列的
7.对进行排序的数组输入的个数大于您定义的数组个数
(4) 编写JUnit单元测试,将前面给出的可能出错的测试数据放入单元测试进行测试
答:1.要进行排序的数组为空数组
2.进行排序的数组里的数字多是一样的
3.进行排序的数组里的数字只有一个
4.进行排序的数组里的数字已经是按照从小到大的顺序依次排列了
5.进行排序的数组里有一些数字的大小是一样的
6.进行排序的数组里的数字是按从大到小的顺序排列的
7.对进行排序的数组输入的个数大于您定义的数组个数
(通过测试发现只对前面输入的限定的数字个数进行冒泡排序)