接口测试平台番外:正交工具过滤功能-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

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

相关文章
|
5天前
|
人工智能 供应链 安全
AI辅助安全测试案例某电商-供应链平台平台安全漏洞
【11月更文挑战第13天】该案例介绍了一家电商供应链平台如何利用AI技术进行全面的安全测试,包括网络、应用和数据安全层面,发现了多个潜在漏洞,并采取了有效的修复措施,提升了平台的整体安全性。
|
10天前
|
安全 前端开发 测试技术
如何选择合适的自动化安全测试工具
选择合适的自动化安全测试工具需考虑多个因素,包括项目需求、测试目标、系统类型和技术栈,工具的功能特性、市场评价、成本和许可,以及集成性、误报率、社区支持、易用性和安全性。综合评估这些因素,可确保所选工具满足项目需求和团队能力。
|
8天前
|
监控 网络协议 Java
一些适合性能测试脚本编写和维护的工具
一些适合性能测试脚本编写和维护的工具
|
9天前
|
安全 网络协议 关系型数据库
最好用的17个渗透测试工具
渗透测试是安全人员为防止恶意黑客利用系统漏洞而进行的操作。本文介绍了17款业内常用的渗透测试工具,涵盖网络发现、无线评估、Web应用测试、SQL注入等多个领域,包括Nmap、Aircrack-ng、Burp Suite、OWASP ZAP等,既有免费开源工具,也有付费专业软件,适用于不同需求的安全专家。
13 2
|
11天前
|
JSON Java 测试技术
SpringCloud2023实战之接口服务测试工具SpringBootTest
SpringBootTest同时集成了JUnit Jupiter、AssertJ、Hamcrest测试辅助库,使得更容易编写但愿测试代码。
42 3
|
14天前
|
监控 安全 测试技术
构建高效的精准测试平台:设计与实现指南
在软件开发过程中,精准测试是确保产品质量和性能的关键环节。一个精准的测试平台能够自动化测试流程,提高测试效率,缩短测试周期,并提供准确的测试结果。本文将分享如何设计和实现一个精准测试平台,从需求分析到技术选型,再到具体的实现步骤。
65 1
|
14天前
|
监控 安全 测试技术
构建高效精准测试平台:设计与实现全攻略
在软件开发过程中,精准测试是确保产品质量的关键环节。一个高效、精准的测试平台能够自动化测试流程,提高测试覆盖率,缩短测试周期。本文将分享如何设计和实现一个精准测试平台,从需求分析到技术选型,再到具体的实现步骤。
40 0
|
1月前
|
JSON 算法 数据可视化
测试专项笔记(一): 通过算法能力接口返回的检测结果完成相关指标的计算(目标检测)
这篇文章是关于如何通过算法接口返回的目标检测结果来计算性能指标的笔记。它涵盖了任务描述、指标分析(包括TP、FP、FN、TN、精准率和召回率),接口处理,数据集处理,以及如何使用实用工具进行文件操作和数据可视化。文章还提供了一些Python代码示例,用于处理图像文件、转换数据格式以及计算目标检测的性能指标。
63 0
测试专项笔记(一): 通过算法能力接口返回的检测结果完成相关指标的计算(目标检测)
|
2月前
|
移动开发 JSON Java
Jmeter实现WebSocket协议的接口测试方法
WebSocket协议是HTML5的一种新协议,实现了浏览器与服务器之间的全双工通信。通过简单的握手动作,双方可直接传输数据。其优势包括极小的头部开销和服务器推送功能。使用JMeter进行WebSocket接口和性能测试时,需安装特定插件并配置相关参数,如服务器地址、端口号等,还可通过CSV文件实现参数化,以满足不同测试需求。
245 7
Jmeter实现WebSocket协议的接口测试方法
|
2月前
|
JSON 移动开发 监控
快速上手|HTTP 接口功能自动化测试
HTTP接口功能测试对于确保Web应用和H5应用的数据正确性至关重要。这类测试主要针对后台HTTP接口,通过构造不同参数输入值并获取JSON格式的输出结果来进行验证。HTTP协议基于TCP连接,包括请求与响应模式。请求由请求行、消息报头和请求正文组成,响应则包含状态行、消息报头及响应正文。常用的请求方法有GET、POST等,而响应状态码如2xx代表成功。测试过程使用Python语言和pycurl模块调用接口,并通过断言机制比对实际与预期结果,确保功能正确性。
253 3
快速上手|HTTP 接口功能自动化测试
下一篇
无影云桌面