03-测试用例设计方法-边界值

简介: 03-测试用例设计方法-边界值

1. 定义

  • 边界值:选取整好等于、刚刚好大于或刚刚好小于边界值作为测试数据

2. 上点、离点、内点

  • 上点:就是指得边界上得点,开区间的话,上点就是在域外,闭区间得话,上点就是在域内。
  • 离点:指得就是离上点最近得点,如果是开区间,那么离点就在域内,如果是闭区间,那么离点就在域外。
  • 内点:域内得任意点都是内点。
  • [0,99]  :  上点:0,99     离点:-1,100     内点:50
  • (0,99] :上点:0,99     离点:1,100     内点:50
  • (0,99) :上点:0,99     离点:1,98        内点:50

 

3. 设计测试用例步骤

  • 分析需求,确定输入数据规则
  • 使用规则划分有效和无效等价类
  • 确认上点、离点、内点:范围、长度类时使用
  • 设计测试用例,覆盖有效等价类:一条用例尽可能多的覆盖有效等价类
  • 设计测试用例,覆盖无效等价类:一条用例只能覆盖一个无效等价类

4. 测试用例设计案例

  • 例子:固定电话号码测试 :地区码(3/4) + 电话号码(7/8位)
例子:固定电话号码测试 :地区码(3/4) + 电话号码(7/8位)
1.分析需求,确定输入的数据规则
输入 组成 数据类型    
固定电话号码 地区码 3/4位数字    
  电话号码 7/8位数字    
         
2.根据输入的规则,划分有效和无效等价类
输入 组成 长度 类型 组成规则
固定电话号码 地区码 3/4位 数字 以0开头
  电话号码 7/8位 数字 以非0非1开头
         
输入 组成 有效等价类 无效等价类  
固定电话号码 地区码 1.以0开头的3位数字  (3位)
2.以0开头的4位数字   (4位)
3.以0开头小于3位的数字          (2位)
4.以0开头大于4位的数字          (5位)
5.以0开头的包含非数字4位字符串
6.以非0开头的4位数字
 
  电话号码 7.以非0开头的7位数字  (7位)
8.以非1开头的8位数字  (8位)
9.以非0非1开头小于7位的数字      (6位)
10.以非0非1开头大于8位的数字     (9位)
11.以非0非1开头包含非数字的8位字符串
12.以0开头的8位数字
13.以1开头的8位数字
 
         
3.确定上点、离点、内点  
         
4.编写用例,覆盖有效等价类
5.编写用例,覆盖无效等价类
输入 有效用例 无效用例    
测试用例 012-2345678       覆盖1,7
012-23456789     覆盖1,8
0123-2345678     覆盖2,7
0123-23456789   覆盖2,8
01-2345678             覆盖3
01234-2345678       覆盖4
0a12-2345678         覆盖5
1234-2345678         覆盖6
012-234567             覆盖9
012-234567890       覆盖10
012-2a345678         覆盖11
012-01234567         覆盖12
012-12345678         覆盖13
   

 


