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

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

 本节继续来研究这个正交过滤功能。目前测试用的用例如下:

微信图片_20220707085608.png

代码当前如下:

微信图片_20220707085621.png

现在我们面临着俩个步骤,如上图注释所示。我们先来来搞定 查看是否存在res这步吧~

微信图片_20220707085647.png

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

微信图片_20220707085656.png

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


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

微信图片_20220707085702.png

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

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


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

微信图片_20220707085708.png

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

微信图片_20220707085714.png

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

微信图片_20220707085722.png

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

如下:

微信图片_20220707085729.png

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

微信图片_20220707085736.png微信图片_20220707085743.png

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


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

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

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


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

微信图片_20220707085750.png

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


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

微信图片_20220707085756.png

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


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

微信图片_20220707085803.png


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

微信图片_20220707085810.png

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


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

# 正交工具运行
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")

然后我们回到前端:

微信图片_20220707085817.png

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


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

微信图片_20220707085824.png

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


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

微信图片_20220707085835.png

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

微信图片_20220707085843.png

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


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


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

子二,子A,子1,子B

我们没法区分这是 几组~ 。 这里我们发现了俩个问题。 一大一小


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


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

子二,子A,子1,子B

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

相关文章
|
26天前
|
Java 测试技术 数据安全/隐私保护
软件测试中的自动化策略与工具应用
在软件开发的快速迭代中,自动化测试以其高效、稳定的特点成为了质量保证的重要手段。本文将深入探讨自动化测试的核心概念、常见工具的应用,以及如何设计有效的自动化测试策略,旨在为读者提供一套完整的自动化测试解决方案,帮助团队提升测试效率和软件质量。
|
18天前
|
Web App开发 IDE 测试技术
Selenium:强大的 Web 自动化测试工具
Selenium 是一款强大的 Web 自动化测试工具,包括 Selenium IDE、WebDriver 和 Grid 三大组件,支持多种编程语言和跨平台操作。它能有效提高测试效率,解决跨浏览器兼容性问题,进行性能测试和数据驱动测试,尽管存在学习曲线较陡、不稳定等缺点,但其优势明显,是自动化测试领域的首选工具。
122 17
Selenium:强大的 Web 自动化测试工具
|
28天前
|
机器学习/深度学习 人工智能 算法
BALROG:基准测试工具,用于评估 LLMs 和 VLMs 在复杂动态环境中的推理能力
BALROG 是一款用于评估大型语言模型(LLMs)和视觉语言模型(VLMs)在复杂动态环境中推理能力的基准测试工具。它通过一系列挑战性的游戏环境,如 NetHack,测试模型的规划、空间推理和探索能力。BALROG 提供了一个开放且细粒度的评估框架,推动了自主代理研究的进展。
42 3
BALROG:基准测试工具,用于评估 LLMs 和 VLMs 在复杂动态环境中的推理能力
|
1月前
|
监控 测试技术 开发工具
移动端性能测试工具
移动端性能测试工具
51 2
|
10天前
|
监控 JavaScript 测试技术
postman接口测试工具详解
Postman是一个功能强大且易于使用的API测试工具。通过详细的介绍和实际示例,本文展示了Postman在API测试中的各种应用。无论是简单的请求发送,还是复杂的自动化测试和持续集成,Postman都提供了丰富的功能来满足用户的需求。希望本文能帮助您更好地理解和使用Postman,提高API测试的效率和质量。
53 11
|
1月前
|
JSON Java 测试技术
SpringCloud2023实战之接口服务测试工具SpringBootTest
SpringBootTest同时集成了JUnit Jupiter、AssertJ、Hamcrest测试辅助库,使得更容易编写但愿测试代码。
65 3
|
2月前
|
JSON 算法 数据可视化
测试专项笔记(一): 通过算法能力接口返回的检测结果完成相关指标的计算(目标检测)
这篇文章是关于如何通过算法接口返回的目标检测结果来计算性能指标的笔记。它涵盖了任务描述、指标分析(包括TP、FP、FN、TN、精准率和召回率),接口处理,数据集处理,以及如何使用实用工具进行文件操作和数据可视化。文章还提供了一些Python代码示例,用于处理图像文件、转换数据格式以及计算目标检测的性能指标。
80 0
测试专项笔记(一): 通过算法能力接口返回的检测结果完成相关指标的计算(目标检测)
|
3月前
|
移动开发 JSON Java
Jmeter实现WebSocket协议的接口测试方法
WebSocket协议是HTML5的一种新协议,实现了浏览器与服务器之间的全双工通信。通过简单的握手动作,双方可直接传输数据。其优势包括极小的头部开销和服务器推送功能。使用JMeter进行WebSocket接口和性能测试时,需安装特定插件并配置相关参数,如服务器地址、端口号等,还可通过CSV文件实现参数化,以满足不同测试需求。
270 7
Jmeter实现WebSocket协议的接口测试方法
|
3月前
|
JSON 移动开发 监控
快速上手|HTTP 接口功能自动化测试
HTTP接口功能测试对于确保Web应用和H5应用的数据正确性至关重要。这类测试主要针对后台HTTP接口,通过构造不同参数输入值并获取JSON格式的输出结果来进行验证。HTTP协议基于TCP连接,包括请求与响应模式。请求由请求行、消息报头和请求正文组成,响应则包含状态行、消息报头及响应正文。常用的请求方法有GET、POST等,而响应状态码如2xx代表成功。测试过程使用Python语言和pycurl模块调用接口,并通过断言机制比对实际与预期结果,确保功能正确性。
287 3
快速上手|HTTP 接口功能自动化测试
|
3月前
|
JavaScript 前端开发 测试技术
ChatGPT与接口测试
ChatGPT与接口测试,测试通过
58 5