第三次博客作业

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、数组中的元素顺序已经排好

时间: 2024-12-29 01:58:49

第三次博客作业的相关文章

C语言第三次博客作业---单层循环结构

一.PTA实验作业 题目1:最佳情侣身高差 1.实验代码 int N,i; double height; //height表示身高 char sex; //sex表示性别 (height>=1.0&&height<=3.0); (N>0&&N<=10); scanf("%d",&N); for(i=1;i<=N;i++){ scanf("\n%c%lf",&sex,&height)

闽江学院2015-2016学年下学期《软件测试》课程-第三次博客作业

1.  某网站管理系统,用户注册时,电话号码为可选输入项,输入格式为:区号-电话号码—分机号,中间用“-”隔开.以下为jsp页面上的设计,且并未对输入做任何控制. 假设系统现在需要取出中间的电话号码部分,代码如下: /** * * 该方法根据用户输入取出中间的电话号码部分 * @param strPhoneNum 电话号码,如:“0591-83279988—002” * @return 返回号码部分,如:“83279988” */ public String getPhoneNumber(Str

软件学院《软件测试》课程第三次博客作业

1.  某网站管理系统,用户注册时,电话号码为可选输入项,输入格式为:区号-电话号码—分机号,中间用“-”隔开.以下为jsp页面上的设计,且并未对输入做任何控制. 假设系统现在需要取出中间的电话号码部分,代码如下: /** * * 该方法根据用户输入取出中间的电话号码部分 * @param strPhoneNum  电话号码,如:“0591-83279988—002” * @return  返回号码部分,如:“83279988” */ public String getPhoneNumber(S

13软金2班吴思婷——第三次博客作业

1. 某网站管理系统,用户注册时,电话号码为可选输入项,输入格式为:区号-电话号码—分机号,中间用“-”隔开.以下为jsp页面上的设计,且并未对输入做任何控制. 假设系统现在需要取出中间的电话号码部分,代码如下: /** * * 该方法根据用户输入取出中间的电话号码部分 * @param strPhoneNum  电话号码,如:“0591-83279988—002” * @return  返回号码部分,如:“83279988” */ public String getPhoneNumber(St

软件测试第三次博客作业

1.  某网站管理系统,用户注册时,电话号码为可选输入项,输入格式为:区号-电话号码—分机号,中间用“-”隔开.以下为jsp页面上的设计,且并未对输入做任何控制. 假设系统现在需要取出中间的电话号码部分,代码如下: /** * * * @param PhoneNum 电话号码,如:“0760-8888888—011” * @return 返回号码部分,如:“8888888” */ public String getPhoneNumber(String strPhoneNum){ if((strP

《软件测试》 第三次博客作业

1.  某网站管理系统,用户注册时,电话号码为可选输入项,输入格式为:区号-电话号码—分机号,中间用“-”隔开.以下为jsp页面上的设计,且并未对输入做任何控制. 假设系统现在需要取出中间的电话号码部分,代码如下: /** * * 该方法根据用户输入取出中间的电话号码部分 * @param strPhoneNum  电话号码,如:“0591-83279988—002” * @return  返回号码部分,如:“83279988” */ public String getPhoneNumber(S

第三次 博客作业

1.  某网站管理系统,用户注册时,电话号码为可选输入项,输入格式为:区号-电话号码—分机号,中间用“-”隔开.以下为jsp页面上的设计,且并未对输入做任何控制. 假设系统现在需要取出中间的电话号码部分,代码如下: /** * * 该方法根据用户输入取出中间的电话号码部分 * @param strPhoneNum 电话号码,如:“0591-83279988—002” * @return 返回号码部分,如:“83279988” */ public String getPhoneNumber(Str

第三次博客作业package com.fry; //导入java.util.Arrays; import java.util.Arrays; public class Demo1 { public static void main(String[]args){ //创建对象,对象名为hello Demo1 hello =new Demo1(); //调用方法并将返回值保存在变量中

1.  某网站管理系统,用户注册时,电话号码为可选输入项,输入格式为:区号-电话号码—分机号,中间用“-”隔开.以下为jsp页面上的设计,且并未对输入做任何控制. 假设系统现在需要取出中间的电话号码部分,代码如下: /** * * 该方法根据用户输入取出中间的电话号码部分 * @param strPhoneNum 电话号码,如:“0591-83279988—002” * @return 返回号码部分,如:“83279988” */ public String getPhoneNumber(Str

C语言博客作业--一二维数组

一.PTA实验作业 题目1:7-2 求整数序列中出现次数最多的数 1. 本题PTA提交列表 2. 设计思路 定义变量n,i,j,max等于0,a[]10用于存放输入的值,b[10]用于存放a[]中各个数有多少个; 输入n的值 i从0开始,每次加1,输入a[i]的值,直到i==n结束循环 i从0开始,判断i是否<n,,进入下一步,每次加一,直到条件不满足 j从0开始,判断j是否<n,,进入下一步,每次加一,直到条件不满足 如果a[i]==a[j],b[i]加一 i从0开始,判断i是否 输出a[j