软件测试 (一) 软件测试方法大汇总

软件测试 (一) 软件测试方法大汇总

软件测试方法种类繁多,记忆起来混乱, 如果把软件测试方法进行分类, 就会清晰很多。 我参考一些书籍和网上的资料, 把常用的软件测试方法列出来, 让大家对软件测试行业有个总体的看法。

从测试设计方法分类


测试名称


测试内容


Black box黑盒测试


把软件系统当作一个“黑箱”,无法了解或使用系统的内部结构及知识。从软件的行为,而不是内部结构出发来设计测试.


White box白盒测试


设计者可以看到软件系统的内部结构,并且使用软件的内部知识来指导测试数据及方法的选择。


Gray box.  灰盒测试


介于黑盒和白盒之间

总结:   实际工作中,对系统的了解越多越好。目前大多数的测试人员都是做黑盒测试,很少有做白盒测试的。 因为白盒测试对软件测试人员的要求非常高,需要有很多编程经验。做.NET程序的白盒测试你要能看得懂.NET代码。做JAVA程序的测试,需要你能看懂 JAVA的代码。 如果你都能看懂了,你还会做测试么

从测试是手动还是自动上分类


测试名称


测试内容


Manual Test 手动测试


测试人员用鼠标去手动测试 (测试GUI)


Automation 自动化测试


用程序测试程序 (测试API)

对于项目来说, 手动测试和自动化测试同等重要,都是保障软件质量的方法。 目前大部分的项目组都是手动测试和自动化测试相结合。因为很多测试无法做成自动化,很多复杂的业务逻辑也很难自动化, 所以自动化测试无法取代手动测试。

对于软件测试人员个人发展来说, 做自动化测试是个挑战,也是测试人员发展的一个方向,  需要测试人员学习大量的开发知识(开发的知识真是学无止境啊)。 从长远角度来看,自动化测试肯定是越来越吃香的。

而手动测试比较适合刚工作不久的人,手动测试最大的缺点就是技术含量低,单调乏味,容易废人。

总的来说,手工测试胜在测试业务逻辑,而自动化测试胜在测试底层架构。

如果被测试的程序可测试性比较好, 很有必要做成自动化测试。 能做自动化的尽量做成自动化, 下面这些情形是可以做自动化的

1.   测试存储过程。  例如用C#去测试存储过程

2.   测试Web servies. 例如: 用SoupUI工具,或者C#,Java 去测试Web servies。

3.   界面和业务逻辑分离的系统,比如,MVC,MVP架构, 或者WPF 程序。 可以用测试脚本去测试这些程序的API。

从测试的目的分类

功能测试

测试的范围从小到大,从内到外, 从程序开发人员(单元测试)到测试人员,到一般用户Alpha/Beta测试


测试名称


测试内容


Unit Test 单元测试


在最低的功能/参数上验证程序的准确性,比如测试一个函数的正确性(开发人员做的)


Functional Test 功能测试


验证模块的功能  (测试人员做的)


Integration Test 集成测试


验证几个互相有依赖关系的模块的功能 (测试人员做的)


Scenario Test  场景测试


验证几个模块是否能完成一个用户场景 (测试人员做的)


System Test  系统测试


对于整个系统功能的测试 (测试人员做的)


Alpha 测试


软件测试人员在真实用户环境中对软件进行全面的测试 (测试人员做的)


Beta 测试


真实的用户在真实的用户环境中进行的测试, 也叫公测   (最终用户做的)

非功能测试

一个软件除了基本功能之外,还有很多功能之外的特性,这些叫“Quality of Service requirement”服务质量需求。没有软件的功能,这些特性都无从表现出来,因此,我们要在软件开发的适当阶段-基本功能完成后做这些测试。


测试名称


测试内容


Stress test 压力测试


验证软件在超过负载设计的情况下仍能返回正确的结果,没有崩溃


Load test 负载测试


测试软件在负载情况下能否正常工作


Performance test性能测试


测试软件的效能,是否提供满意的服务质量


Accessibility test


