软件测试之测试的分类(重点:黑盒测试、白盒测试、单元测试、集成测试、系统测试)

简介: 1. 按照测试对象进行划分1)界面测试2)可靠性测试3)容错性测试4)文档测试5)兼容性测试6)易用性测试7)软件安装卸载的测试8)安全测试9)性能测试10)内存泄漏测试2. 按照是否查看代码划分1)黑盒测试2)白盒测试3)灰盒测试3. 按照开发阶段划分1)单元测试(结合 V 模型)2)集成测试3)系统测试4)验收测试5)将上面四种测试方法同 V 模型的阶段进行对应4. 按照测试实施组织划分1)α 测试2)β 测试3)第三方测试5. 按照是否运行进行划分1)静态测试2)动态测试6. 按照是否手工划分1)手工测试2)自动化测试

1. 按照测试对象进行划分

1)界面测试

界面是直接和用户进行交互的,界面设计的好坏决定了用户使用软件的直观感受


界面测试(UI 测试)一般包括以下内容:


对比 UI 设计稿,验证系统显示界面的一致性和正确性

验证界面上每个功能的正确性

验证界面排版布局是否合理。字体大小、图片排版、清晰程度等

验证界面控件的功能是否正常。滚动条、按钮、文本框等

对不同分辨率下的界面进行测试

保证页面从大变小(或从小变大)的变化过程是丝滑顺畅、不卡顿的

保证页面的字体不模糊、不重影、不消失

保证页面中的图片不消失、排版布局合理

保证页面的功能正常使用

2)可靠性测试

可靠性 是指系统正常运行的能力或者程度,一般用百分比表示


可靠性 = 正常运行时间 / (正常运行时间 + 非正常运行时间)


影响软件可靠性的因素:


软件本身

外界因素,包括电、网络、硬件设备等

3)容错性测试

容错性 是指因为自身或者外部一些异常的操作使得系统发生异常,系统能够自我处理异常或者错误的能力


容错性测试包含以下几个方面:


用户输入异常数据时,系统会不会给出提示,或者系统内部是否做一些处理


在用户做出一些复杂操作或者可能危害数据安全的操作时,会不会给出提示信息


断电、断网或者硬件设备出问题了,是否可以无缝切换到备用服务器


灾难恢复性测试


人为使服务器发生故障,测试软件系统的环境恢复能力、系统数据恢复能力、以及恢复的时间


4)文档测试

对整个开发过程中产生的各种文档,需求文档、设计文档、功能文档、用户使用手册进行测试,验证文档的正确性、一致性和完整性


5)兼容性测试

平台的兼容: 验证系统对不同浏览器、操作系统、不同品牌手机或者电脑的兼容性

软件本身的兼容: 验证软件新功能对旧功能的兼容性,新开发的功能不能影响旧功能的使用

软件对用户数据的兼容性: 比如数据库中的一张表新增加一个字段,不能影响用户之前数据的存储

软件对第三方软件的兼容性: 在与第三方软件有功能或者数据交互时,不能影响第三方软件的使用

6)易用性测试

易用性测试 是指验证用户在使用软件过程中的是否灵活舒适、简单易用


易用性测试一般包括以下几点:


符合标准和规范


对于现在的软件,其 UI 设计的标准已经慢慢被确立,多数用户已经习惯了这种标准和规范。比如,软件发生严重错误时给出提示时图片或者字体的颜色


直观性


要求界面布局合理,软件功能操作简单、清晰易懂


灵活性


用户可以根据自己的习惯选择适合自己的操作方式


比如,手机上的键盘可以切换九宫格、全键盘、手写和五笔输入


舒适性


让用户对自己的操作有感知,不产生焦虑情绪


安装或者下载软件时,添加上进度条


7)软件安装卸载的测试

主要的测试点有以下几点:


是否可以使用不同方式正常安装和卸载软件

安装或者卸载时是否可以手动暂停或者取消

安装空间不足时,是否给出提示

卸载中途,取消卸载,软件是否可以正常使用

卸载或者安装过程中的异常测试(如:断网、断电、死机等)

卸载完成之后,软件的数据文件信息是否清理干净

8)安全测试

安全性 是指信息安全,指网络和系统保护用户的数据和隐私不被侵犯和泄露


