文档介绍:测试用例
版权所有:华深慧正陈绍英
联系凡是:******@.
性能测试、压力测试、负载测试、强度测试、稳定性测试、健壮性测试、功能测试、系
统测试、集成测试、接口测试⋯⋯,这么些眼花缭乱的测试类型名称,估计很少有有人能准
确的区分和说出定义来,对应的测试用例如何编写和执行,就更不容易进行了。
如果问测试工程师测试用例如何编写,就好象是问程序员如何编写代码一样,每个人都
会给出不同的方法,但是实用的测试用例却象优秀的程序一样困难。
本章针对上面的问题,主要讲解在企业实际工作中,如何有效划分测试种类和编写对应
的测试用例,使测试工作更加合理、高效率的运行。
本章主要以测试用例的编写和管理为核心,讲述下面内容:
用例的分类
用例程度的把握
用例的执行
用例的评审
用例的升级、管理、维护
... ...
事实上,完全可以把测试用例看成是测试工程师编写的程序:这个“程序”是为了辅助
测试工作的进行而进行,目的是为了发现软件问题,同时“顺便”证明软件功能是否符合要
求。
测试种类和阶段
测试种类
对于测试种类的说法多种多样,最多的能有 30 多种测试类型。而实际工作中很多测试是互
相包含的。按照企业中实际工作需要,测试主要包含下面的类型:
功能测试:功能测试主要针对产品需求说明书的测试,主要是验证功能是否否合需求,包括
原定功能的检验、是否有冗余功能、遗漏功能。这类测试应由测试员做,这并不意味着程序
员在发布前不必检查他们的代码能否工作(自然他能用于测试的各个阶段)。
健壮性测试(容错能力/恢复能力测试):侧重于程序容错能力的测试。本测试在单元测试阶
段和系统测试阶段都要进行。如数据边界测试、非法数据测试、异常中断测试等等,主要是
验证程序对各种异常情况是否进行正确处理。为了执行方便,建议健壮性的大部分测试用例
尽量编写在功能测试用例中。
接口测试:程序员对各个模块进行系统联调的测试,包含程序内接口和程序外接口测试。这
个测试,在单元测试阶段进行了一部分工作,而大部分都是在集成测试阶段完成的。由开发
人员进行。
强度测试强度测试检查程序对异常情况的抵抗能力。强度测试总是迫使系统在异常的资源
配置下运行。例如,①当中断的正常频率为每秒一至两个时,运行每秒产生十个中断的测试
用例;②定量地增长数据输入率,检查输入子功能的反映能力;③运行需要最大存储空间(或
其他资源)的测试用例;④运行可能导致虚存操作系统崩溃或磁盘数据剧烈抖动的测试用例,
等等。
压力测试:对系统不断施加压力的测试,是通过确定一个系统的瓶颈或者不能接收的性能点,
来获得系统能提供的最大服务级别的测试。例如测试一个 Web 站点在大量的负荷下,何时
系统的响应会退化或失败。
性能测试:在交替进行负荷和强迫测试时常用的术语。性能测试关注的是系统的整体。它和
通常所说的强度、压力/负载测试测试有密切关系。所以压力和强度测试应该于性能测试一
同进行。
举例说明:针对一个网站进行测试,模拟 10 到 50 个用户就是在进行常规性能测试,用
户增加到 1000 乃至上万就变成了压力/负载测试。如果同时对系统进行大量的数据查询操作,
就包含了强度测试。
压力测试注重的是外界不断施压,强度测试注重的是极限或者异常情况下系统的测试。
用户界面测试:对系统的界面进行测试,测试用户界面是否友好、是否方便易用、设计是否
合理、位置是否正确等一系列界面问题
安全测试:主要是测试系统在没有授权的内部或者外部用户对系统进行攻击或者恶意破坏时
如何进行处理,是否仍能保证数据的安全。测试人员可以学习一些黑客技术,来对系统进行
攻击。
可靠性测试:这里是比较狭义的可靠性测试,它主要是对系统能否稳定运行进行一个统计,
在实际工作中如果没有条件可以不必特意去做。重点做好与之紧密相关的功能测试、健壮性
测试就可以了。
安装/反安装测试:安装测试主要检验软件是否可以正确安装,安装文件的各项设置是否有
效,安装后能否影响原系统;反安装是逆过程,测试是否删除干净,是否给影响原系统等。
文档测试:主要测试开发过程中针对用户的文档,以需求、用户手册、安装手册等为主,检
验文档是否和实际应用存在差别。文档测试不需要编写测试用例。
测试阶段
和开发过程相对应,测试主要按照时间顺序经历单元测试、集成测试、系统测试、验收测试
四个阶段。对应关系如图 4-1 所示,
图 4-1 开发与测试的“V”型关系
单元测试:单元