一、 找出函数中存在的问题。以下题目均在Lab04项目中完成。
1、 某站点通过用户输入的用户名和密码(在login.jsp登录页中输入)来判断出现什么样的界面,如果是管理员(即用户名为admin或administrator)跳转到管理员页面(welcome_admin.jsp),非管理用户跳转到普通用户界面(welcome.jsp)。游客访问站点是,无需输入用户名和密码,直接进入普通用户界面(welcome.jsp)。
要求:找出UserOperation.java文件中的getUserRole ()方法存在的问题,说明问题产生的原因,并修改它。
说明:不要求编写Junit单元测试用例,可以自己设想测试数据,通过静态分析,配合动态运行调试找出问题所在。
2、 用户注册(register.jsp)时要输入年龄字段,用户输入的参数由UserOperation.java文件中的validateUserAge()方法,转换为数值型,判断年龄是否在18~26之间(包括18和26),如果年龄在此区间内,则返回true,跳转到login.jsp页,否则弹出提示框,提示“用户年龄输入不正确”。
要求:找出UserOperation.java文件中的validateUserAge()方法存在的问题,说明问题产生的原因,并修改它。
1.
问题:登陆方式不安全,当游客或只输入admin或administrator就可调到管理员界面
原因:没有设置密码,进行密码判断。
修改:
public String getUserRole(String userName){
String userRole="guest";
String userPassword="123456";
if((userName.equals("admin") || userName.equals("administrator")) && userPassword.equals("123456")){
userRole="admin";
userPassword="123456";
}
return userRole;
}
2.
问题:对输入的年龄为进行判断,是否输入的是合法的,是否输入了其他字符串,以及未进行长度判断。
修改:
public boolean validateUserAge(String userAge){
if(null != userAge && !"".equals(userAge)){
if(Integer.parseInt(userAge)>=18 && Integer.parseInt(userAge)<=26){
return true;
}
return false;
}
return false;
}
}
说明:不要求编写Junit单元测试用例,可以自己设想测试数据,通过静态分析,配合动态运行调试找出问题所在。
二、利用黑盒测试中的等价类划分完成以下题目
3、某程序规定:"输入三个非0正整数 a 、 b 、 c 分别作为三边的边长构成三角形(暂不考虑特殊三角形的情况)。请根据给出的说明,用等价类划分法进行划分,并给每个等价类规定唯一的编号。
输入条件 |
有效等价类 |
无效等价类 |
是否是三角形 |
(1) a>0, (2) b>0 (3) c>0 (4) a+b>c (5) b+c>a (6) a+c>b |
(7)a<=0 (8) b<=0 (9) c<=0 (10)a+b<=c (11)b+c<=a (12)a+c<=b |
序号 |
a,b,c |
覆盖等价类 |
输出 |
1 |
3, 4 , 5 |
(1)(2)(3)(4)(5)(6) |
一般三角形 |
2 |
0 ,1 ,2 |
(7) |
不能构成三角形 |
3 |
1 ,0 ,3 |
(8) |
|
4 |
1 ,4 ,0 |
(9) |
|
5 |
1 ,2 ,3 |
(10) |
|
6 |
1 ,3 ,2 |
(12) |
|
7 |
3 ,1 ,2 |
(11) |