白盒测试到底是什么?

今天去面试,技术面试官问我白盒测试具体是怎么个过程(我上家公司是做白盒测试工具的,我的上一份工作就是测试这个白盒测试工具)

我所理解的白盒测试过程,就是先了解被测模块内部结构,基于逻辑来设计用例来测试,白盒测试的标准主要是覆盖率数据

覆盖率分为,基本语句块覆盖率SC0,条件真语句块覆盖率TRUE,条件假语句覆盖率FALSE,条件真假语句都执行覆盖率BOTH,条件分支语句覆盖Branch,和判定覆盖C/DC(条件真假分支都覆盖),修正判定覆盖MC/DC(这个需要足够的测试用例来确定各个条件能够影响到包含的判定的结果。要求满足两个条件:首先,每一个程序模块的入口和出口点都要考虑至少要被调用一次,每个程序的判定到所有可能的结果值要至少转换一次;其次,程序的判定被分解为通过逻辑操作符(and、or)连接的布尔条件,每个条件对于判定的结果值是独立不同的)

白盒测试,一部分是静态测试,即分析代码是否规范,代码结构分析,另一部分就是动态测试,即设计预期输入,查看输出是否符合预期结果。

以上,是我回答面试官的问题;

面试官认为我回答的比较浅面,没有讲到具体怎么去实现,这就有点让我怯场了,当时是面试官又问了其它的,然后回来后,我也是及时搜索相关词条(百度),补充下白盒测试其它的方法。

如下:

白盒测试的测试方法中运用最为广泛的是基本路径测试法。
基本 路径测试法是在程序控制流图的基础上,通过分析控制构造的环路复杂性,导出基本可执行 路径集合,从而设计测试 用例的方法。设计出的 测试用例要保证在测试中 程序的每个可执行语句至少执行一次。
程序控制流图的基础上,通过分析控制构造的环路复杂性,导出基本可执行路径集合,从而设计 测试用例。包括以下4个步骤和一个工具方法:
1. 程序 控制流图:描述程序控制流的一种图示方法。
2. 程序 圈复杂度:McCabe复杂性度量。从 程序的环路复杂性可导出程序基本 路径集合中的独立路径条数,这是确定程序中每个可执行语句至少执行一次所必须的测试用例数目的 上界
3. 导出 测试用例:根据圈复杂度和 程序结构设计用例数据输入和预期结果。
4. 准备 测试用例:确保基本 路径集中的每一条路径的执行。

工具方法

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

步骤

基本 路径测试法的步骤:
第一步:画出 控制流图
流程图用来描述程序控制结构。可将 流程图映射到一个相应的流图(假设流程图的菱形决定框中不包含复合条件)。在流图中,每一个圆,称为流图的结点,代表一个或多个语句。一个处理方框序列和一个菱形决测框可被映射为一个结点,流图中的箭头,称为边或连接,代表 控制流,类似于流程图中的箭头。一条边必须终止于一个结点,即使该结点并不代表任何语句(例如:if-else-then结构)。由边和结点限定的范围称为区域。计算区域时应包括图外部的范围。
第二步:计算圈复杂度
圈复杂度是一种为 程序逻辑复杂性提供定量测度的 软件度量,将该度量用于计算程序的基本的独立路径数目,为确保所有语句至少执行一次的测试数量的 上界。独立路径必须包含一条在定义之前不曾用到的边。
有以下三种方法计算圈复杂度:
流图中区域的数量对应于环型的复杂性;
给定流图G的圈复杂度V(G),定义为V(G)=E-N+2,E是流图中边的数量,N是流图中结点的数量;
给定流图G的圈复杂度V(G),定义为V(G)=P+1,P是流图G中判定结点的数量。
第三步:导出 测试用例 根据上面的计算方法,可得出四个独立的路径。(一条独立路径是指,和其他的独立路径相比,至少引入一个新处理语句或一个新判断的 程序通路。V(G)值正好等于该 程序的独立路径的条数。)
路径1:4-14
路径2:4-6-7-14
路径3:4-6-8-10-13-4-14
路径4:4-6-8-11-13-4-14
根据上面的独立 路径,去设计输入数据,使 程序分别执行到上面四条路径。

 

转载于:https://www.cnblogs.com/darcy-hui/p/10946431.html

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值