软件辅助功能测试-测试软件是否向残疾用户提供足够的辅助功能


Localization/Globalization


本地化/全球化测试


Compatibility Test


兼容性测试


Configuration Test


配置测试-测试软件在各种配置下能否正常工作


Usability Test


可用性测试 –测试软件是否好用


Security Test


软件安全性测试

性能测试

性能测试要求测试人员熟练性能测试工具,比如QTP, LoadRunner, Jmeter。  Visual Studio也提供了很多性能测试的工具. 要求测试人员对低层协议非常理解和编写脚本

性能测试非常有技术含量, 很有发展前途, 是软件测试人员的一个职业发展方向。

安全性测试

安全性测试的内容很广, 非常有难度啊。 我只接触过XSS(跨站脚本攻击)和SQL注入攻击。

安全性测试非常有技术含量, 我认为也是软件测试人员的一个职业发展方向

按测试的时机和作用分类

在开发软件的过程中,不少测试起着“烽火台”的作用,它们告诉我们软件开发的流程是否畅通。


测试名称


测试内容


Smoke Test


“冒烟”–如果测试不通过,则不能进行下一步工作


Build Verification Test(BVT)


验证构建是否通过基本测试。


Acceptance Test


验收测试,为了全面考核某功能/特性而做的测试

BVT测试是一种Smoke Test, 指Build生成好之后,自动运行的自动化测试脚本来检查这个Build的基本功能。 如果BVT测试失败了,需要开发人员马上修改,重新生成Build

按测试测策略分类。


测试名称


测试内容


Regression Test 回归测试


对一个新的版本,重新运行以往的测试用例,看看新版本和已知的版本相比是否有退化 (regression)


Ad hoc Test 探索性测试


随机进行的,探索性的测试。


Sanity Test


粗略的测试, 只需要执行部分的测试用例

Regression Test 回归测试:  

对软件测试人员来说就是重复测试,所以回归测试最好是自动化的, 否则测试人员就要一遍又一遍地重复测试, 

1. 开发人员做些小改动,就需要测试人员做回归测试。确保现有的功能没有被破坏

2. Bug Fix 也需要回归测试,确保新的代码修复了Fix, 也确保现有的功能没有被破坏

3. 项目后期,需要做一个完整回归测试, 确保所有的功能都是好的

Ad hoc Test 探索性测试:

平常我最喜欢做随机测试了, 抛开test case.  自己按照自己的思路,随便点点。 如果测试GUI,Ad hoc能发现大量的bug.

时间: 2024-10-10 20:03:02

软件测试 (一) 软件测试方法大汇总的相关文章

软件测试 (一) 软件测试方法大汇总(转)

软件测试方法种类繁多,记忆起来混乱, 如果把软件测试方法进行分类, 就会清晰很多. 我参考一些书籍和网上的资料, 把常用的软件测试方法列出来, 让大家对软件测试行业有个总体的看法. 从测试设计方法分类 测试名称 测试内容 Black box黑盒测试 把软件系统当作一个"黑箱",无法了解或使用系统的内部结构及知识.从软件的行为,而不是内部结构出发来设计测试. White box白盒测试 设计者可以看到软件系统的内部结构,并且使用软件的内部知识来指导测试数据及方法的选择. Gray box

软件测试方法汇总

软件测试方法种类繁多,记忆起来混乱, 如果把软件测试方法进行分类, 就会清晰很多. 我参考一些书籍和网上的资料, 把常用的软件测试方法列出来, 让大家对软件测试行业有个总体的看法. 从测试设计方法分类 测试名称 测试内容 Black box黑盒测试 把软件系统当作一个"黑箱",无法了解或使用系统的内部结构及知识.从软件的行为,而不是内部结构出发来设计测试. White box白盒测试 设计者可以看到软件系统的内部结构,并且使用软件的内部知识来指导测试数据及方法的选择. Gray box

C语言面试题大汇总

