白盒测试
概念与定义
-
白盒测试:侧重于系统或部件内部机制的测试,类型分为分支测试(判定节点测试)、路径测试、语句测试。
-
控制流分析(基于程序结构):控制流分析是一类用于分析程序控制流结构的静态分析技术,目的在于生成程序的控制流图,在编译器设计程序分析、程序理解等领域都有重要应用。
-
逻辑覆盖测试(对判定的测试)的原理:以程序内部的逻辑结构为基础的用例设计方法,它通过对程序的逻辑结构的遍历,来实现测试对程序的覆盖。
-
测试覆盖率:度量测试完整性的指标,是测试有效性的一个度量。
\[覆盖率 = \frac{至少被执行一次的item总数}{item总数} \]测试覆盖率不需要100%,因为覆盖率越高,测试成本越高。
通常可以设置一个覆盖率达标标准。
-
语句覆盖:设计测试用例时应保证程序中每一条可执行语句至少应执行一次。(点覆盖)
-
判定覆盖(分支覆盖):设计测试用例时应保证程序中每个判定节点取得每种可能的结果至少一次。或者程序中每个判定的真分支和假分支至少执行一次。(边覆盖)
-
条件覆盖:设计测试用例时应保证程序中每个复合判定表达式中,每个简单判定条件(子条件)的取真和取假情况至少执行一次。
-
判定-条件覆盖:设计测试用例时应满足判定节点的取真、取假分支至少执行一次,且每个简单判定条件(子条件)的取真和取假情况也至少执行一次。即判定覆盖+条件覆盖。
-
条件组合覆盖:条件组合覆盖,设计测试用例时应满足每个判定节点中,所有简单判定条件(子条件)的所有可能的取值组合情况至少执行一次。通过列出真值表的方式来得到完全的覆盖。
-
路径覆盖:要求设计足够的测试用例,运行被测程序,覆盖程序中所有可能组合的路径。
-
程序图:简化的程序流程图,不关注源代码细节,只关注程序的基本结构。
-
环复杂度:用于描述程序结构复杂度的度量。
-
基本路径测试:在程序的控制流图的基础上,通过分析控制流程的环路复杂性,导出独立可执行路径集合,从而设计测试用例的方法。
-
静态白盒测试:又称为结构分析,是在不执行程序的条件下审查软件设计、体系结构和代码,从而找出软件缺陷的过程。测试对象是文档、代码等非计算机执行的部分。
简答
白盒测试关注的对象
源代码和程序结构。
白盒测试的优缺点
优点:
- 针对性强,便于快速定位,测试效率高;
- 在函数级别开始测试工作,缺陷修复的成本低;
- 通过不同的白盒覆盖指标有助于了解和衡量对被测对象的测试覆盖程度,
- 有助于代码优化和缺陷预防。
缺点:
- 对测试人员的技术要求高。
- 成本高。
白盒测试的问题
- 软件测试是不完备的;
- 软件测试是有风险的;
- 测试设计应达到的目标:提高效率、降低风险、在代码级别上提高软件质量。
各种程序结构以及它们的复杂程度
程序结构有:线性结构(顺序结构),条件判定结构,循环结构,以及这些结构的组合。
复杂程度:
\[线性结构 < 二分支的条件判定 < 多分支的条件判定 < 循环结构 \]逻辑覆盖测试的六种测试方法
-
语句覆盖
缺点:关注语句,而非关注判定节点。对隐式分支无效。
-
判定覆盖(分支覆盖)
局限性:判定覆盖仅关心表达式的整体取值,并不关心表达式如何构成,不能覆盖到每个子条件的所有取值情况,由此导致测试的漏洞。
-
条件覆盖
局限性:条件覆盖并不能确保满足判定覆盖。
-
判定-条件覆盖(分支-条件覆盖)
-
条件组合覆盖
优点:
- 条件组合覆盖准则满足语句覆盖、判定覆盖、条件覆盖、判定-条件覆盖准则;
- 方法简单;只需要找到所有简单条件,并列出真值表,穷尽所有组合情况即可。
局限性:
- 条件组合覆盖不能保证所有组合的路径被执行;
- 测试用例太多;
- 冗余严重。
-
路径覆盖
覆盖面最广。
100%满足路径覆盖,一定能100%满足判定覆盖标准;但并不一定能100%满足条件覆盖和判定-条件覆盖,也就不能满足100%条件组合覆盖。
各种覆盖之间的关系
- 语句覆盖太弱;
- 判定覆盖、条件覆盖不够全面;
- 判定-条件覆盖设计难度大;
- 条件组合覆盖的测试用例数量太多,不能将所有路径覆盖;
- 路径覆盖的测试用例复杂且数量多,不能将所有的条件组合覆盖。
单独采用任何一种逻辑覆盖方法都不能完全覆盖所有的测试用例,任何一个高效的测试用例,都是针对具体测试场景的。
环复杂度的计算
直观观察法
观察程序图将二维平面分割为封闭区域和开放区域的个数。
公式计算法
方法一:
\[V(G) = E-N+2 \]其中,\(E\) 是边数, \(N\) 是节点或顶点数。
前提条件:单入口单出口。
例题:
\[V(G)=E-N+2=10-7+2=5 \]方法二:
\[V(G)=E-N+1 \]前提条件:无孤立节点,强连通图。如果非强连通图,则需要先添加辅助线。如下图的蓝线。
\[V(G)=E-N+1=11-7+1=5 \]简单地说,强连通图就是图中任意两个点相互可达。
判定节点法
\[V(G)=P+1 \]其中,\(P\) 是二分支判定节点的个数。
前提条件:仅计算二分支的判定节点。
如果没有判定节点,只有一条执行路径,则\(V=1\)。
如上图,二分支判定节点分别有:A,B,C,D。
因此,\(V(G)=P+1=4+1=5\).
特殊情况的计算
环复杂度的计算公式都有特定的前提条件,遇到特殊情况,则使用其它可以使用的公式。
- 左图,非单入单出,不能使用公式计算法的方法一,可以使用判定节点法,V=5
- 右图,非二分支判定节点,不能使用判定节点法,可以使用公式计算法方法一,V=13
基本路径测试的流程
-
生成路径地图
-
确定独立路径集合的规模
计算环复杂度\(V\),则需要\(V\)条独立路径。
-
找出一组独立路径。
- 确定主路径(出错概率最高的路径,或者缺陷对用户影响最大的路径)。
- 根据主路径抽取其它独立路径。
静态白盒测试的方法
- 代码检查
- 静态结构分析
- 静态质量度量
同行评审的一般流程
- 计划评审会议
- 召开评审预备会
- 准备评审会议
- 召开评审会议
- 召开第三小时会议
- 修复缺陷
- 确认修复
同行评审的五种角色
- 主持人:负责组织评审会议;
- 讲解员:负责讲解被评审的工作产品;
- 记录员:负责记录缺陷和决议;
- 作者:程序编写者,负责提供被提审的工作产品;
- 评审员:程序设计者、测试专家,负责评审工作产品,也负责设计测试用例。