防病毒、防黑客、防 XSS 注入、防 SQL 注入、防爬虫


9)性能测试

在使用软件时,有时会碰到网页打开时越来越慢,查询数据时很长时间才显示列表,这些都是系统的性能问题引起的


常见的性能问题如下:


资源泄露

资源瓶颈

线程死锁,线程阻塞

查询速度慢或效率低

衡量一个系统性能好坏的关键性指标有,用户操作的响应时间、吞吐量、内存和 CPU 的使用率


10)内存泄漏测试

内存泄漏会使软件运行越来越慢,最终停止响应


常见的导致内存泄露的原因:


内存分配后,没有回收

程序的写法有问题,无法回收(比如死循环造成无法执行到回收步骤)

API 函数的使用不正确,无法回收


2. 按照是否查看代码划分

1)黑盒测试

黑盒测试 就是完全不关心软件内部代码的实现和逻辑结构,只关心系统的输入输出是否符合预期,功能是否符合需求说明书的规定


黑盒测试的优点:


不需要了解代码的内部结构,代码能力差的人员也可以进行测试

站在用户的角度对系统功能进行测试,有利于培养测试人员的用户思维

测试用例是按照需求说明书设计的,不容易遗漏需求

黑盒测试的缺点: 由于黑盒测试不关心系统内部代码的实现,导致代码得不到测试


黑盒测试的测试方法:


等价类法、边界值法、错误猜测发、因果图法、场景法、正交法


2)白盒测试

白盒测试 就是针对代码进行测试,根据代码的逻辑结构设计测试用例,验证代码的实际运行状态是否符合预期状态


白盒测试的测试方法:


语句覆盖:


设计足够的测试用例,使得程序中的 每条语句都被至少执行一次


判定覆盖:


设计足够的测试用例,使得程序中 每个判定语句的每个分支都被至少执行一次。


如: if else 语句中 if 条件为真、为假都要被测试;switch case 语句中每个 case 都要被测试


条件覆盖:


设计足够的测试用例,使得判定语句中 每个逻辑条件为真和为假都至少出现一次


如: if (a > 0 && b < 0) 中,要确保 a > 0、b < 0 两个逻辑条件分别为真和为假的情况都至少出现一次


判定 – 条件覆盖:


设计足够的测试用例,使得判定语句中 每个逻辑条件为真为假都至少出现一次,同时 判定语句的所有可能结果也至少出现一次


如: if (a > 0 && b < 0) 中,要确保 a > 0、b < 0 两个逻辑条件分别为真和为假的情况都至少出现一次,同时 if (a > 0 && b < 0) 判定语句为真和为假的情况也至少出现一次


条件组合覆盖:


设计足够的测试用例,使得判定语句中 逻辑条件结果的所有可能组合至少出现一次


如: if (A && B) 中,存在两个条件 A 和 B,则条件组合覆盖要求测试用例包含以下几种情况:


A 为真,B 为真

A 为真,B 为假

A 为假,B 为真

A 为假,B 为假

路径覆盖:


设计足够的测试用例,使得程序中 每一条可能走过的路径都至少执行一次


3)灰盒测试

介于黑盒测试和白盒测试之间的一种测试,多用于集成测试阶段,不仅关注程序的输入和输出,同时也关注程序内部的情况


3. 按照开发阶段划分

测试金字塔: 越往下测试效率越高,定位问题越容易


87.png

87.png


1)单元测试(结合 V 模型)

单元测试 是对软件组成的最小单元 —— 模块进行测试,验证软件基本组成模块的正确性


测试阶段: 编码后或者编码前(TDD)


TDD:测试驱动开发,在开发人员编写功能代码之前,先设计好测试用例的代码,然后根据测试用例的代码编写功能代码,最终目的是让开发前设计的测试用例全部都能执行通过


测试对象: 软件的各个模块


测试方法: 白盒测试


测试人员: 白盒测试工程师或者开发人员


测试依据: 详细设计文档


测试内容: 模块的接口、边界测试、异常测试、路径测试、局部数据结构的测试


Java 中使用 Junit 框架进行单元测试


2)集成测试

按照一定的策略把单元模块组合起来形成一个大的功能模块,对这个大的功能模块进行测试


