zoukankan      html  css  js  c++  java
  • 《软件测试》实验四

     白盒测试                                                       

     实验目的

    (1) 掌握静态分析代码的技巧

    (2) 学习黑盒测试中的等价类划分

    实验内容

     

    一、 找出函数中存在的问题。以下题目均在Lab04项目中完成。

     

    1、 某站点通过用户输入的用户名和密码(在login.jsp登录页中输入)来判断出现什么样的界面,如果是管理员(即用户名为admin或administrator)跳转到管理员页面(welcome_admin.jsp),非管理用户跳转到普通用户界面(welcome.jsp)。游客访问站点是,无需输入用户名和密码,直接进入普通用户界面(welcome.jsp)。

     要求:找出UserOperation.java文件中的getUserRole ()方法存在的问题,说明问题产生的原因,并修改它

     说明:不要求编写Junit单元测试用例,可以自己设想测试数据,通过静态分析,配合动态运行调试找出问题所在。

    解答:

    问题:判断方式不安全,当普通用户或游客输入的userName为admin或者administrator将直接进入管理员页面

     

    原因:只判断用户名,没有判断密码

     

    修改:

        public String getUserRole(String username, String password){

           String userRole="guest";

    If(null != password && !“”.equals(password)){

                   If(null != username && !“”.equals(username)){

    if(userName.equals("admin")||userName.equals("administrator"){

                           userRole="admin";

                         }  

                  return userRole;

    }

    else{

                          return userRole;

    }

    }

    else{

                      return userRole;

    }

     

     

     

    2、 用户注册(register.jsp)时要输入年龄字段,用户输入的参数由UserOperation.java文件中的validateUserAge()方法,转换为数值型,判断年龄是否在18~26之间(包括18和26),如果年龄在此区间内,则返回true,跳转到login.jsp页,否则弹出提示框,提示“用户年龄输入不正确”。

     

    要求:找出UserOperation.java文件中的validateUserAge()方法存在的问题,说明问题产生的原因,并修改它

     

    说明:不要求编写Junit单元测试用例,可以自己设想测试数据,通过静态分析,配合动态运行调试找出问题所在。

    答:

    问题:用户没有判断类型,不知道是否有输入值

    解决:

    public boolean validateUserAge(String userAge){

    If(null != userAge && !“”.equals(userAge)){ if(Integer.parseInt(userAge)>=18&&Integer.parseInt(userAge)<=26){

                         return true;

                        }

    else{

    return false;

    }

            }                 

    else{

    return false;

    }

    }

     二、利用黑盒测试中的等价类划分完成以下题目

    3、某程序规定:"输入三个非0正整数 a 、 b 、 c 分别作为三边的边长构成三角形(暂不考虑特殊三角形的情况)。请根据给出的说明,用等价类划分法进行划分,并给每个等价类规定唯一的编号。

     解答:

     

    所需判断

    有效

    无效

    三位非0正整数abc

    不输入0

    输入0

    输入

    空白

    输3位

    缺几位或者多几位

    输入正整数

    输入其他字符串

    构成三角形

    输入的数不构成三角形

    实例

    所需判断

    有效

    无效

    三位非0正整数abc

     

    3    4   5

     

     0   4    0

     

    3    4

    A    b   5

    1    1    1

  • 相关阅读:
    Querying for Event Information
    通过注册表查询 .Net Framework 的版本
    [Batch脚本] if else 的格式
    逆天技能
    财运是靠自己争取的,而财商是可以通过后天学习提高的
    必须冒着可能付出惨痛代价的风险前进,否则你就只能永远做个井底之蛙
    财商低的六种表现
    中国大唐集团公司 主要经营范围
    中国大唐集团公司是2002年12月29日在原国家电力公司部分企事业单位基础上组建而成的特大型发电企业集团
    中国大唐集团公司在役及在建资产分布在全国31个省区市以及境外
  • 原文地址:https://www.cnblogs.com/xianggege/p/5517579.html
Copyright © 2011-2022 走看看