前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >接口测试平台番外:正交工具过滤功能-4

接口测试平台番外:正交工具过滤功能-4

作者头像
我去热饭
发布2022-05-19 15:03:07
2040
发布2022-05-19 15:03:07
举报
文章被收录于专栏:测试开发干货

本节继续来研究这个正交过滤功能。

目前测试用的用例如下:

代码当前如下:

现在我们面临着俩个步骤,如上图注释所示。

我们先来来搞定 查看是否存在res这步吧~

最后一行输出,就是无辜组合,他们去依次和res中的比对,看看是否已经出现过~

如图,经过一个遍历后,我们对w 进行判断是否存在res,若存在则break掉。不存在就代表能平安的遍历完res,这样就可以在else中继续走下去。

针对这种复杂的设计算法,我们不要着急一次性全写完再检查,那样出了问题很难发现是哪问题。所以我们先打印了下w,看看还剩下哪些:

然后我们继续,想办法给它增加被删掉的那个输入条件 的另一种子状态。

不过我们现在面临了一个新的问题,就是 只看子状态,想知道被删掉的那个输入条件的全部子状态 需要折腾一下了....

这里我们可以遍历原始的输入条件/子状态 数据。来找到 这些无辜组合缺失的那个输入条件:

如上图,我用了列表的交集 是否为空集合,来判断出了那个缺失的输入条件并打印:

当然,这里我们只能再次进行组合成 几组新组合,然后再去判断是否中标,但是一旦判断没有中标,则立即 加入到res中,并且这个无辜组合就中止了,然后下一个无辜组合....

如上图,我们先打印 可能的新组合:

如下:

然后我们 对这些新组合 进行判断,看看是否中过滤规则~

这里我们再次发现了一个恐怖的事实!!!

就是 有的无辜组合 生成的所有新组合,都中了过滤规则!!!

也就是说,用户虽然只说这俩种子状态不难组合,但是很可能无形中让一个无辜组合永远都无法匹配到一起! 比如第二组无辜组合!

虽然 用户没有说 子二 和 子A 要过滤, 但是添加子1,那么就会中第一条过滤规则,添加子2 ,又会中第二条过滤组合!所以这个无辜组合真的是含恨而终了要~ 我们再次给这种组合起个名字。叫 被动过滤组合~ 我们可以记录下来,把这种组合 反馈给使用者,让使用者决定是否删减 过滤规则~

代码中我们,继续写,接下来就简单了。没有中过滤规则的组合 我们塞回到res中,中了的扔掉不管,这种被动过滤组合 我们一样收集起来给使用者。

代码如上: 整个过程 比较绕,复杂度也很高~ 以后有时间我再继续优化吧~

打印了下最终res 和 被动过滤的无辜组合:

可以看到,新的res 是4组用例,被动过滤的有一组。

我们最后就是把这些都反馈给用户~

这里我们要修个小bug,就是当过滤条件为空的时候,报错的问题:

如果为空,那么过滤规则用 - 来分割后,提取[1] 就会报下标越界错误,我们捕获到,就证明这次并没有过滤规则。那么就直接给res添加i 然后break掉即可。所以的filter也是空的,所以后面的所有过滤相关的遍历都不会执行~

到此,我们后端的代码算是完成了。复制版本如下:

代码语言:javascript
复制

# 正交工具运行
def zhengjiao_play(request):
    end_values = request.GET['end_values'].split(',')

    filter_input = request.GET['filter_input'] #提取出过滤规则
    filter_input = filter_input.replace(',',',').replace(' ','').replace('\n','') #进行修正

    new_values = [ i.split('/') for i in end_values ]
    res = []
    filter = []
    for i in AllPairs(new_values):
        # 判断是否中了过滤规则
        for f in filter_input.split(','):#遍历过滤规则
            left = f.split('-')[0]
            try:
                right = f.split('-')[1]
            except:
                res.append(i)
                break
            if left in i and right in i:
                filter.append({"case":i,"filter":[left,right]})
                break
        else:
            res.append(i)
    # print('res:',res)
    # print('filter:',filter)

    wugu = [] #声明无辜组合列表
    #开始对filter,整理出无辜组合
    for d in filter: #d此时是个字典
        case = d['case']
        f_case = d['filter']
        cha = list(set(case).difference(set(f_case))) #求出剩余的其他子状态的列表
        for f_c in f_case: # 遍历f_case,拆开中规则的俩个子状态,分别和其他子状态 组合成新的列表,视为无辜组合
            tmp = cha+[f_c]
            wugu.append(tmp)

    # print('wugo: ',wugu)
    bdgl = []
    for w in wugu:
        # 看看无辜组合是否已经存在于res中
        for i in res:
            if set(w).issubset(set(i)) : #判断w是否是i的子列表
                break
        else: #只有当正常结束才会运行,正常结束代表未存在res,可以继续往后走。
            # 用一个新的非中过滤规则的子状态填充,形成完整的组合
            # print('-----------------')
            # print(w) #此时的w 是要添加新的子状态 组成完整组合的~
            which = [v for v in new_values if set(v).intersection(set(w)) == set()][0]  # 用交集函数 确认那个需要增加的输入条件:
            # print(which)
            for whi in which:
                new_zuhe = w + [whi] #变成新组合
                # print('新组合:',new_zuhe)
                # 判断是否中了过滤规则
                for f in filter_input.split(','):  # 遍历过滤规则
                    left = f.split('-')[0]
                    right = f.split('-')[1]
                    if left in new_zuhe and right in new_zuhe: #说明中标
                        # print('中了,则该组合不行,看下一个组合吧~')
                        break
                else: #说明新组合没中过滤
                    # print('全程没中过滤,很nice')
                    res.append(new_zuhe)
                    break
                # 中了过滤 走这里,所以要换下一个新组合
                continue
            else: # 说明是没有break出来的,被动过滤组合,给bdgl组合列表送去把
                bdgl.append(w)
            # break出来的,说明找到了有效组合,所以这个无辜组合已经可以了,赶紧搞下一个无辜组合把~



    d = { "res" : res,"bdgl":bdgl}
    return HttpResponse(json.dumps(d),content_type="application/json")

然后我们回到前端:

可以看到,目前我们res的最终有效组合仍然 正常显示,我们唯一要做的就是把这个被动过滤的无辜组合 给用户显示出来,让用户自行裁决,心里有数。

页面dom上呢,我们再弄个存放bdgl的span标签吧:

在最下方添加了一个span,id就叫bdgl,颜色暗红

然后找到下面js函数中,运行的函数,给它返回值处理部分,插入一段显示bdgl的代码:

重启服务,刷新页面 ,让我们看看最终效果:

这里我们发现了俩个问题。 一大一小

大bug: 条件1 居然和 子二 写一起了。这个bug的引起原因就是我们在之前的各种删中标 又 加新条件的过程中, 丢失了他们原来的顺序。然后前端盲目的匹配导致了这个问题。

小bug:过滤无辜组合,没有外边界,这样如果 有俩组, 就会变成 :

子二,子A,子1,子B

我们没法区分这是 几组~ 。

下一节,我们会来修复这俩个bug

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2021-05-14,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 测试开发干货 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档