小编提示:本文含静态测试主要检查点,纯干货,看官们可先收藏后阅读。
从是否执行被测试软件来进行分类,测试可以分为静态测试和动态测试。软件本身包含了各种代码,如果只是检查代码和文档,而不执行被测试的软件,此时所进行的就是静态测试。反之,如果在测试过程中执行被测试的软件,则所进行的就是动态测试。本文从什么事静态测试、为什么进行静态测试以及如何进行静态测试三个方面进行讲解,和大家分享下个人对于静态测试的一些经验总结。
01/什么是静态测试?
静态测试是指无须执行被测代码,而是借助专用的软件测试工具评审软件文档或程序,度量
程序静态复杂度,检查软件是否符合编程标准,借以发现编写的程序的不足之处,减少错误出现的概率。
02/为什么要进行静态测试?
静态分析潜在收益是很高的: 在软件开发生命周期中,越是后来发现的缺陷,其去除成本呈指数上涨,所以缺陷越早发现越好。静态分析是所有测试中可以最先发现缺陷的方法,极大的降低了软件的修复成本。
对软件经理,静态分析有助于:
1) 减少部署后存在错误的风险,去除此时发现的错误是非常昂贵的;
2) 缩短产品上市时间;
3) 减少代码审查和测试的成本和时间;
4) 自动化(部分)审查,没有或多个有限的人工检查;
5) 消除明显的错误以便改善测试的速度和重点;
6) 提高代码质量(坚持编码标准);
7) 实现更高的覆盖率(更多的代码检查):与测试覆盖率相关但并不完全一样,因为重点不同。
对软件开发人员,静态分析有助于:
1) 提早找到/阻止错误(在错误变得很难处理之前):工具可用作开发周期的一部分,像编译器;更直接,明显的反馈。
2) 发现/阻止“难以测试”的错误:例如,静态分析善于检测潜在的内存泄露和缓冲区溢出,从而使开发人员更高效,花费更少的时间调试。
03/如何进行静态测试?
从概念中我们可以知道,静态测试包括对代码测试、界面测试和文档测试三个方面:
展开全文
1) 对于代码测试,主要测试代码是否符合相应的标准和规范。
2) 对于界面测试,主要测试软件的实际界面与需求中的说明是否相符。
3) 对于文档测试,主要测试用户手册和需求说明是否符合用户的实际需求。
静态测试主要检查点:见表1
下面分别从代码、界面、文档三个方面进行详细说明每一部分应该如何进行测试。
1) 界面测试:见表2
主要从联机功能、接口测试、报表测试和批量测试几个方面进行阐述。
1) 文档测试
主要是需求文档与实际设计和实现是否相符,可以根据界面测试中的点进行测试。
2) 代码测试
程序代码的静态测试要复杂得多,需要我们按照相应的代码规范模板来逐行检查程序代码。
对代码的检查我们推荐使用现有的工具进行。那么我们从哪里获得这个规范模板呢?其实没有一个统一的标准,每个公司内部一般都有自己的编码规范,比如《c/c++编码规范》,你只需要按照上面的条目逐条测试就可以了。
这段C语言编写的小程序,比较简单,实现的功能为:在主函数里输入两个单精度的数a和b,
然后调用max子函数来求a和b中的大数,最后将大数输出。我们现在就对代码进行静态分析,主要根据一些C语言的基础知识来检查。
我们把问题分为两种,一种必须修改的,另一种建议修改的。
必须修改的问题有三个:
1)程序没有注释。
注释是程序中非常重要的组成部分,一般占到总行数的1/4左右。程序开发出来不仅是给程序员看,其他程序员和测试人员也要看。有了注释,别人就能很快地了解程序实
现的功能。注释应该包含作者,版本号、创建日期等,以及主要功能模块的含义。
2)子函数max没有返回值的类型。
由于类型为单精度,我们可以在max()前面加一个float类型声明。
3)精度丢失问题。
大家注意“c=max(a,b)”语句,我们知道c的类型为整型int ,而max(a,b)的返回值z为单精度float, 将单精度的数赋值给一个整型的数,c语言的编译器会自动地进行类型转换,将小数部分去掉,比如z=2.5,赋给c则为2,最后输出的结果就不是a和b 中的大
数,而是大数的整数部分。
建议修改的问题也有三个;
1)Main函数没有返回值类型和参数列表。
虽然main函数没有返回值和参数,但是我们将其改为void main(void),来表明main函数的返回值和参数都为空,因为在有的白盒测试工具的编码规范中,如果不写void会认为是个错误。
2)一行代码只定义一个变量。
3) 程序适当加些空行。空行不占内存,会使程序看起来更清晰。
04/总结
软件测试技术是一门很深的学问,需要测试人员不断去摸索总结,本文只是我对于静态测试的一些看法与总结,希望能够给大家带来帮助。(文/毕东格)
恒生开发者社区(bbs.hscloud.cn)- 恒生电子面向所有开发者提供服务分享、技术交流和互联共通等一站式服务平台。
恒生开发者社区(bbs.hscloud.cn)- 恒生电子面向所有开发者提供服务分享、技术交流和互联共通等一站式服务平台。
来源:恒生开发者社区恒生技术专栏