软件测试用例经典方法 | 因果图法及案例

简介: 典型的黑盒测试用例设计方法包括等价类划分法、边界值分析法、决策表法、因果图法等。如果程序的输入条件之间相互存在联系,那么就会使情况变得复杂,因为要检查输入条件的组合情况并不是一件容易的事情,即使把所有输入条件划分为等价类,它们之间的组合情况也相当多,难以分析。因此,必须考虑采用因果图法,这种方法可以针对多种条件组合、产生多个动作的情况来设计测试用例。

640.jpg


# 01、因果图的画法

因果图法是一种黑盒测试方法,它能够帮助人们按照一定的步骤高效地选择测试用例,同时还能指出需求规格说明书中存在的不完整性和二义性。

1. 输入条件与输出结果之间的因果关系

如图1描述了输入条件与输出结果间的关系,即“因果关系”。这种关系共有4种:恒等、非、或、与。

恒等: 若原因出现,则结果出现;若原因不出现,则结果也不出现。例如,若a=1,b=1;若a=0,则b=0。

非:若原因出现,则结果不出现;若原因不出现,则结果出现。例如,若a=1,则b=0;若a=0,则b=1。

或: 若几个原因中有一个出现,则结果出现;若几个原因都不出现,则结果不出现。例如,若a=1或b=1或c=1,则d=1;若a=b=c=0,则d=0。

与:若几个原因都出现,结果才出现;若其中有一个原因不出现,则结果不出现。例如,若a=b=c=1,则d=1;若a=0或b=0或c=0,则d=0。

640.png


■ 图1 因果图逻辑符号

2.输入或输出的约束关系
如图2 所示,输入状态之间还可能存在某些依赖关系,或输出结果之间相互制约,这被称为约束。其所描述的这种制约关系一般可被分为 5 类:互斥、包含、唯一、要求和屏蔽。其中,输入条件的约束有以下4类。

640.png


■ 图2 因果图的约束符号

互斥(E): 表示a、b、c这3个原因不会同时成立,最多有一个可能成立。

包含(I): 表示a、b、c这3个原因中至少有一个必须成立。

唯一(O): 表示a、b、c中必须有一个成立,且仅有一个成立。

要求(R): 表示当a出现时,b必须也出现。例如,若a=1,则b必须为1。

而其中的输出条件约束类型只有1种,即屏蔽(M):若a=1,则b必须为0;而当a=0时,b的值不定。

  1. 因果图法设计测试用例的步骤

(1) 分析在程序规格说明的描述中哪些是原因,哪些是结果,并给每个原因和结果赋予一个标识符。原因常常是输入条件或是输入条件的等价类,而结果则是输出条件。

(2) 分析在程序规格说明的描述中语义的内容,并将其表示成连接各个原因与各个结果的“因果图”。

(3) 标明约束条件。由于语法或环境的限制,有些原因和结果的组合情况是不可能出现的。为表明这些特定的情况,可在因果图上使用若干个标准的符号标明约束或限制条件。

(4) 把因果图转换成决策表。

(5) 把决策表中每一列拿出来作为依据,设计测试用例。

因果图生成的测试用例(局部,组合关系下的)包括了所有输入数据的取True与取False的情况,其构成的测试用例数目达到最少,且测试用例数目随输入数据数目的增加而增加。在较为复杂的问题中,这个方法常常十分有效,它能有力地帮助测试者确定测试用例。当然,如果开发项目在设计阶段就采用了决策表,那么也就不必再画因果图了,此时可以直接利用决策表设计测试用例。

02、因果图法的测试用例

图3所示的是交通一卡通自动充值模拟系统,其需求描述如下。

(1) 系统只接收50元或100元纸币,一次充值只能使用一张纸币,一次充值金额只能为50元或100元。

(2) 若输入50元纸币,并选择充值50元,完成充值后退卡,提示充值成功。

(3) 若输入50元纸币,并选择充值100元,提示输入金额不足,并退回50元。

(4) 若输入100元纸币,并选择充值50元,完成充值后退卡,提示充值成功,找零50元。

(5) 若输入100元纸币,并选择充值100元,完成充值后退卡,提示充值成功。

(6) 若输入纸币在规定时间内不选择充值按钮,退回输入的纸币,并提示错误。

(7) 若选择充值按钮后不输入纸币,提示错误。

image.png


■ 图3 交通一卡通自动充值模拟系统

下面给出交通一卡通自动充值系统的测试用例设计过程。

1) 条件之间的制约及组合关系

根据上述描述,输入条件(原因)如下。

(1) 投币50元(1)。

(2) 投币100元(2)。

(3) 选择充值50元(3)。

(4) 选择充值100元(4)。

输出(结果)如下。

(1) 完成充值、退卡(a)。

(2) 提示充值成功(b)。

(3) 找零(c)。

(4) 提示错误(d)。

2) 明确所有条件之间的制约关系及组合关系

条件之间的制约关系及组合关系如图4所示。

640.png


■ 图4 条件之间的约束关系

3) 画出因果图

为了描述得更清楚,这里将每种情况单独画一个因果图说明。

(1) 条件1和条件3可以组合,输出a和b的组合,也就是投币50元,充值50元,会输出完成充值、退卡,提示充值成功的结果。其因果图如图5所示。

640.png


■ 图6 条件1和条件3的组合

