溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

python全對偶組合與全覆蓋組合比較實例分析

發(fā)布時間:2022-06-10 09:16:19 來源:億速云 閱讀:151 作者:zzz 欄目:開發(fā)技術(shù)

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

覆蓋測試

同樣 設(shè)定 范圍值,每一種參數(shù)有幾個取值范圍,進行覆蓋測試

1對偶算法覆蓋

2全覆蓋(笛卡爾積算法)

def get_data_list(_type, request_type=0):
    """
    0表示對偶算法;1表示全匹配組合
    返回參數(shù)的取值范圍
    """
    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:  # 數(shù)組集合
            v_list = get_data_list(_type[0])
            for case in v_list:
                new_list.append([case])
            new_list.append(v_list)  # 補全一下多個值的數(shù)組
        return new_list
def all_assemble(dic):
    """返回每個參數(shù)的取值范圍組成的二維數(shù)據(jù),用于求笛卡爾積"""
    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條

python全對偶組合與全覆蓋組合比較實例分析

全覆蓋生成用例1944條

python全對偶組合與全覆蓋組合比較實例分析

以上就是關(guān)于“python全對偶組合與全覆蓋組合比較實例分析”這篇文章的內(nèi)容,相信大家都有了一定的了解,希望小編分享的內(nèi)容對大家有幫助,若想了解更多相關(guān)的知識內(nèi)容,請關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI