标签:
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) 写出问题所在
A、 没有定义数据的类型,电话号码类型肯定要是数字的,没有定义不能是字母类型的输入值。
B、 没有定义输入的电话号码的长度,电话号码为8位,没有定义的话,程序就可以随意输入长度。
(2) 写出问题产生的原因
原因:因为代码在if子句中的判定条件不够完整。
(3) 给出修改后的代码
修改后的代码多添加了判断输入的电话号码的数据类型和输入长度的限制。代码如下:
2、 请写一段用于整型数组排序的代码,说明你的设计思路,并利用错误推测法给出可能出错的情况(至少5种),设计出测试用例,并利用JUnit编写单元测试进行测试。(假设传入的参数已经确定为整型数组)
要求:
(1) 写出代码,并符合代码规范(命名要规范,不可直接写在main方法中,需要有类注释、方法注释、以及适当的行注释)
代码如下:
(2) 说明你的设计思路
思路:就像以前学习数据结构里面的简单排序那样的思想,每次从左往右扫描数组,将最小的放在前面,依次循环直到照玩倒数第二大的数放在倒数第二个位置上。
写出可能出错的情况(至少五种)
A、 数组中出现负数,我们代码中没有编写负数与正数比较,就筛选不出大小了。(6,1,2,-1,5)
B、 数组中出现两个或者几个相同的数,代码没有并列数的功能。(5,5,1,9,2)
C、 数组以0开头。(0,8,5,1,2)
D、 原数组已经是排好序的了。(1,2,3,4,5)
E、 数组中的数出现小数类型的数值。(1,6,3,0.1,8)
(1) 编写JUnit单元测试,将前面给出的可能出错的测试数据放入单元测试进行测试
A、 数组中出现负数,我们代码中没有编写负数与正数比较,就筛选不出大小了。(6,1,2,-1,5)
B、数组中出现两个或者几个相同的数,代码没有并列数的功能。(5,5,1,9,2)
C、数组以0开头。(0,8,5,1,2)
D、原数组已经是排好序的了。(1,2,3,4,5)
E、数组中的数出现小数类型的数值。(1,6,3,0.1,8)
标签:
原文地址:http://www.cnblogs.com/thereisa/p/5449570.html