软件测试:边界值分析法详解

news/2025/11/5 16:40:36/文章来源:https://www.cnblogs.com/kkkk11/p/19194100
1、边界值分析法的介绍和概念

边界值分析是一种常用的黑盒测试方法,是对等价类划分方法的补充;所谓边界值,是指相对于输入等价类和输出等价类而言,稍高于其最高值或稍低于最低值的一些特定情况。边界值分析的步骤包括确定边界,选择测试用例两个步骤。

根据大量的测试统计数据,很多错误是发生在输入或输出范围的边界上,而不是发生在输入/输出范围的中间区域。因此针对各种边界情况设计测试用例,可以查出更多的错误。所以,边界值分析法是一种很实用的黑盒测试用例方法,它具有很强的发现故障缺陷能力。

2、边界值分析法原理和思想

2.1边界值分析法的基本原理

错误更可能出现在输入变量的极值附近。失效极少由两个(或多个)缺陷的同时发生引起的。

2.2边界值分析法的基本思想

选取正好等于,刚刚大于或刚刚小于边界的值作为测试数据,而不是选取等价类中的典型值或任意值作为测试数据。

表示方法:最小值min,略高于最小值min+,正常值nom,略低于最大值max-,最大值max

3、单缺陷假设和多缺陷假设

单缺陷假设是边界值分析的关键假设。单缺陷假设指“失效极少是由两个或两个以上的缺陷同时发生引起的”。在边界值分析中,单缺陷假设即选取测试用例时仅仅使得一个变量取极值,其他变量均取正常值。

多缺陷假设则是指“失效是由两个或两个以上缺陷同时作用引起的”,要求在选取测试用例时同时让多个变量取极值。

4、边界值测试数据类型

类型包括:数值、速度、字符、地址、位置、尺寸、数量、空间……

边界值

测试用例的设计思路

字符

起始-1个字符/结束+1个字符

假设一个文本输入区域允许输入1个到255个 字符,输入1个和255个字符作为有效等价类;输入0个和256个字符作为无效等价类,这几个数值都属于边界条件值。

数值

最小值-1/最大值+1

假设某软件的数据输入域要求输入5位的数据值,可以使用10000作为最小值、99999作为最大值;然后使用刚好小于5位和大于5位的 数值来作为边界条件。

空间

小于空余空间一点/大于满空间一点

例如在用U盘存储数据时,使用比剩余磁盘空间大一点(几KB)的文件作为边界条件。

以上类型的边界值应该在:最大/最小、首位/末位、上/下、最快/最慢、最高/最低、 最短/最长、 空/满等情况下用边界值作为测试数据

5、内部边界值分析

在多数情况下,边界值条件是基于应用程序的功能设计而需要考虑的因素,可以从软件的规格说明或常识中得到,也是最终用户可以很容易发现问题的。然而,在测试用例设计过程中,某些边界值条件是不需要呈现给用户的,或者说用户是很难注意到的,但同时确实属于检验范畴内的边界条件,称为内部边界值条件或子边界值条件。

内部边界值条件主要有下面几种:

51、数值的边界值检验:计算机是基于二进制进行工作的,因此,软件的任何数值运算都有一定的范围限制。

范围或值

位(bit)

0 或 1

字节(byte)

0 ~ 255

字(word)

0~65535(单字)或 0~4294967295(双字)

千(K)

1024

兆(M)

1048576

吉(G)

1073741824

5.2字符的边界值检验:在计算机软件中,字符也是很重要的表示元素,其中ASCII和Unicode是常见的编码方式。如下列出了一些常用字符对应的ASCII码值。

字符

ASCII码值

空 (null)

0

空格 (space)

32

可输入的字符

33~126

0~9

48~57

A~Z

65~90

a~z

97~122

5.3其它边界值检验:在不同的行业应用领域,依据硬件和软件的标准不同而具有各自特定的边界值。如下列出部分手机相关的边界值

硬件设备

范围或值

手机锂电池电压

工作电压:3.6~4.2V;

保护电压:2.5~3V不等

手机正常使用温度

-25°C~+60°C

6、边界值测试介绍

6.1基本边界值测试

有n个输入变量,设计测试用例使得一个变量在数据有效区内取最大值、略小于最大值、正常值、略大于最小值和最小值。如下图所示,两个变量X1,X2。它们的有效取值区间分别为[c,d],[a,b]。

image

 

对于有n个输入变量的程序,基本边界值分析的测试用例个数为4n+1。

