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


猜你喜欢
- 今天看到everything搜索速度秒杀windows自带的文件管理器,所以特地模仿everything实现了文件搜索以及打开对应文件的功能
- 介绍shutil 名字来源于 shell utilities,有学习或了解过Linux的人应该都对 shell 不陌生,可以借此来记忆模块的
- 前 言:作为当前先进的深度学习目标检测算法YOLOv5,已经集合了大量的trick,但是在处理一些复杂背景问题的时候,还是容易出现错漏检的问
- 当设计一个产品,其中很多地方要把日期类型保存到数据库中,如果产品有兼容不同数据库产品的需求,那么,应当怎样设计呢?当然,首先想到的是,使用数
- 今天闲着没事干,以前做过html+js版的数独,这次做个python版本的,界面由pygame完成,数独生成由递归算法实现,由shuffle
- 好了,下面我们看看如何在服务器上生成.m3u文件并下传到客户端的:<%dim choose,path,mydb,myset,
- 默认级别:warningimport logginglogging.debug('debug message')loggin
- 本次案例使用OpenCV和selenium来解决一下滑块验证码先说一下思路:弹出滑块验证码后使用selenium元素截图将验证码整个背景图截
- 源码:#路飞骷髅import turtle as t#黄底帽子t.pu()t.goto(0,200)t.circle(-130,-80)t.
- 目录图像边框的实现图像边框设计的主要函数图像混合的实现图像混合实现的主要函数主要思路图像边框的实现图像边框设计的主要函数cv.copyMak
- 编写程序,完成“名片管理器”项目需要完成的基本功能:添加名片删除名片修改名片查询名片退出系统程序运行后,除非选择退出系统,否则重复执行功能m
- 这是一个小技巧,看着.ejs的后缀总觉得不爽,使用如下方法,可以将模板文件的后缀换成我们习惯的.html。1.在app.js的头上定义ejs
- 上节我们了解了图形验证码的识别,简单的图形验证码我们可以直接利用 Tesserocr 来识别,但是近几年又出现了一些新型验证码,如滑动验证码
- js代码:window.alert = function(msg, callback) {var div = document.create
- 搭建FTP,或者是搭建网络文件系统,这些方法都能够实现Linux的目录共享。但是FTP和网络文件系统的功能都过于强大,因此它们都有一些不够方
- 本文实例讲述了Python简单遍历字典及删除元素的方法。分享给大家供大家参考,具体如下:这种方式是一定有问题的:d = {'a
- 直接pip install impala 是不行滴,按照以下步骤安装就会成功!一路安装就可以1、pip install six2、pip i
- 一、location 对象是什么?window 对象给我们提供了一个 location 属性用于获取或设置窗体的 URL,并且可以用于解析
- 本文实例讲述了Python统计文件中去重后uuid个数的方法。分享给大家供大家参考。具体如下:利用正则表达式按行获取日志文件中的的uuid,
- 在日常的编程中,我经常需要标识存在于文本文档中的部件和结构,这些文档包括:日志文件、配置文件、定界的数据以及格式更自由的(但还是