接口测试平台番外:正交工具过滤功能-3 (难到爆炸)

简介: 接口测试平台番外:正交工具过滤功能-3 (难到爆炸)

 好的本节我们就来简单实现下这个过滤功能。

 一:前端弄个多行文本框,让用户输入过滤规则用。

微信图片_20220706210934.png

现在界面是这样的。虽然说不好看,但是我用渐变色给它美化一下


微信图片_20220706210942.png

就变成这样了

微信图片_20220706210954.png

蓝色和粉色,我称之为神仙颜色~  不信你自信回顾下各种游戏/手机壳等,蓝粉搭配,都是给光辉,神仙这种角色的光环或颜色。比如dnf的神话装备,云顶之弈的神王光环。


好了,结束这个小插曲,我们来做那个过滤窗口,这个功能

微信图片_20220706211000.png

注意我划红线的地方的修改。辛苦调好了宽度 和 排版,效果如下:微信图片_20220706211005.png

因为这个输入框多行的,也叫文本域。所以可以输入很多很多内容,虽然它是自动换行,但是用户依然有可能会主动换行,所以当我们的视图逻辑层也就是views_tools.py中的时候,需要对数据进行整理。也就是先替换掉这里面所有非法输入字符,如换行符,空格符等等。

好了我们找到 运行按钮对应的运行js函数:微信图片_20220706211011.png

如上图,给这个文本域的内容value 一起传给后端吧~

然后找到我们views_tools.py中的运行函数,给这个过滤规则先拿出来。

微信图片_20220706211018.png

搞定之后。我们就要等 最终结果出来,也就是这个res,我们先找个例子,输出一下这个res,看看是什么吧?微信图片_20220706211025.png

如图,我们设计了上面这个比较全面的用例,并增加了俩条过滤规则。输出了旧的res,发现是如下的二维列表:

微信图片_20220706211120.png

每个子列表也就是一个用例了。那么我们看这个代码:微信图片_20220706211126.png


我们原来的逻辑是,用res来接收所有i,现在我们改一下,在弄个要过滤掉的里空列表filter ,然后循环内每生成一个i,都判断下,如果不在过滤规则,那么直接放入res,如果中了过滤规则,那么就先放在filter列表中,全部分开存放之后,再继续考虑后面的事:

微信图片_20220706211132.png

如上图,加了这个判断算法后,我们看下res和filter都有什么:

微信图片_20220706211138.png

可以看到,原来的四条用例,其中有俩条因为中了规则而被放在了filter里:

微信图片_20220706211148.png

前面一节们已经探讨过,不能简简单单的就不要这个filter里的用例,这样会丢失几个重要的无辜组合。所以我们要对这个用例尽量改造后放回res。

但是这个算法说起来容易,做起来太难了。因为我们弄完后还要进行至少俩种判断才能放回res:

第一个判断:res里已经有重复的了。

第二个判断:没有再中过滤规则。

不过我们先把这些filter的组合,进行重组吧~ ,就拿第一个组合来说:

3个子状态,因为其中子状态2 和 子状态A 中了过滤规则而被淘汰。那么无辜的被过滤规则是谁呢?

是另外的规则和他们俩的组合,也就是如下:

子状态2 和 子状态二,子状态A和子状态二。

好,这俩种情况我们都找出来,然后去判断是否中了过滤规则,如果这也中了,那么就彻底放弃这个组合吧,删了一点不可惜。如果没中,我们再去重组:

微信图片_20220706211156.png

写到这里我们要想,怎么找出无辜组合呢?当然先找出罪魁祸首,也就是中了过滤规则那组,但是我不想再去循环过滤规则来找了,那样太麻烦了还增加了一层遍历。

所以我想了办法,在一开始把它放进filter的时候,就把中签的过滤规则也放进去不就好了么?这样我们现在直接就知道中过滤的是哪俩个子状态了,然后这俩个子状态每一个+剩余的其他子状态,就是无辜组合!微信图片_20220706211203.png

打印结果如下:

微信图片_20220706211211.png

这次我们直接就可以简单的搞定无辜组合了:

微信图片_20220706211217.png

我新建了这个wugu列表作为存放那些被误删的子状态组合,借助leetcode800道题的功底,秒出这个算法。看看wugu组合列表是什么:

微信图片_20220706211222.png

可以看到,它找出了4组 组合。

