软件测试第六周——白盒测试

概述:

  软件白盒测试,也称为结构化测试、基于代码的测试,是一种 测试用例设计方法,它从程序的控制结构导出测试用例。 
  用软件白盒测试产生的 测试用例能够: 
  1)保证一个模块中的所有独立 路径至少被使用一次; 
  2)对所有逻辑值均需测试true和false; 
  3)在上下边界及可操作范围内运行所有循环; 
  4)检查内部 数据结构以确保其有效性。 
  这一方法是把测试对象看作一个打开的盒子,测试人员依据程序内部 逻辑结构相关信息,设计或选择测试用例,对程序所有逻辑路径进行测试,通过在不同点检查程序的状态,确定实际的状态是否与预期的状态一致。 
  采用什么方法对软件进行测试呢?常用的 软件测试有两大类:静态测试方法和动态测试方法。其中软件的静态测试不要求在计算机上实际执行所测程序,主要以一些人工的模拟技术对软件进行分析和测试;而软件的 动态测试是通过输入一组预先按照一定的 测试准则构造的实例数据来动态运行程序,而达到发现程序错误的过程

软件白盒测试法的覆盖标准:

  六种覆盖标准: 语句覆盖、 判定覆盖、 条件覆盖、判定/条件覆盖、 条件组合覆盖和 路径覆盖发现错误的能力呈由弱至强的变化。语句覆盖每条语句至少执行一次。判定覆盖每个判定的每个分支至少执行一次。条件覆盖每个判定的每个条件应取到各种可能的值。判定/条件覆盖同时满足判定覆盖条件覆盖。条件组合覆盖每个判定中各条件的每一种组合至少出现一次。路径覆盖使程序中每一条可能的路径至少执1次

挑选软件白盒测试工具:

  软件白盒测试目前主要用在具有高可靠性要求的软件领域,例如:军工软件、航天航空软件、工业控制软件等等。软件白盒测试工具在选购时应当主要是对开发语言的支持、代码覆盖的深度、 嵌入式软件的测试、测试的可视化等。 
  对开发语言的支持:软件白盒测试工具是对 源代码进行的测试,测试的主要内容包括 词法分析与 语句分析、静态错误分析、动态检测等。但是对于不同的开发语言,测试工具实现的方式和内容差别是较大的。目前测试工具主要支持的开发语言包括:标准C、C++、Visual C++、Java、Visual J++等。 
  代码的覆盖深度:从覆盖源程序语句的详尽程度分析, 逻辑覆盖标准包括以下不同的覆盖标准:语句覆盖、判定覆盖、 条件覆盖、条件判定组合覆盖、多条件覆盖和修正 判定条件覆盖。 
  ·语句覆盖 为了暴露程序中的错误,程序中的每条语句至少应该执行一次。因此语句覆盖(Statement Coverage)的含义是:选择足够多的测试数据,使被测程序中每条语句至少执行一次。语句覆盖是很弱的逻辑覆盖。
  ·判定覆盖 比 语句覆盖稍强的覆盖标准是判定覆盖(Decision Coverage)。判定覆盖的含义是:设计足够的测试用例,使得程序中的每个判定至少都获得一次“真值”或“假值”,或者说使得程序中的每一个取“真”分支和取“假”分支至少经历一次,因此判定覆盖又称为 分支覆盖。 
  ·条件覆盖 在设计程序中,一个判定语句是由多个条件组合而成的复合判定。为了更彻底地实现逻辑覆盖,可以采用条件覆盖(Condition Coverage)的标准。条件覆盖的含义是:构造一组测试用例,使得每一判定语句中每个逻辑条件的可能值至少满足一次。 
  ·多条件覆盖 多条件覆盖也称 条件组合覆盖,它的含义是:设计足够的测试用例,使得每个判定中条件的各种可能组合都至少出现一次。显然满足多条件覆盖的测试用例是一定满足 判定覆盖、条件覆盖和条件判定组合覆盖的。 
  ·修正条件判定覆盖 修正条件判定覆盖是由欧美的航空/航天制造厂商和使用单位联合制定的“航空运输和装备系统软件认证标准”,目前在国外的国防、航空航天领域应用广泛。这个覆盖度量需要足够的测试用例来确定各个条件能够影响到包含的判定的结果。它要求满足两个条件:首先,每一个 程序模块的入口和出口点都要考虑至少要被调用一次,每个程序的判定到所有可能的结果值要至少转换一次;其次,程序的判定被分解为通过逻辑操作符(and、or)连接的布尔条件,每个条件对于判定的结果值是独立的。 
  不同的测试工具对于代码的覆盖能力也是不同的,通常能够支持修正条件判定覆盖的测试工具价格是极其昂贵的。 
  嵌入式软件的测试:对于嵌入式软件的测试,我们还需要一方面进一步考虑测试工具对于 嵌入式操作系统的支持能力,例如DOS、Vxworks、Neculeus、Linux和Windows CE等;另一方面还需要考虑测试工具对于硬件平台的支持能力,包括是否支持所有64/32/16位CPU 和 MCU,是否可以支持 PCI/VME/CPCI 总线。 
  测试的可视化:软件白盒测试是工作量巨大并且枯燥的工作,可视化的设计对于测试来说是十分重要的。在选购软件白盒测试工具时,应当考虑该款测试工具的可视化是否良好,例如: 测试过程中是否可以显示覆盖率的函数分布图和上升趋势图,是否使用不同的颜色区分已执行和未执行的 代码段显示分配内存情况实时图表等,这些对于测试效率和测试质量的提高是具有很大的作用

