接口测试平台代码实现42:各个请求体自动显示

简介: 本节主要是用来在用户打开调试弹层后,能自动显示弹层的接口请求体的功能。 本节之后,将会进行数节的 接口后台实际请求的代码实现。

打开P_apis.html:找到我们上节没写完的那个打开显示的函数微信图片_20220620115730.png

首先我们记得,不同的展示窗口,显示的不一样,主要分俩类:

一类是:

form-data和x-www....的表格类显示。

另一类是raw的五种子选项的多行文本框的显示效果。

很明显,第二类要简单很多, 所以我们先从第二类入手,迅速解决掉这五个多行本文框的显示,再集中精力对付较难的第一类表格显示。微信图片_20220620115808.png

如上图五种,用五个if判断搞定了这个显示效果。有同学可能会说,其实这五种一开始不用5个多行文本框,用一个就可以了,5个的话很麻烦。这里的话其实也是可以的。但是后续的话可能要少一点灵活性。不过这里全凭大家自选哈。就算现在这种五个输入框,也都是写好一个,直接复制粘贴成5个。也没啥太多成本。

   到这为止。我们还剩下俩个编码格式:form-data和x-www....

写好一个,另一个基本就是复制改改。

如下图,是form-data的显示代码:

微信图片_20220620115814.png

在正式写之前,我们要思考下这里要如何填充好呢?作者看了下第三方这个表格,并没有自动填充的方法,只能我们手动拼接了看来。

所以步骤为:

  1. 给这个表格进行初始化,清除掉旧数据。(不然的话,你每次切换到这里这里搞不好数据会重复累加显示),但是因我们在整个显示函数中的一开始就触发了clear清除函数,所以这步我就不用再写了。
  2. 拿到请求体列表,作为循环主体
  3. 遍历这个请求体列表,获取每一对key-value,然后我们获取表格的所有子标签,也就是获取到一堆tr,和tr内部的一对td。
  4. 然后tr的下标就是我们遍历这个循环的下标,td应该只有2个,第一个放key,第二个放value,我们对其分别赋值,值就是从这个请求体列表拿到的。
  5. 最后我们别忘了代码要点击一下这个表格的新增参数按钮。不然下一对key-value你就没地方放了,因为这个第三方表格我们设定一开始就带一行空的。所以顺序就是先填key-value,再新增空行。不要担心空行最后多出来,我们可以在最后一次遍历的时候结尾不点击新增参数按钮,即便我们点击了。我们的保存函数也可以过滤掉空行不保存。

好了,看下代码:微信图片_20220620115820.png

可复制代码如下:

if(ret.body_method == 'form-data'){
    var tbody = document.getElementById('mytbody'); // 定位表格中的tbody部分
    body = eval(ret.api_body); //把这个像列表的字符串请求体变成真正的列表
    for(var i=0;i<body.length;i++){ // 遍历这个请求体列表
        key = body[i][0]; //拿出每一个键值对的key
        value = body[i][1];//拿出每一个键值对的value
        var childs_tr = tbody.children ;//获取到这个表格下面所有的tr组成的大列表
        // 每个tr下的children得到的是 td列表,只有俩个。
        childs_tr[i].children[0].innerText = key; //第一个td放key
        childs_tr[i].children[1].innerText = value;//第二个td放value
        //判断是否是最后一次遍历,来决定是否点击新增参数按钮
        if(i<body.length-1){
            document.getElementById('add').click()
        }
    }
}

微信图片_20220620115827.png可以看到,已经可以默认显示成功了。

接下来再如法炮制,去写x-www....,注意其中几个修改的地方:

微信图片_20220620115840.png

然后我们再次刷新页面,看看效果:

微信图片_20220620115853.png

好了,到这里,我们就可以进行完整的保存显示 测试了。各个编码格式大家都可以试一下,确保全部正常后,本节即可结束。

