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

简介: 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. 按照地域划分

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


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


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


目录
相关文章
|
1月前
|
数据管理 测试技术 持续交付
深入理解软件测试中的持续集成与持续部署
在现代软件开发实践中,持续集成(Continuous Integration, CI)和持续部署(Continuous Deployment, CD)是提升开发效率、保障产品质量的关键环节。本文将深入探讨CI/CD的概念、实施策略及其在软件测试中的作用,旨在为读者揭示如何通过有效的自动化流程来优化测试活动,减少人为错误,并实现快速反馈和迭代。文章还将讨论面临的挑战和可能的解决方案,以期帮助团队构建更加健壮的开发和测试环境。
|
19天前
|
Java 测试技术
SpringBoot整合单元测试&&关于SpringBoot单元测试找不到Mapper和Service报java.lang.NullPointerException的错误
SpringBoot整合单元测试&&关于SpringBoot单元测试找不到Mapper和Service报java.lang.NullPointerException的错误
21 0
|
1天前
|
数据挖掘 jenkins 测试技术
python集成测试持续集成
【4月更文挑战第20天】
8 2
|
3天前
|
敏捷开发 测试技术 持续交付
探索自动化测试在持续集成中的关键作用
【4月更文挑战第24天】 随着敏捷开发和持续集成(CI)实践的普及,自动化测试已经成为确保软件质量和加速交付过程的核心环节。本文将深入探讨自动化测试如何与持续集成协同工作,提升开发流程的效率和可靠性。我们将分析自动化测试的策略、工具选择以及最佳实践,并讨论其对缩短反馈周期、降低风险和提高生产力的影响。通过案例研究和实际经验分享,本文旨在为读者提供实施高效自动化测试策略的深刻见解。
|
Java 测试技术
Java 中的单元测试和集成测试策略
【4月更文挑战第19天】本文探讨了Java开发中的单元测试和集成测试。单元测试专注于单一类或方法的功能验证,使用测试框架如JUnit,强调独立性、高覆盖率和及时更新测试用例。集成测试则验证模块间交互,通过逐步集成或模拟对象来检测系统整体功能。两者相辅相成,确保软件质量和降低修复成本。
|
13天前
|
分布式计算 Hadoop 测试技术
Hadoop【基础知识 05】【HDFS的JavaAPI】(集成及测试)
【4月更文挑战第5天】Hadoop【基础知识 05】【HDFS的JavaAPI】(集成及测试)
40 8
|
15天前
|
缓存 自动驾驶 测试技术
如何进行有效的Apollo测试:单元测试和集成测试指南
如何进行有效的Apollo测试:单元测试和集成测试指南
44 13
|
22天前
|
jenkins 测试技术 持续交付
软件测试|docker搭建Jenkins+Python+allure自动化测试环境
通过以上步骤,你可以在Docker中搭建起Jenkins自动化测试环境,实现Python测试的自动化执行和Allure报告生成。 买CN2云服务器,免备案服务器,高防服务器,就选蓝易云。百度搜索:蓝易云
44 6
|
1月前
|
机器学习/深度学习 人工智能 自然语言处理
提升软件测试效率:AI驱动的自动化测试策略
【2月更文挑战第30天】随着人工智能(AI)在软件开发周期中的日益普及,其在提高软件测试效率方面的潜力正受到越来越多的关注。本文探讨了如何通过集成AI技术来优化自动化测试流程,从而减少重复工作、提高错误检测率和加快反馈速度。我们将分析当前AI在自动化测试中的应用,并提出一系列策略以利用AI改进测试案例生成、执行和维护过程。
88 0
|
18天前
|
测试技术 C语言
网站压力测试工具Siege图文详解
网站压力测试工具Siege图文详解
26 0

热门文章

最新文章