边界值测试分析采用了可靠性理论的单缺陷假设。

优点:简便易行;生成测试数据的成本很低

局限性:测试用例不充分;不能发现测试变量之间的依赖关系;不考虑含义和性质;

结论:只能作为初步测试用例使用

6.2健壮性测试

健壮性是指在异常情况下,软件还能正常运行的能力。健壮性考虑的主要部分是预期输出,而不是输入。健壮性测试是边界值分析的一种简单扩展。除了变量的5 个边界分析取值还要考虑略超过最大值(max)和略小于最小值(min)时的情况。健壮性测试的最大价值在于观察处理异常情况,它是检测软件系统容错性的重要手段。如下图所示。

PS:软件容错性的度量:从非法输入中恢复;健壮性有两层含义:容错能力和恢复能力

image

 

对于有n个输入变量的程序,健壮性测试的测试用例个数为6n+1。

6.3最坏情况测试

最坏情况测试拒绝单缺陷假设,它关心的是当多个变量取极值时出现的情况。最坏情况测试中,对每一个输入变量首先进行包含最小值、略高于最小值、正常值、略低于最大值、最大值等5个元素集合的测试,然后对这些集合进行笛卡尔积计算,以生成测试用例。最坏情况测试将意味着更大工作量。如下图所示。

image

 

对于有n个输入变量的程序,最坏情况测试的测试用例个数为5^n。

最坏情况与基本边界值分析的比较

  • 基本边界值分析测试用例是最坏情况测试用例的真子集
  • 最坏情况测试显然更彻底
  • 最坏情况测试工作量大得多,变量函数的最坏情况测试会产生5的n次方个测试用例,边界值分析只产生4n+1个测试用例

image

 

6.4健壮性最坏情况测试

健壮最坏情况假设对每一个变量首先进行最小值、略小于最小值的值、略高于最小值的值、正常值、最大值、略高于最大值的值、略低于最大值的值等7个元素的集合。然后对这些集合进行笛卡尔积运算,以生成测试用例。如下图所示。

image

 

对于有n个输入变量的程序,健壮最坏情况测试的测试用例个数为7^n。

6.5特殊值测试

  • 边界值分析假定n个变量是互相独立的,没有考虑这些变量之间的互相依赖关系;
  • 特殊值测试使用领域知识、使用类似程序的经验开发用例的特殊值。
  • 特点:最直观、最不一致、具有高度主观性
  • 特殊值测试特别依赖测试人员的能力
  • 虽然特殊值测试是高度主观性,但是能更有效地发现问题

例如:2月28日、2月29日

6.6随机测试

  • 随机测试的基本思想

不是永远选取有界变量的最小值、略高于最小值、正常值、略低于最大值和最大值,而是使用随机数生成器选出测试用例。

  • 随机测试的一种实现方法

有界变量a≤X≤b值的一个VisualBasic应用程序生成的X,满足下式:

X=Int(b-a+1)*Rnd+a

函数Int返回浮点数的整数部分

函数Rnd生成区间[0,1]内的随机数

7、基于边界值分析方法选择测试用例的原则

1)如果输入条件规定了值的范围,则应取刚达到这个范围的边界的值,以及刚刚超越这个范围边界的值作为测试输入数据。

例如,如果程序的规格说明中规定:

"重量在10公斤至50公斤范围内的邮件,其邮费计算公式为……"。作为测试用例,我们应取10及50,还应取10.01,49.99,9.99及50.01等。

2)如果输入条件规定了值的个数,则用最大个数,最小个数,比最小个数少一,比最大个数多一的数作为测试数据。

例如,一个输入文件应包括1~255个记录,则测试用例可取1和255,还应取0及256等。

3)将规则1)和2)应用于输出条件,即设计测试用例使输出值达到边界值及其左右的值。

例如,某程序的规格说明要求计算出"每月保险金扣除额为0至1165.25元",其测试用例可取0.00及1165.24、还可取一0.01及1165.26等。

再如一程序属于情报检索系统,要求每次“最少显示1条、最多显示4条情报摘要”,这时我们应考虑的测试用例包括1和4,还应包括0和5等。

4)如果程序的规格说明给出的输入域或输出域是有序集合,则应选取集合的第一个元素和最后一个元素作为测试用例。

5)如果程序中使用了一个内部数据结构,则应当选择这个内部数据结构的边界上的值作为测试用例。

6)分析规格说明,找出其它可能的边界条件。

8、边界值分析法实例分析

