這篇“python全對偶組合與全覆蓋組合比較實例分析”文章的知識點大部分人都不太理解,所以小編給大家總結了以下內容,內容詳細,步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“python全對偶組合與全覆蓋組合比較實例分析”文章吧。
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_listcase_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條

以上就是關于“python全對偶組合與全覆蓋組合比較實例分析”這篇文章的內容,相信大家都有了一定的了解,希望小編分享的內容對大家有幫助,若想了解更多相關的知識內容,請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。