基本路径测试法:

  软件白盒测试的测试方法有代码检查法、静态结构分析法、静态质量度量法、 逻辑覆盖法、基本路径测试法、域测试、符号测试、Z 路径覆盖、程序变异。 
  其中运用最为广泛的是基本 路经测试法。 
  基本路径测试法是在程序控制流图的基础上,通过分析控制构造的环路复杂性,导出基本可执行路径集合,从而设计 测试用例的方法。 
  设计出的测试用例要保证在测试中程序的每个可执行语句至少执行一次。 
  在程序控制流图的基础上,通过分析控制构造的环路复杂性,导出基本可执行路径集合,从而设计测试用例。包括以下4个步骤和一个工具方法:

  4个步骤:

 

    1. 程序的 控制流图:描述程序控制流的一种图示方法。 

    2. 程序圈复杂度:McCabe复杂性度量。

    3. 导出测试用例:根据圈复杂度和程序结构设计用例数据输入和预期结果。 

    4. 准备测试用例:确保基本路径集中的每一条路径的执行

工具方法: 

  图形矩阵:是在基本 路经测试中起辅助作用的软件工具,利用它可以实现自动地确定一个基本路径集。 
  程序的 控制流图:描述程序控制流的一种图示方法。 
  圆圈称为控制流图的一个结点,表示一个或多个无分支的语句或源程序语句 
  流图只有二种图形符号:图中的每一个圆称为流图的结点,代表一条或多条语句。 
  流图中的箭头称为边或连接,代表控制流
  任何过程设计都要被翻译成控制流图。 
  如何根据程序流程图画出控制流程图? 
  在将程序流程图简化成控制流图时,应注意: 
  在选择或多分支结构中,分支的汇聚处应有一个汇聚结点。 
  边和结点圈定的区域叫做区域,当对区域计数时,图形外的区域也应记为一个区域。

软件白盒测试的优缺点:

  1. 优点

    · 迫使测试人员去仔细思考软件的实现 
    · 可以检测代码中的每条分支和路径 
    · 揭示隐藏在代码中的错误 
    · 对代码的测试比较彻底 
    · 最优化

   2. 缺点 

    · 昂贵 
    · 无法检测代码中遗漏的路径和数据敏感性错误 
    · 不验证规格的正确性

  

posted @ 2015-04-19 19:13  一班&范世良  阅读(216)  评论(0编辑  收藏  举报