白盒测试定义:
基于系统或者组件的内部实现结构和逻辑寻找缺陷的测试技术。
白盒测试很多时候是不可能进行彻底的。
白盒测试法检查程序内部逻辑结构,对所有逻辑路径进行测试,是一种穷举路径的测试方法。
穷举路径测试无法检查出程序本身是否违反了设计规范,即程序是否是一个错误的程序。
穷举路径测试不可能查出程序因为遗漏路径而出错。
穷举路径测试发现不了一些与数据相关的错误。
白盒测试的方法:
①基本路径测试方法:
根据流程图画出控制流图,计算环复杂度,列出基本路径。
环复杂度是等于基本路径的数量的。
环复杂度的计算:等于闭合区域数目(包含整体这个大闭合区域),也等于二值判断点+1,也等于边的数目-节点数+2。
②逻辑覆盖法:语句覆盖,条件覆盖,判定覆盖,判定和条件覆盖,组合覆盖,路径覆盖。
语句覆盖:选择足够多的测试用例,使得程序中的每个可执行语句至少执行一次。
判定覆盖:通过执行足够的测试用例,使得程序中的每个判定至少都获得一次“真”值和“假”值, 也就是使程序中的每个取“真”分支和取“假”分支至少均经历一次,也称为“分支覆盖”。
条件覆盖:设计足够多的测试用例,使得程序中每个判定包含的每个条件的可能取值(真/假)都至少满足一次。
判定/条件覆盖:设计足够多的测试用例,使得程序中每个判定包含的每个条件的所有情况(真/假)至少出现一次,并且每个判定本身的判定结果(真/假)也至少出现一次。
组合覆盖:通过执行足够的测试用例,使得程序中每个判定的所有可能的条件取值组合都至少出现一次。
语句覆盖,条件覆盖,判定覆盖,判定和条件覆盖,组合覆盖之间的关系图:
路径覆盖:设计足够多的测试用例,要求覆盖程序中所有可能的路径。
在满足组合覆盖的测试用例中修改其中一个测试用例,则可以实现路径覆盖。