现有一个学生标准化考试批阅试卷,产生成绩报告的程序。其规格说明如下:程序的输入文件由一些有80个字符的记录组成,如右图所示,所有记录分为3组:

image

 

标题:这一组只有一个记录,其内容为输出成绩报告的名字。

试卷各题标准答案记录:每个记录均在第80个字符处标以数字"2"。该组的第一个记录的第1至第3个字符为题目编号(取值为1一999)。第10至第59个字符给出第1至第50题的答案(每个合法字符表示一个答案)。该组的第2,第3……个记录相应为第51至第100,第101至第150,…题的答案。

每个学生的答卷描述:该组中每个记录的第80个字符均为数字"3"。每个学生的答卷在若干个记录中给出。如甲的首记录第1至第9字符给出学生姓名及学号,第10至第59字符列出的是甲所做的第1至第50题的答案。若试题数超过50,则第2,第3……纪录分别给出他的第51至第100,第101至第150……题的解答。然后是学生乙的答卷记录。

学生人数不超过200,试题数不超过999。

程序的输出有4个报告:

a)按学号排列的成绩单,列出每个学生的成绩、名次。
b)按学生成绩排序的成绩单。
c)平均分数及标准偏差的报告。
d)试题分析报告。按试题号排序,列出各题学生答对的百分比。

分别考虑输入条件和输出条件,以及边界条件。给出右表所示的输入条件及相应的测试用例。

image

 


欢迎大家关注笔者的公众号:程序员老奕,专注于软件测试干活分享,全套测试资源可免费分享!

最后如果你想学习自动化测试,欢迎加入笔者的交流群:771645171,里面会有很多资源和大佬答疑解惑,我们一起交流一起学习!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/956933.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

2025 年 11 月社区养老院,老年痴呆养老院,自理老人住养老院最新推荐,聚焦资质、案例、售后的五家机构深度解读

引言 随着人口老龄化进程持续加快,养老服务需求呈现多元化爆发态势,社区养老院、老年痴呆养老院、自理老人住养老院等细分领域的服务品质成为家庭决策的核心考量。然而市场上机构数量繁杂,服务标准不统一,部分机构…

Branching Heuristic Combining in SAT