(2) 条件1和条件4可以组合,输出c和d的组合,也就是投币50元,充值100元,会输出找零、提示错误的结果。其因果关系如图7所示。

640.png


■ 图7 条件1和条件4的组合

(3) 条件2和条件3可以组合,输出a、b、c的组合,也就是投币100元,充值50元,会输出找零、完成充值、提示充值成功的结果。其因果图如图8所示。

640.png


■ 图9 条件2和条件3的组合

(4) 条件2和条件4可以组合,输出a和b的组合,也就是投币100元,充值100元,会输出完成充值、退卡,提示充值成功的结果。其因果图如图10所示。

640.png


■ 图10 条件2和条件4的组合

(5) 条件1、2、3、4均可以单独出现,其因果图如图11所示。

640.png


■ 图11 各条件单独出现

4) 根据因果图写出决策表

根据上面的因果图,写出对应的决策表,如表1所示。

■ 表1 决策表


640.png


5) 根据决策表写出测试用例

根据上面的决策表,写出对应的测试用例,如表2所示。

■ 表2 交通一卡通自动充值模拟系统测试用例


640.png

目录
相关文章
|
2月前
|
测试技术 API 项目管理
API测试方法
【10月更文挑战第18天】API测试方法
46 1
|
2月前
|
测试技术 UED
软件测试中的“灰盒”方法:一种平衡透明度与效率的策略
在软件开发的复杂世界中,确保产品质量和用户体验至关重要。本文将探讨一种被称为“灰盒测试”的方法,它结合了白盒和黑盒测试的优点,旨在提高测试效率同时保持一定程度的透明度。我们将通过具体案例分析,展示灰盒测试如何在实际工作中发挥作用,并讨论其对现代软件开发流程的影响。
|
24天前
|
Java 测试技术 Maven
Java一分钟之-PowerMock:静态方法与私有方法测试
通过本文的详细介绍,您可以使用PowerMock轻松地测试Java代码中的静态方法和私有方法。PowerMock通过扩展Mockito,提供了强大的功能,帮助开发者在复杂的测试场景中保持高效和准确的单元测试。希望本文对您的Java单元测试有所帮助。
64 2
|
2月前
|
测试技术 Python
自动化测试项目学习笔记(三):Unittest加载测试用例的四种方法
本文介绍了使用Python的unittest框架来加载测试用例的四种方法,包括通过测试用例类、模块、路径和逐条加载测试用例。
66 0
自动化测试项目学习笔记(三):Unittest加载测试用例的四种方法
|
2月前
|
测试技术 Python
自动化测试项目学习笔记(二):学习各种setup、tearDown、断言方法
本文主要介绍了自动化测试中setup、teardown、断言方法的使用,以及unittest框架中setUp、tearDown、setUpClass和tearDownClass的区别和应用。
65 0
自动化测试项目学习笔记(二):学习各种setup、tearDown、断言方法
|
2月前
|
安全 测试技术 API
一图看懂API测试9种方法
一图看懂API测试九种方法:冒烟测试验证基本功能,功能测试确保符合规格,集成测试检查组件协同工作,回归测试防止新变更引入问题,负载测试评估性能稳定性,压力测试挑战极限负载,安全测试发现并修复漏洞,用户界面测试确保UI与API协调,模糊测试提升异常数据处理鲁棒性。
|
2月前
|
测试技术 UED
软件测试中的探索性测试:一种创新的质量保证方法
在软件开发的生命周期中,测试阶段扮演着至关重要的角色。传统的软件测试方法,如自动化测试和回归测试,虽然在一定程度上保证了软件质量,但它们往往依赖于预定义的测试用例和脚本,可能无法覆盖所有用户场景和边缘情况。为了克服这些限制,探索性测试作为一种创新的质量保证方法应运而生。本文将深入探讨探索性测试的概念、优势以及如何有效地实施它,以帮助读者更好地理解和应用这种测试技术。
|
16天前
|
JSON Java 测试技术
SpringCloud2023实战之接口服务测试工具SpringBootTest
SpringBootTest同时集成了JUnit Jupiter、AssertJ、Hamcrest测试辅助库,使得更容易编写但愿测试代码。
50 3
|
2月前
|
JSON 算法 数据可视化
测试专项笔记(一): 通过算法能力接口返回的检测结果完成相关指标的计算(目标检测)
这篇文章是关于如何通过算法接口返回的目标检测结果来计算性能指标的笔记。它涵盖了任务描述、指标分析(包括TP、FP、FN、TN、精准率和召回率),接口处理,数据集处理,以及如何使用实用工具进行文件操作和数据可视化。文章还提供了一些Python代码示例,用于处理图像文件、转换数据格式以及计算目标检测的性能指标。
67 0
测试专项笔记(一): 通过算法能力接口返回的检测结果完成相关指标的计算(目标检测)
|
3月前
|
移动开发 JSON Java
Jmeter实现WebSocket协议的接口测试方法
WebSocket协议是HTML5的一种新协议,实现了浏览器与服务器之间的全双工通信。通过简单的握手动作,双方可直接传输数据。其优势包括极小的头部开销和服务器推送功能。使用JMeter进行WebSocket接口和性能测试时,需安装特定插件并配置相关参数,如服务器地址、端口号等,还可通过CSV文件实现参数化,以满足不同测试需求。
250 7
Jmeter实现WebSocket协议的接口测试方法

热门文章

最新文章

下一篇
无影云桌面