测试阶段: 单元测试之后


测试对象: 集成的大模块


测试方法: 灰盒测试


测试依据: 概要设计文档


测试人员: 白盒测试人员或者开发人员


测试内容: 整个模块功能的正确性、单元模块之间接口的正确性、单个模块的缺陷对整个模块功能的影响、模块之间功能的冲突、全局数据结构的测试


3)系统测试

对整个软件系统的功能、性能以及软件运行的软硬件环境进行全面测试


测试阶段: 集成测试通过之后


测试对象: 整个软件系统


测试方法: 黑盒测试


测试人员: 黑盒测试人员


测试依据: 需求规格说明文档


测试内容: 功能、界面、兼容性、安全性、性能、可靠性、易用性、容错性


系统测试中还包含有回归测试和冒烟测试:


回归测试: 当系统引入新的代码或者修改了旧代码之后,重新进行测试以确保系统各项功能正常使用


回归测试一般采用自动化测试


冒烟测试: 正式测试之前,会对系统的基本流程和核心功能进行测试,测试通过之后,才会开始正式测试


4)验收测试

软件上线前的最后一道测试,由用户或者产品交付方依据用户需求进行测试


测试阶段: 系统测试之后


测试对象: 整个系统


测试人员: 用户或者产品交付方


测试依据: 用户需求


测试方法: 黑盒测试


测试内容: 同系统测试


5)将上面四种测试方法同 V 模型的阶段进行对应


88.png

4. 按照测试实施组织划分

1)α 测试

α 测试 是指让用户或 除了开发人员和测试人员之外 的公司内部人员到开发现场去进行测试


2)β 测试

β 测试 是指 实际用户在实际使用环境下 进行测试,不限时间、不限地点


比如:某些游戏在正式上线之前会开启测试服,并邀请一部分玩家进行测试


α 测试和 β 测试的区别:


α 测试在 β 测试之前

两者的测试环境不同,α 测试是在开发环境下,β 测试是在实际用户使用环境下

相较于 α 测试,β 测试的规模较大,测试周期也比较长

3)第三方测试

由第三方软件测试机构 按照业内的标准和规范 对软件进行测试


5. 按照是否运行进行划分

1)静态测试

不运行代码,静态的检查代码中可能出现错误的地方,分析代码的逻辑结构和具体的方法实现是否满足需求


2)动态测试

运行代码,执行测试用例进行测试


6. 按照是否手工划分

1)手工测试

手工的一个一个的执行测试用例,查看测试结果


优点: 有利于做探索性测试,无法被自动化测试替代


缺点: 用例很多时容易出错,效率也比较低


2)自动化测试

机器按照事先设定好的条件去执行测试,这些条件包括正常的和异常的


自动化测试按照测试对象还可分为:UI 自动化、接口自动化、性能自动化


自动化的价值和意义: 节省人力,自动化脚本运用率越高,越有价值


不是所有项目都适合自动化测试


自动化测试不适合于项目不稳定,功能频繁变动的功能,一般多用于回归测试和冒烟测试


7. 按照地域划分

按照地域划分可以划分为:本地化测试 和 国际化测试


软件的国际化: 开发软件时使用的一种工程技术,使得软件在适用不同国家的语言、风俗以及使用习惯的时候不用更改软件的源码就可以做到


软件的国际化和本地化是面向全球不同地区用户使用的软件系统的两个过程,而本地化测试和国际化测试则是针对这类软件产品进行的测试