Branching Heuristic Combining in SAT学习文献来源: 1. Combining VSIDS and CHB Using Restarts in SAT。 引用: @inproceedings{DBLP:conf/cp/CherifHT21,author = {Mohamed Sami Cherif andDjamal Habet a…

2025 年 11 月山西养老院,太原养老院,敬老院,日间照料养老院最新推荐,产能、专利、环保三维数据透视!

引言 随着养老服务需求的持续增长,养老机构市场规模不断扩大,年均增长率保持在较高水平,优质养老服务成为众多家庭的核心需求。然而当前市场中机构数量繁杂,部分机构存在设施不完善、护理专业度不足、安全保障缺失…

HTML、CSS 和 JavaScript 基础知识笔记

一~七,HTML 八~ 十三,CSS 十四~二十二,JavaScript 二十三,总结与后续学习建议一、web前端介绍 三件套:HTML-页面结构,CSS-页面样式和布局,Javascipt交互和功能 二、安装VScode开发环境 插件:Chinese (Simplifi…

2025年昆明民办高中优质学校排名:比较不错的民办高中品牌学校

一、定制型民办高中优质学校 昆明经济技术开发区正道实力中学 - TOP1 推荐指数:★★★★★ 口碑评分:4.9分(满分5分) 品牌介绍:昆明经济技术开发区正道实力中学作为正道教育集团布局昆明民办教育的核心校区,是经…

2025 年最新推荐电镀加工优质厂家榜单:环保达标与质量稳定企业全面盘点及选择指南美妆系列五金件/手镯/宠物链电镀加工公司推荐

引言 为助力企业精准筛选优质电镀加工合作伙伴,本次榜单由行业权威协会主导测评,结合近一年行业数据及实地考察结果生成。测评采用 “三维九项” 评估体系,从环保合规(废水处理效率、废气净化率、环保认证完整性)…

[题解]P6117 [JOI 2019 Final] 硬币收藏 / Coin Collecting

思路 每一个硬币最终都会走到 \(2 \times n\) 的矩形里面,所以不妨将它们先到其到矩形中最近的节点。 现在只需要在这个矩形中调整使每一个位置都有一个硬币。贪心的,我们希望让 \(x\) 更小的填的位置尽量靠前。 从前…

joyagent部署笔记 - sherlock

京东的joyagent感觉就是个半成品,很多坑。卡住的问题,看控制台的报错,这是没配置服务端地址,需要在ui/.env 这里配置

阜阳民事纠纷律师2025年Top10排行:专业推荐与选择指南

摘要 随着法律意识的提升,阜阳地区民事纠纷案件逐年增加,对专业律师的需求日益旺盛。2025年,民事纠纷律师行业在阜阳呈现专业化、高效化趋势,本文基于行业数据和用户口碑,整理出排行前十的律师推荐,旨在帮助用户…

目前阜阳有实力的民事纠纷律师哪家好

摘要 随着2025年法律服务业的发展,阜阳地区的民事纠纷案件逐年增加,对专业律师的需求日益凸显。本文基于行业数据和用户口碑,为您推荐阜阳地区排名前五的实力民事纠纷律师,并提供详细比较和选择指南。文章末尾附有…

Linux 格式化U盘为FAT32格式

格式命令 sudo mkfs.vfat -F 32 -n "MY_USB" /dev/sda1查看U盘格式 root@hzmct:~# lsblk -f NAME FSTYPE LABEL UUID FSAVAIL FSUSE% MOUNTPOIN sda └─sda1exfa…

2025 年 11 月码垛机厂家推荐排行榜,全自动码垛机,高低位码垛机,编织袋/纸箱/桶/粉料/肥料码垛机,码垛机器人,江苏无锡全自动码垛机厂家推荐

行业背景与发展趋势随着工业自动化进程的加速推进,码垛机作为现代物流与生产环节中的关键设备,正经历着技术革新与市场扩张的双重驱动。码垛机不仅显著提升了物料搬运效率,还通过智能化控制系统降低了人工成本,成为…

目录映射

在您提供的 Docker 命令中,目录映射是通过 -v 参数指定的,其格式为 宿主机目录:容器内目录。具体解析如下:-v 主机目录(本地目录/data/ftp):虚拟目录(容器目录 /home/vsftpd ) -v /data/ftp:/home/vsftpd数据持…

MATLAB/Simulink的开关磁阻电机(SRM)控制系统仿真

一、系统架构 1. 硬件组成模块 graph TDA[SRM电机] --> B(不对称半桥功率变换器)B --> C{控制器}C --> D[电流检测电路]C --> E[位置检测电路]C --> F[电压检测电路]D --> CE --> CF --> CC -…

一款开源的微信公众号Markdown编辑器

https://mp.weixin.qq.com/s/Hloo_NVTCVCK6nfyq6Z2PQ 安装Docker sudo apt update sudo apt install -y docker.io docker-compose 启动服务 sudo docker run -d -p 8080:80 doocs/md:latest 服务启动后,浏览器访问IP…

Docker实操:安装MySQL5.7详解

介绍 Docker 中文网址: https://www.dockerdocs.cn Docker Hub官方网址:https://hub.docker.com Docker Hub中MySQL介绍:https://hub.docker.com/_/mysql 准备 先创建3个目录,创建MySQL容器时会挂载容器的卷(Volum…

在 Docker 中部署 FTP 服务器

在 Docker 中部署 FTP 服务器可以通过以下步骤完成,这里以广泛使用的 pure-ftpd 镜像为例,提供完整部署方案: 📦 基础部署(单用户模式) # 创建数据目录 mkdir -p ~/ftp/data ~/ftp/config# 运行容器(单用户模式…

在AI技术唾手可得的时代,挖掘新需求成为核心竞争力——某知名自动化脚本项目需求洞察

本文分析了一个广受欢迎的自动化脚本项目,该项目包含多个实用脚本,如自动发送工作延迟消息、处理紧急邮件和远程控制咖啡机等,展示了在AI技术快速发展的背景下,识别真实用户需求的重要性。内容描述核心功能定位:该…

LangChain4j实战:模型参数配置、多模态、流式输出、聊天记忆、提示词工程全解析

LangChain4j实战:模型参数配置、多模态、流式输出、聊天记忆、提示词工程全解析 前提后面用于演示的代码环境为: JDK-21,apache-maven-3.6.2,spring-boot和langchain4j的版本如下面pom文件所示<properties><…

kafka-ui-docker-compose.yml

version: 3.8services:kafka-ui:image: artifacts.iflytek.com/docker-repo/provectuslabs/kafka-uicontainer_name: kafka-uiports:- "18080:8080"restart: unless-stoppedenvironment:- DYNAMIC_CONFIG_EN…