软件测试分类详解

一图看清软件测试分类
在这里插入图片描述

一、按测试技术分(是否查看代码)

**1. 黑盒测试**:软件功能是否正常使用【功能的测试】
**2. 白盒测试**:代码逻辑是否正确【结构的测试】
**3. 灰盒测试**:介于两者之间的测试,也称为接口测试

二、被测对象是否运行程序分:

1、动态测试

● 称动态分析,是指需要实际运行被测软件,检查运行结果与预期结果的差异,并分析运行效率和健壮性等性能等来发现软件的缺陷。
● 动态测试实际上也是通常意义上的测试,需要搭建测试环境,制订测试计划,设计测试用例,执行测试用例,编写测试报告等

2、静态测试

● 主要是采用走查、同行评审、会审等方法来查找错误,可以在项目开始之初就可以开始介入。
● 静态测试中的差错和分析功能是其他方法所不能替代的,静态测试能尽早发现文档中的问题,进而找出需求分析、软件设计中存在的问题,避免开发后期发现问题而需要返工,减少开发风险。
● 静态测试还能有效地检查代码的编写质量,为后续的维护打下坚实基础。

三、按测试手段分类

**1. 手工测试**:测试人员手动的对被测对象进行验证
**2. 自动化测试:**自己写测试脚本或通过第三方工具对被测对象进行测试

四、按测试阶段

1. 单元测试

概念:(Unit Testing)是指对软件中的最小可测试单元进行检查和验证。组件测试 也称:单元测试
● 什么是桩模块、驱动模块?
○ 桩模块∶被被测模块调用的模块。
○ 驱动模块∶调用被测模块的模块。
● 单元测试的技术∶黑盒白盒技术,但是白盒居多,黑盒居少,一般先做黑盒再做白盒。
● 单元测试重点∶功能性测试,健壮性(逆向测试∶无效值),性能。
● 单元测试前提条件∶完成编译的测试对象,测试环境,开发工具,测试对象的规范说明书

2. 集成测试

(Integration Testing)又称:组装测试;组件间的接口与交互测试。
● 概念:是在单元测试的基础上,按照设计要求,把单元测试通过的单元组成系统或子系统而进行的有序的测试,目的是检验不同程序单元或部件之间的接口关系是否符合设计的要求,能否正常运行。
● 接口和系统内不同部分的相互作用(交互)。
● 测试条件:是完成集成的被测系统,测试台,有关组件间交互的文档。
● 测试技术:包括白盒技术、黑盒技术,白盒居多,黑盒居少,对比单元测试,白盒下降,一般先做黑盒再做白盒。
● 集成测试测试策略:
○ 自顶向下集成
○ 自底向上集成

3. 系统测试

概念:(System Testing)为了验证和确认系统是否达到设计目标,对集成的硬件和软件系统进行的测试
● 对整个系统能不能满足用户需求的测试,目的检查软件是否满足需求。
● 是在实际环境下,与所在操作系统的其他部分(包括硬件、外设、网络、系统软件和数据库等)组合在一起进行的测试。
○ 系统测试的前期:主要看系统功能是否满足需求,被称为功能测试
○ 系统测试的后期:主要测试系统允许是否满足要求,以及在不同硬件和软件环境中的兼容性
■ 这部分主要有性能测试、兼容性测试、界面测试等。
● 系统测试能够发现哪些缺陷?会遗留哪些缺陷?
○ 发现缺陷∶非功能性缺陷、涉及整个系统的问题。
○ 遗留缺陷∶对用户的需求的错误理解、没有实现或者没有完全实现用户的隐性需求

4. 验收测试

概念:(Acceptance Testing)是软件产品发布之前所进行的软件测试活动。技术测试的最后一个阶段,也称为:交付测试。
目的:是确保软件准备就绪,并且可以让用户将其用于执行软件的既定功能和任务。
一般由用户/客户进行的确认是否可以接受一个系统的验证性测试。验收测试根据用户需求,业务流程进行的正式测试以确保系统符合所有验收的准则。
验收测试 分为:正式测试和非正式测试。
正式测试:是一项管理严格的过程,是系统测试的延续。
验收测试一般由用户派出代表和开发方的测试小组一起进行测试验收,也可能由用户单独验收,总之方式不限,最终的目的还是用户满意并接收。
非正式测:包括Alpha测试、Beta测试
a. Alpha测试:一般是在开发者所提供的场所进行测试,主要对软件最初版本进行测试,一般不对外发布,由开发人员、测试人员或用户共同参与。
b. Beta测试:是对上线之后的软件版本进行测试,完全脱离开发者的环境,完全交给用户测试。

五、按测试包含的内容:

**1. 功能测试**:各个功能模块是否正常
**2. 界面测试**:被测系统界面是否和原型图一致
**3. 安全测试**:对系统进行安全测试(账号多次输入错误,是否允许继续输)
**4. 兼容性测试**:在不同的环境下被测系统是否正常
**5. 易用性测试**:各个功能是否操作方便,是否容易理解、容易上手
**6. 性能测试**:某时间用户数量剧增,软件是否正常【负载测试、压力测试】
**7. 安装测试**

六、其他测试

1、 冒烟测试:

测试整个软件的主体业务功能是否可以正常的运行(在进行正式测试前(开发人员或测试主管)对主要功能核心功能进行的测试)

2、回归测试:

将某个缺陷提交给开发人员后由开发人员进行修复,修复完成后需测试人员再次进行的测试

3、探索性测试:

根据自己的项目经验而进行的随意测试

猜你喜欢

转载自blog.csdn.net/weixin_37600187/article/details/130047631