软件测试-根据状态迁移图设计测试用例

测试用例状态迁移图

许多需求用状态机的方式来描述,状态机的测试主要关注状态转移是否正确。对于一个有限状态机,通过测试验证其在给定的条件内是否能够产生需要的状态变化,有没有不可达的状态和非法的状态,是否可能产生非法的状态转移等。通过构造能导致状态迁移的事件来测试状态之间的转换,多用于协议测试,使用这种方法可以设计逆向的测试用例,如状态和事件的非法组合。
状态迁移图测试用例设计方法的步骤如下:
(1)画出状态迁移图
(2)列出状态-事件表
(3)画出状态转换树,并从状态转换树推导出测试路径
(4)根据测试路径编写测试用例
【实例】使用状态迁移分析法分析从提交到解决整个过程中,Bug 状态变化的情况
软件测试-根据状态迁移图设计测试用例_第1张图片
列出状态-事件表
软件测试-根据状态迁移图设计测试用例_第2张图片
根据状态迁移图画状态转换树
软件测试-根据状态迁移图设计测试用例_第3张图片

根据状态转换树可以推导出以下路径:
路径1:初始化→打开→修改→回归→打开。
路径2:初始化→打开→修改→回归→关闭。
路径3:初始化→打开→CCB 评审→非问题。
路径4:初始化→打开→CCB 评审→修改→打开。
路径5:初始化→打开→CCB 评审→挂起→打开。
路径6:初始化→重复问题关闭。
路径7:初始化→非问题关闭。
步骤4:根据测试路径编写测试用例,以路径6 为例,设计的测试用例
软件测试-根据状态迁移图设计测试用例_第4张图片
软件测试-根据状态迁移图设计测试用例_第5张图片

2 状态机的覆盖目标

状态机有不同的覆盖目标,带来不同的用例生成复杂度。

(1)状态覆盖:状态机中的每个状态至少访问一次;状态覆盖是最基本的覆盖目标。

(2)迁移覆盖:状态机中的每个迁移至少触发一次;迁移覆盖包含状态覆盖,实现迁移覆盖则必然实现了状态覆盖。

(3)状态格局覆盖:状态机包含层次、并发结构,在状态机运行的某个时刻,可能有多个状态处于激活状态,它们构成一个状态格局(state configuration)。实现状态格局覆盖,意味着被测系统所有可能的状态组合被覆盖。实现状态格局覆盖,必然实现了状态覆盖。

(4)状态格局迁移覆盖:即状态格局之间所有迁移至少触发一次。

除上述状态机覆盖目标外,还可进一步对迁移守卫条件(guard)进行覆盖,包括对guard的判定覆盖、MC/DC覆盖等。???

你可能感兴趣的:(测试,功能测试)