第三次博客作业

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 写出问题所在

<1>输入类型是否为数字

<2>输入长度为多少

2 写出问题产生的原因

<1>没有明确定义类型

<2>没有明确定义长度

3 给出修改后的代码

 package cn.zhang.aa;

public class PhoneNum {

 public String getPhoneNumber(int[] quhao,int[] dianhuahao,int[] fenjihao){

        if(quhao.length==4&&dianhuahao.length==8&fenjihao.length==3){

         return "true";

        }

        else if("".equals(quhao)||" ".equals(dianhuahao)||"".equals(fenjihao)){

         return "false";

        }

 return dianhuahao;

    }

}

2  请写一段用于整型数组排序的代码,说明你的设计思路,并利用错误推测法给出可能出错的情况(至少5种),设计出测试用例,并利用JUnit编写单元测试进行测试。(假设传入的参数已经确定为整型数组)

要求:

(1) 写出代码,并符合代码规范(命名要规范,不可直接写在main方法中,需要有类注释、方法注释、以及适当的行注释)

public class Demo{
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
int[] arg={6,6,44,66,22,33,1,23,11};
int[] arg1 =test2.arr(arg);
for(int k = 0;k<arg1.length;k++){
System.out.print(arg1[k]+"\t");
}
}
public static int[] arr(int arr[]){
int tmp;
for(int i=0;i<arr.length;i++){
for (int j=0;j<arr.length;j++){
if(arr[i]<arr[j]){
tmp=arr[i];
arr[i]=arr[j];
arr[j]=tmp;
}
}
}
return arr;

}
}

 

2) 说明你的设计思路

设计思路

首先先从用户端获取一组数组。然后着手写arr方法也就是数组排序的方法;用了两个循环来嵌套进行冒泡排序;第一层循环是用来做被比较的对象的;然后第二层循环是用来跟第一层循环进行对比的;然后设置一个临时值充当缓冲区来临时保存数值;返回arr数组;打印新的数组;

3) 写出可能出错的情况(至少五种)

1:输入的非数字就报错;

2:数组元素都一样

posted @ 2016-05-13 11:48  指缝间的阳光~  阅读(107)  评论(0编辑  收藏  举报