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) 给出修改后的代码
答案:
(1)问题所在
①:
电话号码输入应为数字且限制长度为11位
②:
区号-电话号码—分机号的格式为4位区号,8位直播号码,3位分机号
③:
public String getPhoneNumber(String strPhoneNum){ if((strPhoneNum==null) || "".equals(strPhoneNum)){ return ""; }
}
(2) 问题产生的原因:
原因一:问题一中输入的电话号码为null,但是却返回""
原因二:原系统代码不够完善、不严格
(3) 给出修改后的代码:
public String getPhoneNumber(String strPhoneNum)
{
if((strPhoneNum==null) || strPhoneNum.equals("")){
System.out.println("输入的电话号码不能为空");
return false;
}
if (strPhoneNum.length() != 11) {
throw new Exception("电话号码必须长11位");
}
for (int i = 2; i < strPhoneNum.length(); i++) {
char p = strPhoneNum.charAt(i);
if (p < '0' || p > '9') {
throw new Exception("电话号码必须由数字组成!");
}
}
String format="((\d{11})|^((\d{7,8})|(\d{4}|\d{3})-(\d{7,8})|(\d{4}|\d{3})-(\d{7,8})-(\d{4}|\d{3}|\d{2}|\d{1})|(\d{7,8})-(\d{4}|\d{3}|\d{2}|\d{1}))$)";
if(strPhoneNum.matches(format))
{
return true;
}
else{
return false;
System.out.println("输入的电话号码格式不正确");
}
}
String[] arrPhone=strPhoneNum.split("-");
return arrPhone[1];
}
2、 请写一段用于整型数组排序的代码,说明你的设计思路,并利用错误推测法给出可能出错的情况(至少5种),设计出测试用例,并利用JUnit编写单元测试进行测试。(假设传入的参数已经确定为整型数组)
要求:
(1) 写出代码,并符合代码规范(命名要规范,不可直接写在main方法中,需要有类注释、方法注释、以及适当的行注释)
(2) 说明你的设计思路
(3) 写出可能出错的情况(至少五种)
(4) 编写JUnit单元测试,将前面给出的可能出错的测试数据放入单元测试进行测试
答案:
(1) 写出代码,并符合代码规范(命名要规范,不可直接写在main方法中,需要有类注释、方法注释、以及适当的行注释)
public class haha {
public static int[] paixu(int[] x){
for(int i = 0 ;i<x.length ;i++){
for(int j= i+1; j<x.length; j++){
if(x[i]>x[j]){
int temp = x[i];
x[i] = x[j];
x[j] = temp;
}
}
}
for(int i:x){
//将x的值赋给i
System.out.println(i + "");
}
return x;
}
public static void main(String[] args) {
// TODO Auto-generated method stub
int[] i={8,9,56,5,6,13,-9,-4,20,4,67,6495,22};
System.out.println("排序后的结果为:");
//调用排序paixu(i)
paixu(i);
System.out.println();
}
}
(2)设计思路:
运用冒泡排序
(3) 写出可能出错的情况(至少五种)
1、数组里面没有数字
2、存在负数的情况
3、数字完全相同
4、有负数
5、以0开头,比如08