C语言面试题大汇总 1.局部变量能否和全局变量重名? 答:能,局部会屏蔽全局.要用全局变量,需要使用"::" ;局部变量可以与全局变量同名,在函数内引用这个变量时,会用到同名的局部变量,而不会用到全局变量.对于有些编译器而言,在同一个函数内可以定义多个同名的局部变量,比如在两个循环体内都定义一个同名的局部变量,而那个局部变量的作用域就在那个循环体内. 2.如何引用一个已经定义过的全局变量? 答: extern 可以用引用头文件的方式,也可以用extern关键字,如果用引用头文件方式来引

【转载】如何对软件测试方法分类

软件测试方法种类繁多,记忆起来混乱,如果把软件测试方法进行分类,就会清晰很多.我参考一些书籍和网上的资料,把常用的软件测试方法列出来,让大家对软件测试行业有个总体的看法. 一.从测试设计方法分类 测试名称 测试内容 Black   box黑盒测试 把软件系统当作一个“黑箱”,无法了解或使用系统的内部结构及知识.从软件的行为,而不是内部结构出发来设计测试. White   box白盒测试 设计者可以看到软件系统的内部结构,并且使用软件的内部知识来指导测试数据及方法的选择. Gray box  灰盒

【转载】虫师『性能测试』文章大汇总

虫师『性能测试』文章大汇总 为了方便阅读,我重新整理本文,将包含本博客所有与性能测试有关的内容. ------------------------------------------- 近两年市面上的性能测试书籍很多了,但大部分书都在讲loadrunner的操作技巧项目与项目实践.我不认为有什么问题,因为loadrunner性能测试工具已经占据很大市场.loadrunner是非常的强大,但我们在做性能测试时,往往都以“loadrunner的模式”在思考如何进行性能测试.loadrunner只是一

软件测试方法

1软件测试基础 信息技术的飞速发展,使软件产品应用到社会的各个领域,软件产品的质量自然成为人们共同关注的焦点.不论软件的生产者还是软件的使用者,均生存在竞争的环境中,软件开发商为了占有市场,必须把产品质量作为企业的重要目标之一,以免在激烈的竞争中被淘汰出局.用户为了保证自己业务的顺利完成,当然希看选用优质的软件.质量不佳的软件产品不仅会使开发商的维护难度和用户的使用本钱大幅增加,还可能产生其他的责任风险,造成公司信誉下降,继而冲击股票市场.在一些关键应用 (如民航订票系统.银行结算系统.证券交易

软件测试-5 软件测试总结

一.概述 软件测试的开始与软件开发生命周期的开始是同时的,即软件测试伴随着整个软件开发生命周期.在软件开发的生命周期中,我们可能用到各种软件测试的方法,而且现在软件测试的工具和方法非常多,现在回想起来可能已经十分混乱,所以我希望能从新整理一遍软件测试的方法: 二.软件测试方法 2.1 黑盒/白盒 刚学软件测试就学的是这个,把软件测试分为两类: 测试名称 描述 黑盒测试 Black Box 把软件看做一个黑盒,不清楚里面的结构,从功能上做测试 白盒测试 white Box 已知软件内部的结构,根据

java面试大汇总

java面试笔试题大汇总     第一,谈谈final, finally, finalize的区别. 最常被问到. 第二,Anonymous Inner Class (匿名内部类) 是否可以extends(继承)其它类,是否可以implements(实现)interface(接口)? 第三,Static Nested Class 和 Inner Class的不同,说得越多越好(面试题有的很笼统). 第四,&和&&的区别. 这个问得很少. 第五,HashMap和Hashtable的区

浅谈软件测试方法

      软件测试已然成为生产高质量软件必不可少的一个工程实践活动,其中软件测试方法更是种类繁多,对于初学者而言,记忆起来比较困难.因而我通过课上听讲及查阅资料加以简单地整理总结,方便大家有个整体的了解. 从测试设计方法分类 测试名称                                 测试内容 Black Box Testing黑盒测试 黑盒测试也称功能测试,它是通过测试来检测每个功能是否都能正常使用.在测试中,把程序看作一个不能打开的黑盒子,在完全不考虑程序内部结构和内部特性的