好,现在就可以继续往下走了。


下面要做的事 就三件事:


1.按照第一个判断,看看无辜组合是否已经存在于res中,若存在则拉到~

2.按照第二个判断,用一个新的非中过滤规则的子状态填充,形成完整的组合,然后添加3.进res中(可能这里还是个难点),把最终的res返回给前端即可~


好,本节内容已经足够多了。饭佬的脑子有点昏昏沉沉的~  

毕竟能看出这个正交+过滤规则有俩个大问题,就很耗费脑细胞。然后提出解决方案更耗费脑细胞。然后还要设计用户交互,则又死一批脑细胞。最后又要用复杂的算法去实现这个方案,则又累死一批脑细胞~

目录
打赏
0
0
0
0
27
分享
相关文章
Apifox工具让我的 Socket.IO 测试效率翻倍
用了 Apifox 测试 Socket.IO 后,我整个人都升级了!不仅操作简单到令人发指,功能还贼全面,真的是 提升开发效率的神器 !
OS-Copilot参数功能全面测试报告
作为一名运维工程师,我主要负责云资源的运维和管理。通过使用OS Copilot的-t/-f/管道功能,我顺利解决了环境快速搭建的问题,例如Tomcat的快速部署。具体步骤包括购买ECS服务器、配置安全组、远程登录并安装OS Copilot。使用-f参数成功安装并启动Tomcat,自动配置JDK,并通过|管道功能验证了生成内容的正确性。整个过程非常流畅,极大提升了工作效率。
60 12
Selenium:强大的 Web 自动化测试工具
Selenium 是一款强大的 Web 自动化测试工具,包括 Selenium IDE、WebDriver 和 Grid 三大组件,支持多种编程语言和跨平台操作。它能有效提高测试效率,解决跨浏览器兼容性问题,进行性能测试和数据驱动测试,尽管存在学习曲线较陡、不稳定等缺点,但其优势明显,是自动化测试领域的首选工具。
302 17
Selenium:强大的 Web 自动化测试工具
slb测试会话保持功能
slb测试会话保持功能
115 6
软件测试中的自动化策略与工具应用
在软件开发的快速迭代中,自动化测试以其高效、稳定的特点成为了质量保证的重要手段。本文将深入探讨自动化测试的核心概念、常见工具的应用,以及如何设计有效的自动化测试策略,旨在为读者提供一套完整的自动化测试解决方案,帮助团队提升测试效率和软件质量。
BALROG:基准测试工具,用于评估 LLMs 和 VLMs 在复杂动态环境中的推理能力
BALROG 是一款用于评估大型语言模型(LLMs)和视觉语言模型(VLMs)在复杂动态环境中推理能力的基准测试工具。它通过一系列挑战性的游戏环境,如 NetHack,测试模型的规划、空间推理和探索能力。BALROG 提供了一个开放且细粒度的评估框架,推动了自主代理研究的进展。
96 3
BALROG:基准测试工具,用于评估 LLMs 和 VLMs 在复杂动态环境中的推理能力
移动端性能测试工具
移动端性能测试工具
181 2
AI辅助安全测试案例某电商-供应链平台平台安全漏洞
【11月更文挑战第13天】该案例介绍了一家电商供应链平台如何利用AI技术进行全面的安全测试,包括网络、应用和数据安全层面,发现了多个潜在漏洞,并采取了有效的修复措施,提升了平台的整体安全性。
167 4
Socket.IO介绍,以及怎么连接测试Socket.IO接口?
Socket.IO 是一个用于浏览器和服务器间实时双向通信的库,支持低延迟消息传递、跨平台运行及自动重连。文章介绍了其特点与调试需求,并详细说明如何使用 Apifox 工具创建、连接、发送/接收 Socket.IO 事件,以及团队协作和调试技巧。掌握这些技能可提升实时应用开发效率与质量。
Python测试淘宝店铺所有商品接口的详细指南
本文详细介绍如何使用Python测试淘宝店铺商品接口,涵盖环境搭建、API接入、签名生成、请求发送、数据解析与存储、异常处理等步骤。通过具体代码示例,帮助开发者轻松获取和分析淘宝店铺商品数据,适用于电商运营、市场分析等场景。遵守法规、注意调用频率限制及数据安全,确保应用的稳定性和合法性。

热门文章

最新文章