第三次博客作业
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) 写出问题所在
答:①电话号码为11位数字
②数据必须是0到9之间的数字,如字母之类的肯定不行
(2) 写出问题产生的原因
答:判断语句没有考虑数据类型。
(3) 给出修改后的代码
public String getPhoneNumber(String strPhoneNum){
if((strPhoneNum==null) || "".equals(strPhoneNum)){
return "";
}
if (strPhoneNum.length() != 11) {
throw new Exception("输入号码有误");
}
for (int i = 2; i < strPhoneNum.length(); i++) {
char p = strPhoneNum.charAt(i);
if (p < '0' || p > '9') {
throw new Exception("输入号码有误");
}
}
String[] arrPhone=strPhoneNum.split("-");
return arrPhone[1];
}
2、 请写一段用于整型数组排序的代码,说明你的设计思路,并利用错误推测法给出可能出错的情况(至少5种),设计出测试用例,并利用JUnit编写单元测试进行测试。(假设传入的参数已经确定为整型数组)
要求:
(1) 写出代码,并符合代码规范(命名要规范,不可直接写在main方法中,需要有类注释、方法注释、以及适当的行注释)
package CN.SU;
public class S {
public static int[] selectSort(int[] array){
int position=0;
for(int i=0;i<array.length;i++){
int j=i+1;
position=i;
int temp=array[i];
for(;j<array.length;j++){
if(array[j]<temp){
temp=array[j];
position=j;
}
}
array[position]=array[i];
array[i]=temp;
}
return array;
}
public static void main(String args[]){
int[] array = {4,7,5,2,3};
S sort = new S();
int[] b=sort.selectSort(array);
for(int i = 0;i<b.length;i++){
System.out.println(b[i]);
}
}
}
(2) 说明你的设计思路
答:数组排序为简单排序,方法是首先选出最小的一个数与第一个位置的数交换;然后在剩下的数当中再找最小的与第二个位置的数交换,如此循环到倒数第二个数和最后一个数比较为止。
(3) 写出可能出错的情况(至少五种)
1、数组没有数字
2、数组有相同数字(如:1,9,9,4,7)
3、数组中的元素有负数存在(如:6,-4,8,1,7)
4、数组数字0开头(如:0,1,5,7,3.6)
5、数组中的元素顺序已经排好(如:1,2,3,4,5)
(4) 编写JUnit单元测试,将前面给出的可能出错的测试数据放入单元测试进行测试
1、数组没有数字
2、数组有相同数字
3、数组中的元素有负数存在
4、数组数字0开头
5、数组中的元素顺序已经排好