相关文章
|
8天前
|
算法 Java 测试技术
使用 BenchmarkDotNet 对 .NET 代码进行性能基准测试
使用 BenchmarkDotNet 对 .NET 代码进行性能基准测试
40 13
|
18天前
|
监控 JavaScript 测试技术
postman接口测试工具详解
Postman是一个功能强大且易于使用的API测试工具。通过详细的介绍和实际示例,本文展示了Postman在API测试中的各种应用。无论是简单的请求发送,还是复杂的自动化测试和持续集成,Postman都提供了丰富的功能来满足用户的需求。希望本文能帮助您更好地理解和使用Postman,提高API测试的效率和质量。
70 11
|
2月前
|
并行计算 算法 测试技术
C语言因高效灵活被广泛应用于软件开发。本文探讨了优化C语言程序性能的策略,涵盖算法优化、代码结构优化、内存管理优化、编译器优化、数据结构优化、并行计算优化及性能测试与分析七个方面
C语言因高效灵活被广泛应用于软件开发。本文探讨了优化C语言程序性能的策略,涵盖算法优化、代码结构优化、内存管理优化、编译器优化、数据结构优化、并行计算优化及性能测试与分析七个方面,旨在通过综合策略提升程序性能,满足实际需求。
65 1
|
2月前
|
人工智能 供应链 安全
AI辅助安全测试案例某电商-供应链平台平台安全漏洞
【11月更文挑战第13天】该案例介绍了一家电商供应链平台如何利用AI技术进行全面的安全测试,包括网络、应用和数据安全层面,发现了多个潜在漏洞,并采取了有效的修复措施,提升了平台的整体安全性。
|
2月前
|
JSON Java 测试技术
SpringCloud2023实战之接口服务测试工具SpringBootTest
SpringBootTest同时集成了JUnit Jupiter、AssertJ、Hamcrest测试辅助库,使得更容易编写但愿测试代码。
70 3
|
2月前
|
监控 安全 测试技术
构建高效的精准测试平台:设计与实现指南
在软件开发过程中,精准测试是确保产品质量和性能的关键环节。一个精准的测试平台能够自动化测试流程,提高测试效率,缩短测试周期,并提供准确的测试结果。本文将分享如何设计和实现一个精准测试平台,从需求分析到技术选型,再到具体的实现步骤。
150 1
|
3月前
|
人工智能 监控 测试技术
云应用开发平台测试
云应用开发平台测试
82 2
|
2月前
|
监控 安全 测试技术
构建高效精准测试平台:设计与实现全攻略
在软件开发过程中,精准测试是确保产品质量的关键环节。一个高效、精准的测试平台能够自动化测试流程,提高测试覆盖率,缩短测试周期。本文将分享如何设计和实现一个精准测试平台,从需求分析到技术选型,再到具体的实现步骤。
71 0
|
3月前
|
JSON 算法 数据可视化
测试专项笔记(一): 通过算法能力接口返回的检测结果完成相关指标的计算(目标检测)
这篇文章是关于如何通过算法接口返回的目标检测结果来计算性能指标的笔记。它涵盖了任务描述、指标分析(包括TP、FP、FN、TN、精准率和召回率),接口处理,数据集处理,以及如何使用实用工具进行文件操作和数据可视化。文章还提供了一些Python代码示例,用于处理图像文件、转换数据格式以及计算目标检测的性能指标。
83 0
测试专项笔记(一): 通过算法能力接口返回的检测结果完成相关指标的计算(目标检测)
|
4月前
|
移动开发 JSON Java
Jmeter实现WebSocket协议的接口测试方法
WebSocket协议是HTML5的一种新协议,实现了浏览器与服务器之间的全双工通信。通过简单的握手动作,双方可直接传输数据。其优势包括极小的头部开销和服务器推送功能。使用JMeter进行WebSocket接口和性能测试时,需安装特定插件并配置相关参数,如服务器地址、端口号等,还可通过CSV文件实现参数化,以满足不同测试需求。
280 7
Jmeter实现WebSocket协议的接口测试方法