目录
相关文章
|
2月前
|
测试技术 开发者 UED
探索软件测试的深度:从单元测试到自动化测试
【10月更文挑战第30天】在软件开发的世界中,测试是确保产品质量和用户满意度的关键步骤。本文将深入探讨软件测试的不同层次,从基本的单元测试到复杂的自动化测试,揭示它们如何共同构建一个坚实的质量保证体系。我们将通过实际代码示例,展示如何在开发过程中实施有效的测试策略,以确保软件的稳定性和可靠性。无论你是新手还是经验丰富的开发者,这篇文章都将为你提供宝贵的见解和实用技巧。
|
4月前
|
IDE 测试技术 持续交付
Python自动化测试与单元测试框架:提升代码质量与效率
【9月更文挑战第3天】随着软件行业的迅速发展,代码质量和开发效率变得至关重要。本文探讨了Python在自动化及单元测试中的应用,介绍了Selenium、Appium、pytest等自动化测试框架,以及Python标准库中的unittest单元测试框架。通过详细阐述各框架的特点与使用方法,本文旨在帮助开发者掌握编写高效测试用例的技巧,提升代码质量与开发效率。同时,文章还提出了制定测试计划、持续集成与测试等实践建议,助力项目成功。
104 5
|
4月前
|
机器学习/深度学习 Web App开发 测试技术
『软件测试3』八大典型的黑盒测试方法已来袭,快快接住!
该文章介绍了八种常用的黑盒测试方法,包括等价类划分、边界值分析、错误推测法、因果图法、决策表测试、状态转换法、场景法以及随机测试,并提供了相应的案例说明。
|
4月前
|
测试技术 数据库
『软件测试2』 关于黑盒测试和测试用例的基础知识
该文章讲解了黑盒测试的基本概念以及如何编写有效的测试用例,包括选择合适的输入数据、预期结果的设定和测试执行的步骤。
|
5月前
|
测试技术 C# 开发者
“代码守护者:详解WPF开发中的单元测试策略与实践——从选择测试框架到编写模拟对象,全方位保障你的应用程序质量”
【8月更文挑战第31天】单元测试是确保软件质量的关键实践,尤其在复杂的WPF应用中更为重要。通过为每个小模块编写独立测试用例,可以验证代码的功能正确性并在早期发现错误。本文将介绍如何在WPF项目中引入单元测试,并通过具体示例演示其实施过程。首先选择合适的测试框架如NUnit或xUnit.net,并利用Moq模拟框架隔离外部依赖。接着,通过一个简单的WPF应用程序示例,展示如何模拟`IUserRepository`接口并验证`MainViewModel`加载用户数据的正确性。这有助于确保代码质量和未来的重构与扩展。
148 0
|
5月前
|
测试技术 Java Spring
Spring 框架中的测试之道:揭秘单元测试与集成测试的双重保障,你的应用真的安全了吗?
【8月更文挑战第31天】本文以问答形式深入探讨了Spring框架中的测试策略,包括单元测试与集成测试的有效编写方法,及其对提升代码质量和可靠性的重要性。通过具体示例,展示了如何使用`@MockBean`、`@SpringBootTest`等注解来进行服务和控制器的测试,同时介绍了Spring Boot提供的测试工具,如`@DataJpaTest`,以简化数据库测试流程。合理运用这些测试策略和工具,将助力开发者构建更为稳健的软件系统。
80 0
|
5月前
|
测试技术 Java
全面保障Struts 2应用质量:掌握单元测试与集成测试的关键策略
【8月更文挑战第31天】Struts 2 的测试策略结合了单元测试与集成测试。单元测试聚焦于单个组件(如 Action 类)的功能验证,常用 Mockito 模拟依赖项;集成测试则关注组件间的交互,利用 Cactus 等框架确保框架拦截器和 Action 映射等按预期工作。通过确保高测试覆盖率并定期更新测试用例,可以提升应用的整体稳定性和质量。
90 0
|
8月前
|
前端开发 Java 测试技术
【软件测试】个人博客系统测试
【软件测试】个人博客系统测试
123 1
|
5月前
|
Java 测试技术 开发者
探索软件测试的多维度:从单元到系统,再到性能测试
本文深入探讨了软件测试的多个关键维度,包括单元测试、集成测试、系统测试以及性能测试。通过分析每个阶段的目标和方法,本文旨在帮助读者理解如何构建一个全面的测试策略,确保软件产品的质量与性能。我们将通过具体案例和数据来揭示不同测试阶段的重要性及其在软件开发生命周期中的作用。
118 0
|
6月前
|
测试技术 数据库 Python
在系统工程中,软件测试是一个至关重要的环节,它确保软件的质量、可靠性和性能。软件测试通常包括多个阶段,如单元测试、集成测试、系统测试和验收测试等。
在系统工程中,软件测试是一个至关重要的环节,它确保软件的质量、可靠性和性能。软件测试通常包括多个阶段,如单元测试、集成测试、系统测试和验收测试等。

热门文章

最新文章