python自动化测试用例全对偶组合与全覆盖组合比较
作者:二到不知处 发布时间:2021-02-03 01:59:45
标签:python,全对偶组合,全覆盖组合,自动化测试
python3用到2个库
import itertools
import metacomm.combinatorics.all_pairs2 as all_pairs
all_pairs 这个库适用于python2.7 安装好 里面有语法需要更新才能在python3中用
test = """{
"a": [{"a": "string"}],
"b": ["string"],
"c": "string",
"d": "bool",
"e": "int",
"f": {"ff": "string", "gg": "int"}
}"""
覆盖测试
同样 设定 范围值,每一种参数有几个取值范围,进行覆盖测试
1对偶算法覆盖
2全覆盖(笛卡尔积算法)
def get_data_list(_type, request_type=0):
"""
0表示对偶算法;1表示全匹配组合
返回参数的取值范围
"""
if _type == 'string':
return ["", None, "abc123"]
elif _type == 'time':
return ["1900-01-01", time.strftime("%Y-%m-%d %H:%M:%S", time.localtime())]
elif _type == 'int':
return [-1, 0, 1]
elif _type == 'decimal':
return [-0.50, 0.0, 0.50]
elif _type == 'bool':
return [True, False]
elif isinstance(_type, dict):
if request_type == 0:
return dual_test_case(_type)
elif request_type == 1:
return itertools_case_list(_type)
elif isinstance(_type, list):
new_list = []
c_list = []
if isinstance(_type[0], dict): # 字典集合,递归取得自己的取值范围
if request_type == 0:
c_list = dual_test_case(_type[0]) # 对偶算法
elif request_type == 1:
c_list = itertools_case_list(_type[0]) # 全匹配算法
for case in c_list:
new_list.append([case])
else: # 数组集合
v_list = get_data_list(_type[0])
for case in v_list:
new_list.append([case])
new_list.append(v_list) # 补全一下多个值的数组
return new_list
def all_assemble(dic):
"""返回每个参数的取值范围组成的二维数据,用于求笛卡尔积"""
return_list = []
for k, v in dic.items():
k_list = []
for _value in get_data_list(v, 1):
di = {}
di[k] = _value
k_list.append(di)
return_list.append(k_list)
return return_list
def itertools_case_list(dic):
"""笛卡尔积"""
_list = all_assemble(dic)
case_list = []
for item in itertools.product(*_list):
d3 = {}
for di in item:
d3.update(di)
case_list.append(d3)
return case_list
def dual_test_case(_base):
"""对偶生成测试用例"""
if not isinstance(_base, dict):
return []
key_list = list()
value_list = list()
case_list = list()
for k, v in _base.items():
key_list.append(k)
value_list.append(get_data_list(v))
# print(key_list, value_list)
if value_list.__len__() >= 2:
res = all_pairs.all_pairs2(value_list)
for i, b in enumerate(res):
# print i, b
dic = dict()
for n in range(b.__len__()):
dic[key_list[n]] = b[n]
case_list.append(dic)
else:
for v in value_list[0]:
dic = dict()
dic[key_list[0]] = v
case_list.append(dic)
return case_list
测试生成
case_list1 = dual_test_case(json.loads(test))
print(case_list1.__len__())
for case in case_list1:
print(str(json.dumps(case)))
case_list2 = itertools_case_list(json.loads(test))
print(case_list2.__len__())
for case in case_list2:
print(str(json.dumps(case)))
对偶算法生成用例39条
全覆盖生成用例1944条
来源:https://www.cnblogs.com/twofool/p/10396817.html
0
投稿
猜你喜欢
- 本文的asp xmlhttp类,使用asp的MSXML2.ServerXMLHTTP组件来获取远程音乐文件。类定义 Cls_AspHttp.
- 通过Python中的matplotlib绘制百分比堆叠柱状图,并为每一个类别设置不同的填充图案。主要原因是有些论文打印出是黑白色的,不同类别
- 操作系统会为每一个创建的进程分配一个独立的地址空间,不同进程的地址空间是完全隔离的,因此如果不加其他的措施,他们完全感觉不到彼此的存在。那么
- 在一个页面制作过程,突然被设计稿上的一个问题难住了,思路一时没打开,后来在费人的提醒下,用定位控制,顺利完成。这个是我做的大概的
- 你的设计为什么平平无奇,为什么吸引不到别人的眼球,这里先来说说什么是焦点(也可以称兴趣中心或者视觉中心),我认为用焦点更能简单准确的阐述。有
- 这是解释器设置问题,在设置里找到interpreter 找到合适的目录就可以了。因为重装了python导致pycharm找不到路径了。另外,
- 一直在期待这本书,一直希望国内能有一本正视WEB标准,并且全面阐述WEB标准书籍。而这本书是我觉得国内最全面的一本关于WEB标准的书籍,这本
- 刚开始学习Python的类写法的时候觉得很是麻烦,为什么定义时需要而调用时又不需要,为什么不能内部简化从而减少我们敲击键盘的次数?你看完这篇
- Django中内置了邮件发送功能,被定义在django.core.mail模块中。发送邮件需要使用SMTP服务器,常用的免费服务器有:163
- 1 配置 Python3 环境单击 工具 > 编译系统 > 新建编译系统...弹出:替换里面的内容为:{ &nbs
- 一、前言关于什么是Dapper(详细入口),在此不做赘述;本文仅对Dapper在.Net Core中的使用作扼要说明,所陈代码以示例讲解为主
- 当你连接到MySQL服务器时,你应使用一个密码。密码不以明文在上传输。客户端连接序列中的密码处理在MySQL 4.1.1中已经升级,很安全。
- 6、遮罩滤镜作用:该滤镜可以为对象建立一个覆盖于表面的膜,其效果就象戴着有色眼镜看物体一样。语法: {filter:mask(color=c
- 代码如下:--销售冠军 --问题:在公司中,老板走进来,要一张每个地区销量前3名的销售额与销售员的报表 --- create t
- 如何定义记录集打开的游标类型和锁定类型?我们知道,打开记录集时,可以定义记录集打开的游标类型和锁定类型。在adovbs.inc文件中就定义了
- The test clienttest client是一个python类,来模拟一个简单的“哑”浏览器,允许你来测试你的view函数.你可以
- 前言优雅关机就是服务端关机命令发出后不是立即关机,而是等待当前还在处理的请求全部处理完毕后再退出程序,是一种对客户端友好的关机方式。而执行C
- 在数据库testDB中存在架构A及用户A,现将testDB数据库所属的用户由A改为B,同时删除用户A;架构也由A改为B,删除架构A,操作如下
- 具体用法:1、<%= Counters.Get(CounterName) %>显示计数器的值。2、<% counterva
- QQ通过返回不同的图片,来表示在线或离线,图标也随之变换,既然图片不同,那么,返回的HTTP头信息中的Content-Length 也一定不