标签:
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) 给出修改后的代码
public String getPhoneNumber(String strPhoneNum){
if((strPhoneNum == null)|| "".equals(strPhoneNum)){
return "";
}
if(strPhoneNum.length() == 17){
for(int i=0;i<=17;i++){
result = strPhoneNum.substring(5, 12);
}
}else{
return result = "error!";
}
return result;
}
2、 请写一段用于整型数组排序的代码,说明你的设计思路,并利用错误推测法给出可能出错的情况(至少5种),设计出测试用例,并利用JUnit编写单元测试进行测试。(假设传入的参数已经确定为整型数组)
要求:
(1) 写出代码,并符合代码规范(命名要规范,不可直接写在main方法中,需要有类注释、方法注释、以及适当的行注释)
package cn.wjw.select; //选择排序
public class ArraySort {
public int[] arraySort (int[] arr){
for(int i=0;i<arr.length-1;i++){
for (int j=i+1;j<arr.length; j++ ){
if(arr[i]<arr[j]){
int temp=arr[i];
arr[i]=arr[j];
arr[j]=temp;//由大到小开始选择排序
}
}
}
return arr;
}
public static void main(String[] args){
int[] num = {4,8,16,9,46};
ArraySort x = new ArraySort();
int[] y=x.arraySort(num);
for(int a = 0;a<y.length;a++){
System.out.println(y[a]);
}
}
}
(2) 说明你的设计思路
首先,第一个for循环定义了i,并且不能是最后一位;第二个循环定义了j,j在i的后面。将i和j二者相比较,如果i比j小,那么j就往前挪一位,最后得到由大到小的排序。
(3) 写出可能出错的情况(至少五种)
输入的数组只含一个元素;
数组已经排好了顺序;
数组为空的情况;
数组中的部分或全部元素相同时。
数组已按逆序排好;
(4) 编写JUnit单元测试,将前面给出的可能出错的测试数据放入单元测试进行测试
标签:
原文地址:http://www.cnblogs.com/zhanglin-/p/5444964.html