测试用例编写完之后,我们在测试过程中往往会发现,有一些用例其实是重复的,造成很多重复工作,那么我们应当如何去除这些重复用例呢?
尤其使用等价类划分和边界值分析编写用例时,很容易造成用例重复。
举例
下面我们通过一个例子来具体分析一下。
首先选择一个场景,后台维护前台账号,主要有以下几个字段(字段太多,这里只列举三个字段进行分析)。
账号:4~8位字母和数字组合
密码:8~16位字母数字组合
姓名:字母、数字、特殊字符和汉字组合,长度4~20
下面我们对他们的等价类和边界值进行分析。
账号
有效等价类:6位数字和字母组合,5位纯数字组合,7位纯字母组合。
无效等价类:3位字符,9位字符,汉字,空。
边界值:4位字符,8位字符。
密码
有效等价类:9位数字和字母组合,10位纯数字组合,11位纯字母组合。
无效等价类:7位字符,17位字符,汉字,空。
边界值:8位字符,16位字符。
姓名
有效等价类:字母、数字特殊字符和汉字组合,长度10;纯字母,长度11;纯数字,长度12;纯特殊字符,长度13;纯汉字,长度14。
无效等价类:长度3,长度21,空。
边界值:长度4,长度10。
如果我们只是通过等价类划分边界值分析,我们可以来统计一下共有多少条用例——共28条。
但是测试的过程中我们就会发现,有好多重复的,比如说:我们先测试账号这个输入框,输入6位纯数字,然后其他两个输入框都需要输入有效等价类。
其实我们一条用例里,账号、密码和姓名是都覆盖了一条测试用例的,当再测试密码这个输入框时,这条用例是重复执行的,那么我们怎么去避免这种情况呢?
首先将所有的输入都列到一列,如下图:
我们用例组合的原则就是,一条用例里可以包含多条有效等价类,且必须都是有效等价类。
一条用例里只能包含一条无效等价类,且这条用例里的有效等价类不能作为验证条件,比如说:账号输入了汉字,密码和姓名都输入正确,这个时候提示了账号输入错误,这条用例是通过的,只能说明无效等价类的这个条件通过了,并不说明这条用例里的其他两个有效等价类是通过的。
所以验证有效等价类时,不能跟无效等价类一起验证。
接下来我们在上边的表格里标注一下哪些等价类可以组合到一起,数字相同的表示可在一条用例里覆盖。
我们可以发现,用例1、2、3、4、5都可以在一条用例里覆盖多条有效等价类,用例6和7是比其他两个输入框多出来的有效等价类。
因为其他两个输入框的有效等价类已经覆盖完了,那么执行这两条用例时,可以从其他两个输入框任意选取有效等价类来测试,用例8~18都是无效等价类,只能单独验证。
这样分析下来,用例只有18条,比起原先的28条少了10条,这样我们的用例才能更加精简,在保证用例全部覆盖的情况下避免了用例冗余。
作者:CICI
来源:http://www.51testing.com/html/59/n-4480259.html