博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
《微软的软件测试之道》读书笔记 之 结构测试技术
阅读量:6682 次
发布时间:2019-06-25

本文共 877 字,大约阅读时间需要 2 分钟。

《微软的软件测试之道》读书笔记 之 结构测试技术

2014-07-18

我们需要结构测试吗?

微软的一项试验说明了结构测试的在代码覆盖中起到的效果:

超过3000名测试员参与了这项实验,每25人一组,实验结果在所有组中都是一致的。在这项研究中,

  • 脚本化测试:根据样式书设计的脚本化测试在被测程序上达到了标称83%的代码覆盖率。
  • 探索性测试:然后,实验参与者允许进行每人15分钟,累计5小时的探索性测试。令人惊讶的是,代码覆盖率平均只增加了3个百分点。
  • 结构测试:但是,当实验参与者能够分析探测过的(Instrumented)代码的运行结果并使用白盒技术设计测试以后,不到20分钟的时间代码覆盖率就提高到了 91%(这是不使用代码突变或故障注入所能达到的最大实际代码覆盖率)。同时,测试员们也能够更好的从代价和收益的角度解释为什么剩下的9%未覆盖代码是不可测试的。

下图显示了不同测试技术的代码覆盖效果。

图1 不同测试技术的代码覆盖效果

 

块测试


 

此书把块测试、决策测试、条件测试、基础路径测试都归入结构测试技术。这里主要讲一下块测试。

块覆盖和语句覆盖

  • 语句覆盖测量一个程序在测试过程中被执行过的语句的数量。
  • 块覆盖测量无分支的连续语句组的数量。导致控制流程转向分支的条件语句可以包含若干块。

这个看起来似乎只是一个极小的区别,然而,语句测试和块测试的区分是相当重要的。因为相较于语句测试,块测试对控制流程提供了更好的敏感度。

?代码块的计算 

 

块测试小结

块测试是用于单元测试的一种普遍方法:

优势:它非常适合于迅速地评估某函数的基本功能。对于设计用于执行switch/case语句和异常处理程序控制流程的测试来说,它也是一个很有价值的技术。

劣势:然而,块测试是健壮的结构测试中相对较弱的标准,它还可能漏掉控制流程的一些重要的分支。此外,块测试还容易忽略一些潜在的问题,特别是在我们测试的目的只是要提高代码覆盖率而不是要仔细分析被测试代码的情况下。

转载于:https://www.cnblogs.com/Ming8006/p/3853904.html

你可能感兴趣的文章
精通MVC3摘译(9)-过滤器
查看>>
补基础:自学:计算机科学导论 第三章 数据存储 续
查看>>
JFreeChart使用及乱码解决及整合struts2
查看>>
小学生缺乏学习动力的三大原因?
查看>>
我的友情链接
查看>>
我国需要的项目管理
查看>>
Use SourcceInsight on openSUSE
查看>>
OAUTH协议简介
查看>>
Ext.Loader 详解--中文
查看>>
sql server学习小结
查看>>
connectify建立的无线 手机搜索不到信号解决办法!
查看>>
管理域计算机
查看>>
OpenLDAP学习笔记(基于OpenLDAP-2.4.x)
查看>>
android添加KeyMob广告管理库中文教程
查看>>
Linux三剑客老三grep总结
查看>>
nginx http 访问控制相关配置
查看>>
Exchange Server 2010高可用设计
查看>>
我的友情链接
查看>>
bash 学习一 变量、参数、判断与循环
查看>>
第一个tensorflow程序
查看>>