《the art of software testing》第四章 测试用例的设计

白盒测试

逻辑覆盖测试:

逻辑覆盖是以程序内部的逻辑结构为基础的设计测试用例的技术。它属白盒测试。白盒测试的测试方法有代码检查法、静态结构分析法、静态质量度量法、逻辑覆盖法、基本路径测试法、域测试、符号测试、Z路径覆盖、程序变异。白盒测试法的覆盖标准有逻辑覆盖、循环覆盖和基本路径测试。
  • 语句覆盖:语句覆盖又称行覆盖、段覆盖、基本块覆盖,常被称为“最弱的覆盖”,它只覆盖代码中的执行语句,却不考虑各种分支的组合等等。

  • 判定覆盖:设计若干个测试用例,要求每个判断都必须有“是”和“否”的结果,并且每条分支路径都必须至少遍历一次。(较强准则的覆盖)

  • 条件覆盖:条件覆盖是指选择足够的测试用例以确保将一个判断中的每个条件的所有可能的结果至少执行一次,因为,就如同判定覆盖的情况一样,这并不总是能让每条语句都执行到,因此作为对这条准则的补充就是对程序或子程序,包括 ON 单元的每一个入口点都至少调用一次。。(更强准则的覆盖)

  • 判定/条件覆盖:将一个判断中的每个条件的所有可能的结果至少执行一次,将每个判断的每个条件的所有可能的结果至少执行一次,将每个判断的所有可能的结果至少执行一次,将每个入口点都至少调用一次。

  • 多重条件覆盖:该准则要求编写足够多的测试用例,将每个判定中的所有可能的条件结果的组合,以及所有的入口点都至少执行一次。

黑盒测试

等价类划分:

  • 测试时,如果我们将程序的输入范围进行划分,将其划分为有限数量的等价类,这样就可以合理的假设测试每个等价类的代表性数据等同于测试该类的其他任何数据

  • 使用等价划分方法设计测试用例主要有两个步骤:
    (1)确定等价类
    (2)生成测试用例

边界值分析:

  • 考虑了边界条件的测试用例具有更高的测试回报率
  • 所谓边界条件,是指输入和输出等价类中那些恰好处于边界、或超过边界、或在边界以下的状态。
    (看了一下课本P32的例子,似懂非懂)

边界值分析和等价划分的一个弱点是未对输入条件的组合进行分析

因果图:

  • 因果图是一种形式语言,用自然语言描述的规格说明可以转换为因果图。

  • 下面附上一张基本的因果图符号:

      每个结点的值为 0 或为 1,0代表“不存在”状态,1 代表“存在”状态。identity 函数表示如果 a 等于 1,则b 也为 1,否则 b 为 0。not 函数表示如果 a 等于 1, 则 b 为 0,否则 b 为 1。  or 函数表示如果 a 或 b 或 c 等于 1,则 d 为 1,否则 d 为 0。and 函数表示如果 a 和 b 都等于 1,则 c 为 1,否则 c 为 0。 后两个函数(or 和 and)允许存在任意数量的输入。
    

  • 生成测试用例时采用的过程如下:

      1.将规格说明分解为可执行的片段。这是必须的步骤,因为因果图不善于处理较大的规格说明。
      
      2.确定规格说明中的因果关系。
      
      3.分析规格说明的语义内容,并将其转换为连接因果关系的布尔图。
      
      4.给图加上注解符号,说明由于语法或环境的限制而不能联系起来的“因”和“果”。
      
      5.通过仔细地跟踪图中的状态变化情况,将因果图转换成一个**有限项的判定表**。表中的每一列代表一个测试用例。
      
      6.将判定表中的列转换成测试用例。
    
    (`结合P48页的例子了解因果图,感觉将因果图转化为判定表是比较有难度的部分!)`
    

测试策略

一组合理的策略如下:

  1. 如果规格说明中包含输入条件组合的情况,应首先使用因果图分析方法。
  2. 在任何情况下都应使用边界值分析方法。应记住,这是对输入和输出边界进行的分析。边界值分析可以产生一系列补充的测试条件,但是,也正如“因果图分析”一节所述,多数甚至全部条件都可以被整合到因果图分析中。
  3. 应为输入和输出确定有效和无效等价类,在必要情况下对上面确认的测试用例进行补充。
  4. 使用错误猜测技术增加更多的测试用例。
  5. 针对上述测试用例集检查程序的逻辑结构。应使用判定覆盖、条件覆盖、判定/条件覆盖或多重条件覆盖准则(最后的一个最为完整)。如果覆盖准则未能被前四个步骤中确定的测试用例所满足,并且满足准则也并非不可能(由于程序的性质限制,某些条件的组合也许是不可能实现的),那么增加足够数量的测试用例,以使覆盖准则得到满足。

体会

本章中,主要还是了解了些概念性的内容。包括白盒测试的语句覆盖、判定覆盖、条件覆盖、判定/条件覆盖、多重条件覆盖;黑盒测试的等价类划分、边界值分析、因果图分析、错误猜测。看书的过程不是很细,包括书上的例子看完后也是似懂非懂的感觉。。。。

posted @ 2015-10-08 23:08  adacn  阅读(300)  评论(0编辑  收藏  举报