
功能测试 —测试人员用鼠标去手动测试 (测试GUI),点点点测试
自动化测试 —用程序测试程序 (测试API),解放双手
性能测试 —定位系统瓶颈,保证系统良好性能与稳定性
黑盒测试 —测试应用程序的功能,验证结果是否正确
白盒测试 —测试程序内部结构,以编程语言角度设计测试案例
按测试阶段划分:
单元测试是针对基本单元(软件设计最小单位)进行正确性检测工作。
单元测试目的是检测软件模块是否完成了需求设计书中的要求。
将内存条放进插槽,检查规格是否符合,放入内存是否机器可以工作,此称为集成测试。
集成测试是基于单元测试的基础,将所有模块按照设计组装为一个子系统验证。
结合测试工作人员安排,测试环境配置,计算机硬件环境配置,整合在一起,进行测试工作。
单元、集成、系统测试的区别:
测试方法不同
测试范围不同
测试过程信息流
软件环境配置:需求文档,需求设计书,测试代码等
测试环境配置:测试需求说明书,测试计划书,测试用例等

回归测试定义
软件在测试或者其他活动中发现了缺陷且经过修复之后,应该进行回归测试活动。
目的在于验证缺陷是否正确的被修复,并且是否影响到其他的功能。
回归测试流程
回归测试策略设计
完全重复测试
重新执行所有先前定义的测试用例,来确认问题修改的正确性,以及软件修改后可能造成的影响扩散。
选择性重复测试
有选择性的重新执行部分测试用例。
回归自动化测试
由于回归测试的特性,是重新执行以前的成果,且无法预知需要回归几次后才能够通过测试标准,因此回归测试可能由于枯燥乏味造成测试人员积极性低下,测试质量下降。
因此我们得用机器人或是计算机程序解决此重复且乏味的测试活动,自动化回归测试应运而生。
良好的回归自动化测试活动包括如下:
对于特定系统或者复杂测试环境下,商业测试工具难以解决问题,自主研发自动化测试工具是灵活的方法。
验收测试
在软件生命周期流程上来看,软件研发阶段,测试活动包括单元测试、集成测试,系统测试等企业内部进行的测试活动。
在软件发布之前还有一个测试活动有真实用户介入,称为验收测试。
软件项目开发分为两种形式:
企业自研产品,如今日头条,王者荣耀,抖音
公司承接业务开发,客户要什么就开发什么
产品研发好后,由客户方验收,检验产品需求正确性
验收测试概要
如何确定验收测试的执行时间、执行人员、执行环境
内部系统测试活动以及软件配置审查之后,开始执行验收测试验收测试计划书或软件需求规格书进行标准化测试α、β测试
α测试活动好比游戏的删档内测
尤其注重产品的界面和特色,β测试好比游戏的不删档公测
测试过程分为四大阶段:
测试计划->测试方案->测试用例->测试报告
测试分类
| ~ | 单元测试 | 冒烟测试 | 集成测试 | 系统测试 | 验收测试 |
|---|---|---|---|---|---|
| 测试阶段 | 编码后 | 提测后 | 单元测试后 | 冒烟测试通过后 | 软件发布前 |
| 测试对象 | 最小模块覆盖 | 整个系统 | 模块间联调 | 整个系统 | 整个系统 |
| 测试人员 | 白盒测试或开发 | 黑盒测试 | 白盒测试或开发 | 黑盒测试 | 用户或需求方 |
| 测试依据 | 代码、注释、详细设计文档 | 冒烟测试用例 | 单元测试模块、概要设计文档 | 需求说明文档、测试用例 | 用户需求、验收标准文档 |
| 测试方法 | 白盒测试 | 黑盒测试,自动化测试 | 黑盒与白盒结合 | 黑盒测试 | 黑盒测试 |
软件测试分类说明
| 名称 | 说明 |
|---|---|
| 性能测试 | 性能测试是为验证系统性能指标进行测试。 |
| 负载测试 | 负载测试是通过改变系统负载方式来发现系统中所存在的性能问题,如内存泄露,性能瓶颈。 |
| 压力测试 | 在高负荷且长时间的稳定性压力测试和极限负荷情况下进行测试。验证系统稳定性。 |
| 恢复测试 | 检查系统的容错能力。强制性迫使系统失败,然后验证系统恢复能力重启系统。 |
| 易用性测试 | 测试软件是否易用性,一般根据用户反馈信息验证。 |
| 回归测试 | 指错误被修正后,软件功能发生变化后重新测试,确认不会影响其他功能。 |
| Alpha测试 | 模拟实际操作环境下验收测试,如删档内侧 |
| Beta测试 | 系统已经通过内部测试,大部分错误已经修复,即将正式发布,在多个真实环境下发布,如不删档公测。 |
测试计划->测试设计->测试构建->测试执行->测试结果分析->测试评估和报告
黑盒测试类型
白盒测试就打开了盒子,可以看到软件的内部代码
对比黑盒测试,白盒测试更严谨,对软件的源码和架构进行测试。
需要软件源代码,流程图等设计文档。
依据被测软件分析程序内部构造,并且根据内部结构设计测试用例,针对内部控制流程进行测试。
白盒测试是基于程序结构的逻辑驱动测试。
黑盒,白盒测试,相辅相成,白盒测试通过了,还得运行软件,查看软件的性能好坏,界面美丑,是否易用等等方面。
软件测试方法选择:
已知产品需求规格,但不知道其系统内部实现,进行黑盒测试证明需求是否实现。
已知产品内部实现,通过测试每种内部操作是否符合需求,属于白盒测试。
为什么要白盒测试
只验证产品基本需求得到实现,为什么要费力去测试产品内部实现呢?所谓知其然不知其所以然,仅黑盒测试,只能够满足一定的覆盖率,不能够消除更多隐藏的缺陷。
而白盒测试能够从内部逻辑检测,测试覆盖率更高,给予软件质量更高的保证。
白盒测试特点
白盒测试的方法
逻辑覆盖测试
逻辑覆盖率的统计通过程序插装可以体现
程序插装
黑盒测试的优点有:
- 比较简单,不需要了解程序内部的代码及实现;
- 与软件的内部实现无关;
- 从用户角度出发,能很容易的知道用户会用到哪些功能,会遇到哪些问题;
- 基于软件开发文档,所以也能知道软件实现了文档中的哪些功能;
- 在做软件自动化测试时较为方便。
黑盒测试的缺点有:
- 没有清晰的测试规格说明,测试用例难以设计
- 自动化测试的复用性较低。
- 无法控制程序内部路径,可能缺少较多测试点
白盒测试的优点有:
- 帮助软件测试人员增大代码的覆盖率,提高代码的质量,发现代码中隐藏的问题。
白盒测试的缺点有:
- 程序运行会有很多不同的路径,不可能测试所有的运行路径;测试基于代码,只能测试开发人员做的对不
对,而不能知道设计的正确与否,可能会漏掉一些功能需求;系统庞大时,测试开销会非常大。灰盒测试
介于白盒与黑盒之间,针对被测对象信息的不同,采用不同的测试方法。
- 检验被测对象整体特性信息,采用黑盒测试
- 检验被测对象内部实现,采用白盒测试
- 既要观察被测对象整体信息,又要观察内部具体信息,信息占比不同,这就是所谓灰盒测试。
软件研发如同工厂生产,整个过程会有产品输出,输出的产品有两类
编译好的代码程序,如QQ.exe
用户使用手册,QQ使用手册
源代码,QQ源代码
需求分析:软件测试依据
概要设计:根据需求分析的内容,进行方案设计,明确是否覆盖到软件的需求
详细设计:包含方案、策略、架构、体系、接口名、接口文档、数据结构算法,保证开发过程细致
测试设计:测试需要进行哪些内容,包含哪些功能点,是否会影响其他功能,例如第三方支付页面跳转
测试用例:用例是进行测试的依据,测试的规范条文
测试报告:测试成功数量、失败数量、测试是否通过,允许产品上线等
静态测试:不运行被测试的软件系统,采用例如代码阅读、文档评审、代码分析等方式进行软件测试。
动态测试:按照预先规划好的测试数据与流程执行被测软件系统。
静态分析技术
定义:静态分析是不执行程序而分析程序的技术
功能:检查软件功能与需求是否一致,没有明显缺陷与歧义
测试点:
- 程序代码语法上是否一致性与完整性
- 文档描述是否规范、精准、便于查阅
- 程序与文档之间描述的一致性
动态分析技术
对软件系统进行数据驱动运行,与期望结果进行对比检查的过程。
- 脚本录制工具,进行反复测试,回归测试,如Robot、QTP、Selenium工具
- 性能测试工具,LoadRunner、Robot等
原文:https://www.cnblogs.com/Neroi/p/12968601.html