单元测试与单元测试的基本方法 软件测试
一、什么是单元测试
测试是软件开发的重要环节之一。按照软件开发的过程测试可分为:单元测试、集成测试、系统测试等。在本文中,我们主要讨论面向程序员的单元测试。
什么是单元测试?单元测试就是开发者编写的一小段代码,用于检验被测代码的一个很小的、很明确的功能是否正确。举个例子,工厂在组装一台电视机之前,会对每个元件都进行测试,这就是单元测试。一般而言,软件开发中的单元测试是指对方法的测试。
单元测试是软件开发过程中重要的质量保证活动,单元测试的质量将很大程度上影响软件产品的最终质量。单元测试是对软件基本组成单元进行的测试,是属于白盒测试的范畴,它主要通过对代码的逻辑结构进行分析来设计测试用例。
一个完整的单元测试说明应该包含正面测试(Positive Testing)和负面的测试(Negative Testing)。正面测试验证程序应该执行的工作,负面测试验证程序不应该执行的工作。
什么是测试用例?测试用例(Test Case)是为某个特殊目标而编制的一组测试输入、执行条件以及预期结果,以便测试某个程序路径或核实是否满足某个特定需求。
二、单元测试的基本方法
单元测试的对象是软件设计的最小单位――模块。单元测试的依据是详细设描述,单元测试应对模块内所有重要的控制路径设计测试用例,以便发现模块内部的错误。单元测试多采用白盒测试技术,系统内多个模块可以并行地进行测试。 单元测试任务单元测试任务包括:1 模块接口测试;2 模块局部数据结构测试;3 模块边界条件测试;4 模块中所有独立执行通路测试;5 模块的各条错误处理通路测试。
模块接口测试是单元测试的基础。只有在数据能正确流入、流出模块的前提下,其他测试才有意义。测试接口正确与否应该考虑下列因素:1 输入的实际参数与形式参数的个数是否相同;2 输入的实际参数与形式参数的属性是否匹配;3 输入的实际参数与形式参数的量纲是否一致;4 调用其他模块时所给实际参数的个数是否与被调模块的形参个数相同;5 调用其他模块时所给实际参数的属性是否与被调模块的形参属性匹配;6调用其他模块时所给实际参数的量纲是否与被调模块的形参量纲一致;7 调用预定义函数时所用参数的个数、属性和次序是否正确;8 是否存在与当前入口点无关的参数引用;9 是否修改了只读型参数;10 对全程变量的定义各模块是否一致;11是否把某些约束作为参数传递。
如果模块内包括外部输入输出,还应该考虑下列因素:1 文件属性是否正确;2 OPEN/CLOSE语句是否正确;3 格式说明与输入输出语句是否匹配;4缓冲区大小与记录长度是否匹配;5文件使用前是否已经打开;6是否处理了文件尾;7是否处理了输入/输出错误;8输出信息中是否有文字性错误;检查局部数据结构是为了保证临时存储在模块内的数据在程序执行过程中完整、正确。局部数据结构往往是错误的根源,应仔细设计测试用例,力求发现下面几类错误:1 不合适或不相容的类型说明;2变量无初值;3变量初始化或省缺值有错;4不正确的变量名(拼错或不正确地截断);5出现上溢、下溢和地址异常。
除了局部数据结构外,如果可能,单元测试时还应该查清全局数据(例如FORTRAN的公用区)对模块的影响。
在模块中应对每一条独立执行路径进行测试,单元测试的基本任务是保证模块中每条语句至少执行一次。此时设计测试用例是为了发现因错误计算、不正确的比较和不适当的控制流造成的错误。此时基本路径测试和循环测试是最常用且最有效的测试技术。计算中常见的错误包括:1 误解或用错了算符优先级;2混合类型运算;3变量初值错;4精度不够;5表达式符号错。
比较判断与控制流常常紧密相关,测试用例还应致力于发现下列错误:1不同数据类型的对象之间进行比较;2错误地使用逻辑运算符或优先级;3因计算机表示的局限性,期望理论上相等而实际上不相等的两个量相等;4比较运算或变量出错;5循环终止条件或不可能出现;6迭代发散时不能退出;7错误地修改了循环变量。
一个好的设计应能预见各种出错条件,并预设各种出错处理通路,出错处理通路同样需要认真测试,测试应着重检查下列问题:1输出的出错信息难以理解;2记录的错误与实际遇到的错误不相符;3在程序自定义的出错处理段运行之前,系统已介入;4异常处理不当;5错误陈述中未能提供足够的定位出错信息。
边界条件测试是单元测试中最后,也是最重要的一项任务。众的周知,软件经常在边界上失效,采用边界值分析技术,针对边界值及其左、右设计测试用例,很有可能发现新的错误。
文章来源于领测软件测试网 https://www.ltesting.net/