商品各个状态间的转换,也有起始状态和终止状态,不同于序列状态,几乎每个状态都和多个状态存在在转换关系,且状态之间的转换是相互的,犹如蜘蛛网一样,面对这种网状的状态图,测试的时候需要特别注意状态之间不允许发生的转换是否存在。
从两个实例,根据状态图,我们可以看到我们需要关注的内容:
状态:状态图中的每一个状态,都必须进行测试,校验该状态下,向其他状态的转换是否如状态图中展示的一致。
状态之间允许的转换:可能是如下情况,相同数据,不同操作引起不同转换;不同数据(前置条件不一样),相同操作引起的不同转换;不同数据,不同操作引起的不同转换。对每一个允许的状态转换进行验证,设置状态转换的前置条件,操作使状态发生转换的功能,验证操作是否正常、状态是否如预期变化。对使用频率特别高、或者特别容易出错的转换、以及最不常使用的转换,需要构造更多的测试数据,做尽可能多的覆盖。
状态之间不允许的转换:状态之间不允许的转换测试,关注系统返回的错误信息和状态值是否变更,不需要对所有的不可能进行验证,应该挑选那些特别容易发生的转换进行测试。
状态转换的角色权限:状态之间的转换操作,是有用户角色要求的,我们不仅要验证有权限的角色能够正常操作,还需要验证没有权限的角色是否能操作,对于没有权限的角色验证,在不可能全部验证的情况下,也是挑选相对容易出错的操作进行。
状态的转换,在软件中是非常普遍的,通过状态图梳理各个状态转换的关系,并在状态图的基础上按照状态和状态转换的覆盖原则进行测试设计,可以有效的保证软件状态转换的正确性。测试过程中,还可以进行随机的状态转换测试。
文章来源于领测软件测试网 https://www.ltesting.net/