相关文章
|
1月前
|
数据采集 监控 机器人
浅谈网页端IM技术及相关测试方法实践(包括WebSocket性能测试)
最开始转转的客服系统体系如IM、工单以及机器人等都是使用第三方的产品。但第三方产品对于转转的业务,以及客服的效率等都产生了诸多限制,所以我们决定自研替换第三方系统。下面主要分享一下网页端IM技术及相关测试方法,我们先从了解IM系统和WebSocket开始。
49 4
|
3月前
|
测试技术 API 项目管理
API测试方法
【10月更文挑战第18天】API测试方法
70 1
|
3月前
|
安全 测试技术
北大李戈团队提出大模型单测生成新方法,显著提升代码测试覆盖率
【10月更文挑战第1天】北京大学李戈教授团队提出了一种名为“统一生成测试”的创新方法,有效提升了大模型如GPT-2和GPT-3在单一测试中的代码生成覆盖率,分别从56%提升至72%和从61%提升至78%。这种方法结合了模糊测试、变异测试和生成对抗网络等多种技术,克服了传统测试方法的局限性,在大模型测试领域实现了重要突破,有助于提高系统的可靠性和安全性。然而,该方法的实现复杂度较高且实际应用效果仍需进一步验证。论文可从此链接下载:【https://drive.weixin.qq.com/s?k=ACAAewd0AA48Z2kXrJ】
87 1
|
3月前
|
测试技术 UED
软件测试中的“灰盒”方法:一种平衡透明度与效率的策略
在软件开发的复杂世界中,确保产品质量和用户体验至关重要。本文将探讨一种被称为“灰盒测试”的方法,它结合了白盒和黑盒测试的优点,旨在提高测试效率同时保持一定程度的透明度。我们将通过具体案例分析,展示灰盒测试如何在实际工作中发挥作用,并讨论其对现代软件开发流程的影响。
|
4月前
|
人工智能 测试技术 开发者
北大李戈团队提出大模型单测生成新方法,显著提升代码测试覆盖率
【9月更文挑战第27天】北京大学李戈团队在人工智能领域取得重要突破,提出HITS新方法,通过将待测方法分解为多个切片并利用大型语言模型逐个生成测试用例,显著提升代码测试覆盖率,尤其在处理复杂方法时效果显著,为软件开发和测试领域带来新希望。尽管存在一定局限性,HITS仍展示了巨大潜力,未来有望克服限制,推动软件测试领域的创新发展。论文详情见【https://www.arxiv.org/pdf/2408.11324】。
154 6
|
2月前
|
机器学习/深度学习 算法 UED
在数据驱动时代,A/B 测试成为评估机器学习项目不同方案效果的重要方法
在数据驱动时代,A/B 测试成为评估机器学习项目不同方案效果的重要方法。本文介绍 A/B 测试的基本概念、步骤及其在模型评估、算法改进、特征选择和用户体验优化中的应用,同时提供 Python 实现示例,强调其在确保项目性能和用户体验方面的关键作用。
42 6
|
2月前
|
JavaScript 安全 编译器
TypeScript 与 Jest 测试框架的结合使用,从 TypeScript 的测试需求出发,介绍了 Jest 的特点及其与 TypeScript 结合的优势,详细讲解了基本测试步骤、常见测试场景及异步操作测试方法
本文深入探讨了 TypeScript 与 Jest 测试框架的结合使用,从 TypeScript 的测试需求出发,介绍了 Jest 的特点及其与 TypeScript 结合的优势,详细讲解了基本测试步骤、常见测试场景及异步操作测试方法,并通过实际案例展示了其在项目中的应用效果,旨在提升代码质量和开发效率。
57 6
|
2月前
|
Java 测试技术 Maven
Java一分钟之-PowerMock:静态方法与私有方法测试
通过本文的详细介绍,您可以使用PowerMock轻松地测试Java代码中的静态方法和私有方法。PowerMock通过扩展Mockito,提供了强大的功能,帮助开发者在复杂的测试场景中保持高效和准确的单元测试。希望本文对您的Java单元测试有所帮助。
356 2
|
3月前
|
测试技术 Python
自动化测试项目学习笔记(三):Unittest加载测试用例的四种方法
本文介绍了使用Python的unittest框架来加载测试用例的四种方法,包括通过测试用例类、模块、路径和逐条加载测试用例。
111 0
自动化测试项目学习笔记(三):Unittest加载测试用例的四种方法
|
3月前
|
测试技术 Python
自动化测试项目学习笔记(二):学习各种setup、tearDown、断言方法
本文主要介绍了自动化测试中setup、teardown、断言方法的使用,以及unittest框架中setUp、tearDown、setUpClass和tearDownClass的区别和应用。
98 0
自动化测试项目学习笔记(二):学习各种setup、tearDown、断言方法