软件测试按照测试方法分类【摘抄】

1、静态和动态测试

静态测试是不运行被测程序本身而寻找程序中可能存在的错误或评估程序代码的过程。通过分析或者检查源程序的语法、结构、过程、借口等来检查程序的正确性,找出问题。这些问题包括:参数不匹配、不适当的分支嵌套和循环嵌套、未使用过的变量、空指针的引用等。

文档的测试一般也是用静态测试。

静态测试可以用手工,也可以用工具实现。静态测试工具一般是对代码进行语法检查,找出不符合编码规范的地方,根据某种模型评价代码的质量,生成系统的调用关系图等,常见的工具有Telelogic公司的Logiscope、PR公司的PRQA等。

动态测试是运行被测试程序,输入相应的测试数据,检查运行结果与预期结果的差异,判定执行结果是否符合要求,从而检验程序的正确性、可靠性和有效性,并分析系统运行效率和健壮性等性能。

2、黑盒测试、灰盒测试和白盒测试

黑盒测试又称为功能测试、数据驱动测试或者基于规格说明书的测试,注重测试软件的功能需求。测试人员不关心程序具体如何实现,根据软件的规格对软件进行各种输入,观察软件的各种输出结果,发现软件的缺陷。因为这类测试不考虑软件的内部运作原理,因此软件对用户来说就像一个黑盒子。

灰盒测试是介于黑盒测试与白盒测试之间的测试方法,在执行白盒测试的时候考虑使用黑盒测试的方法。

白盒测试又称结构测试、逻辑驱动测试或基于程序代码的测试。根据软件内部的工作原理分析来进行测试,测试人员通过阅读程序代码或者通过使用开发工具中的单步调试来判断软件的质量。

3、冒烟测试

冒烟测试的对象是每一个新编译的需要正式测试的软件版本,目的是确认软件的基本功能正常,可以进行后续的正式测试工作。简单的说,冒烟测试就是用较少的人,在较短的时间内,测试程序的主要功能,如果通过再进行正式的测试。

4、回归测试(Regression testing)

在发生修改之后重新测试先前的测试以保证修改的正确性,以及修改后没有引发新的错误。

5、功能测试和性能测试

功能测试(Functional testing):根据产品特征、操作描述和用户方案,测试一个产品的特性和可操作行为以确定它们满足设计需求。

性能测试(Performance testing):评价一个产品或组建与性能需求是否符合的测试。包括负载测试、强度测试、数据库容量测试、基准测试等类型。

6、压力测试和负载测试

压力测试:获取系统正确运行的极限,检查系统在瞬间峰值负荷下正确运行的能力,例如:对服务器做压力侧室时增加并发操作的用户数量,或者不停向服务器发送请求,或者一次性向服务器发送特别大的数据等。看服务器保持正常运行所能达到的最大状态。

负载测试:用于检查系统在使用大量数据的时候正确工作的能力,即检验系统的能力最高能达到什么程度,例如:对信息检索系统,让他的使用频率达到最大,或者对多个终端的分时系统,让所有的终端都开动,在使整个系统的全部资源达到“满负荷”的情况下,测试系统的承受能力。区别于压力测试的是,负载测试一般模仿用户真实环境,大量数据也不会取到实际不可能达到的数值。

7、易用性测试:从客户角度出发,从使用软件的合理性和方便性等角度对软件系统进行检查,发现人为因素或使用上的问题。

8、安装测试:确保软件在正常情况和异常情况的不同条件下,如首次安装、升级、完整或自定义安装等都能进行安装。异常情况包括磁盘空间不足、缺少目录创建权限等。核实软件在安装后可正常运行。安装测试还包括卸载测试。

9、界面测试:用户界面风格是否满足用户要求,文字是否正确,版面是否美观等。包括窗口测试,菜单和鼠标操作,数据项测试。

10、配置测试:主要检查计算机系统内各个设备或各种资源之间的相互连接和功能分配中的错误,包括验证全部配置命令的可操作性,软件配置,硬件配置,利用手动方式进行配置状态间的转换。

11、文档测试:检查文档的正确性、完备性和可理解性。

12、兼容性测试(企业内常称为“共存性”):测试软件是否和系统的其它与之交互的元素之间兼容,如浏览器、操作系统、硬件等。

13、安全性测试(尤其B/S系统要求比较高):检查系统对非法入侵的防范能力,检查系统中已存在的系统安全性、保密性措施是否发挥作用,有无漏洞。系统安全设计的准则是,使非法侵入的代价超过被保护信息的价值。

14、恢复测试(Recovery testing):主要检查系统的容错能力。当系统出错时,能否在规定时间内修正错误并恢复正常。例如SQL的回滚机制。

 

15、可移植性测试:测试软件是否可以被成功移植到指定的硬件或软件平台上。

16、引导测试:软件开发中,验证系统在真实硬件和客户基础上处理典型操作的能力。在软件外包测试中,引导测试通常是客户检查软件测试公司测试能力的一种形式,只有通过了客户特定的引导测试,软件测试公司才能接受客户真实软件项目的软件测试。

17、随机测试:没有书面测试用例、记录期望结果、检查列表、脚本或指令的测试,主要是根据测试者的经验对软件进行功能和性能抽查。随机测试是根据测试说明书执行测试用例的重要补充手段,是保证测试覆盖完整性的有效方式和过程。

18、健全测试:软件主要功能成分的简单测试以保证它是否能进行基本的测试。

19、手工和自动化测试

自动化测试:使用自动化测试工具进行测试,一般不需要人工过多干预,在GUI、性能测试中用得较多。

20、国际化测试、本地化能力测试、本地化测试

国际化测试:目的是测试软件的国际化支持能力,发现软件的国际化的潜在问题,保证软件在世界不同区域中都能正常运行。国际化测试使用每种可能的国际输入类型,针对任何区域性或区域设置检查产品的功能是否正常,软件国际化测试的重点在于执行国际字符串的输入/输出功能。

本地化能力测试:本地化能力是指不需要重新设计或修改代码,将程序的用户界面翻译成任何目标语言的能力。常在软件的伪本地化版本上进行。

本地化测试:对象是软件的本地化版本。本地化测试的目的是测试特定目标区域设置的软件本地化质量。本地化测试的环境是在本地化的操作系统上安装本地化的软件。

21、通过测试:即正面测试,使用满足需求的数据测试系统的过程。

22、失败测试:负面测试,使用不满足需求的数据测试系统。

23、错误猜测:是通过直觉发现程序中的错误和缺陷的能力。

posted @ 2009-08-10 11:00  suzihuy  阅读(671)  评论(0编辑  收藏  举报