问小白 wenxiaobai
资讯
历史
科技
环境与自然
成长
游戏
财经
文学与艺术
美食
健康
家居
文化
情感
汽车
三农
军事
旅行
运动
教育
生活
星座命理

因果图在软件测试中的应用:从基本概念到实战案例

创作时间:
作者:
@小白创作中心

因果图在软件测试中的应用:从基本概念到实战案例

引用
1
来源
1.
https://www.cnblogs.com/junting/p/18728936

因果图是一种将软件需求规格说明书中的输入条件组合与输出动作关联起来的图形化工具,主要用于设计测试用例。它通过分析输入条件之间的逻辑关系,帮助测试人员生成全面且有效的测试数据。本文将详细介绍因果图的基本概念、绘制步骤、约束条件以及实际应用案例。

因果图的基本概念

(1)定义:因果图提供了一个把规格转化为判定表的系统化方法,从该图中可以产生测试数据。其中,原因是表示输入条件,结果是对输入执行的一系列计算后得到的输出。

(2)作用:因果图方法最终生成的就是判定表。它适合于检查软件输入条件的各种组合情况。

因果图中的基本关系

在因果图的基本符号中,图中的左结点ci 表示输入状态(或称原因),右结点ei表示输出 状态(或称结果)。ci与ei取值0或1,0表示某状态不出现,1则表示某状态出现。

  • 恒等:若 c1 是1,则 e1 也为1,否则 e1 为0。 案例1:有钱------富豪
  • 非:若 c1 是1,则 e1 为0,否则e1为1。 案例2:有钱------穷人
  • 或V:若 c1 或 c2 或 c3 是1,则 e1 为1,否则 e1 为0。 案例3: 有车、 有房、有存款------满足一个是有钱人
  • **与A:若 c1 c2和 c3 都是1,则e1为1,否则 e1 为0。案例4: 有车、 有房、有存款------满足三个是有钱人

因果图中的约束

在实际问题中输入状态相互之间、输出状态相互之间可能存在某些依赖关系,称为“约 束”。对于输入条件的约束有E、I、O、R四种约束,对于输出条件的约束只有M约束。

  • E约束(异):a和b中最多有一个可能为1,即a和b不能同时为1。
  • I约束(或):a、b、c中至少有一个必须为1,即 a、b、 c不能同时为0。
  • O约束(唯一):a和b必须有一个且仅有一个为1。
  • R约束(要求):a是1时,b必须是1;即a为1时,b不能为0。
  • M约束(强制):若结果a为1,则结果b强制为0。

因果图的绘制步骤

  1. 把大的系统规格划分解成可以测试的规格片段
  2. 分析分解后待测的系统规格,找出哪些是原因,哪些是结果
  3. 画出因果图
  4. 把因果图转换成判定表
  5. 简化判定表
  6. 用判定表中的每一列生成测试用例

因果图的优点与缺点

优点:

  1. 等价类法尽管各个输入条件可能出错的情况都考虑到了,但是多个输入条件组合起来出错的情况却被忽略了
  2. 因果图法能够帮助我们按照一定步骤,高效的选择测试用例,设计多个输入条件组合用例
  3. 因果图分析还能为我们指出,程序规格说明描述中存在什么问题

缺点:

  1. 输入条件与输出结果的因果关系,有时难以从软件需求规格说明书得到
  2. 即使得到了这些因果关系,也会因为因果关系复杂 导致因果图非常庞大,测试用例数目及其庞大

应用案例

自动售货机案例

一个处理单价为5角钱的饮料的自动售货机。其规格说明如下:

  • 若投入5角钱或1元钱的硬币,押下〖橙汁〗或〖啤酒〗的按钮,则相应的饮料就送出来。
  • 若售货机没有零钱找,则一个显示〖零钱找完〗的红灯亮,这时在投入1元硬币并押下按钮后,饮料不送出来而且1元硬币也退出来;
  • 若有零钱找,则显示〖零钱找完〗的红灯灭,在送出饮料的同时退还5角硬币

因果图:

判定表转换方法

  1. 将因果图中的所有条件(因)填入判定表的条件桩中;
  2. 将因果图中的所有动作(果)填入判定表的动作桩中;
  3. 根据因果图确定各个条件组合对应的动作,并且确定判定表中各个规则的条件项和动作项,在需要时优化判定表。

文件修改案例

某软件规格说明书包含这样的要求:

  • 第一列字符必须是A或B
  • 第二列字符必须是一个数字
  • 在此情况下进行文件的修改
  • 但如果第一列字符不正确,则给出信息L
  • 如果第二列字符不是数字,则给出信息M

解答:

  • 原因: 1——第一列字符是A; 2——第一列字符是B; 3——第二列字符是一个数字。
  • 结果: 21——修改文件;22 ——给出信息L; 23——给出信息M。
  • 11为中间节点;考虑到原因1和原因2不可能同时为1,因此在因果图上施加E约束。

总结

因果图是对组合情况设计用例的重要工具,通过分析输入条件之间的逻辑关系,帮助测试人员生成全面且有效的测试数据。虽然在复杂场景下可能导致测试用例数量庞大,但其系统化的方法能够显著提高测试效率和覆盖率。

© 2023 北京元石科技有限公司 ◎ 京公网安备 11010802042949号