接口测试平台代码实现51: 自动异常测试-4

简介: 接口测试平台代码实现51: 自动异常测试-4

 书接上文,我们回顾一下最后的这个函数:微信图片_20220623070748.png

我们在catch中已经对不可替换的请求体类型做了处理。现在要开始进行try中符合规则的请求体类型了。

   这里需要补一句,这里第一层try中可以运行完的只是说不会报错,共俩种:

  1. none
  2. 二维数组

其中none很显然我们也不需要对其进行替换所以我们这么写:微信图片_20220623070809.png

我们只需要在俩个红色箭头的位置,进行替换规则即可。数组是二维数组:长这样 [["aa","11"],["bb":"22]]

微信图片_20220623070817.png

如果要替换,那我们的循环应该起码是俩层,

第一层我们负责遍历请求体有几个参数,示例有俩个参数

第二层循环遍历预置的替换参数,示例有6个微信图片_20220623070824.png

但是我们需要先加上把这个替换数据的数组声明出来的代码:微信图片_20220623070832.png

接下来就是这个复杂的双层循环替换了。我们要保证每次替换只让目标参数的值依次变成预置替换参数,其他的保持原始正确的值。那么就不要在原始的s上做替换,否则我们会丢失原来的正确的值。

比如 示例中:aa = 11 ,bb =22 俩个参数。当我们遍历aa的时候,aa = '中文', bb=22。然后到了该遍历bb的时候,我们就没办法把aa复原了,因为原始值11已经丢失了。所以我们要新建一个新的请求体作为替身。每次替换前,都让他的值初始化,靠着原始的s,把s的原始值覆盖到这个新替身上即可。

微信图片_20220623070838.png

(最后会给大家附上这个函数的完整代码可复制版本)代码中的深拷贝是jquery的方法:$.extend(true,新,旧)我们每次都输出打印了下这个新请求体,来看看是不是符合我们预期吧:

微信图片_20220623070845.png

大家可以看到,当开始遍历bb的时候,aa成功恢复了原始值11。看来没什么问题。

   数组的也就是这个form-data和x-www....的我们完成之后。接下来就是raw-json格式的了。看看现在的代码:

微信图片_20220623070851.png

当我们判断出来这是个json串的时候,就对其进行依次替换。

微信图片_20220623070901.png

我们遍历这个字典的key,然后依次进行替换,仍然是俩层大循环:

代码如下:

微信图片_20220623070907.png

来看下效果:

微信图片_20220623070914.png

果然都进行了替换。

所以给大家奉上源码:

function error_play() {
    api_body = document.getElementById('error_api_body').value;
    ready_error_data = document.getElementById('ready_error_data').value;
    //把预替换数据从一个大字符串,按逗号解析成数组。
    var r = ready_error_data.split(',');
    //判断是不是form-data/x-www...的二维数组格式
    try {
        var s = eval(api_body);
        if(s instanceof Array){
            console.log('这是数组');
            for(var i=0;i<s.length;i++){ //第一层 判断一共请求体有几个参数就进行几次大循环
                for(var j=0;j<r.length;j++){
                    var new_body = []; //我们不能在s本尊上来回替换,所以弄了个替身,这个替身每次新的参数循环,都会重新被赋值原始s
                    $.extend(true,new_body, s);
                    new_body[i][1] = r[j];
                    console.log(new_body)
                }
            }
        }else{
            console.log('这是none');
            alert('当前请求体不含任何内容!');
        }
    }catch (e) {
        //若不是就继续判断是不是raw-json的json串格式
        try {
            var s = JSON.parse(api_body);
            console.log('这是字典json')
            for(var i in s){
                for(var j=0;j<r.length;j++){
                    var new_body = {};
                    $.extend(true,new_body, s);
                    new_body[i] = r[j];
                    console.log(new_body)
                }
            }
        }catch (e) {
            //若也不是,那就不需要做异常值测试了
            alert('当前接口的请求体类型不支持异常值测试!')
        }
    }
}

本节的最后,给大家看一个bug:

就是当我们把请求体变成如下这种带回车的情况时,那么点击异常值测试就会报错,甚至打不开弹层:

微信图片_20220623070923.png微信图片_20220623070929.png

这种原因是因为我们在调用这个函数的时候,这个按钮的传参数位置因为有了回车,就变成下面这个样子:

微信图片_20220623070936.png

这种直接换行的写法在html中属于引起了语法错误。

那么我们显然在一开始的时候没考虑到这种情况,只是简单的想当然的我们需要这个接口请求体,就传进来的思维。


所以下节课会给大家公布一些解决方案和具体代码。小伙伴也可以自己想想办法,看看怎么解决?欢迎回复:

相关文章
|
1月前
|
数据采集 机器学习/深度学习 大数据
行为检测代码(一):超详细介绍C3D架构训练+测试步骤
这篇文章详细介绍了C3D架构在行为检测领域的应用,包括训练和测试步骤,使用UCF101数据集进行演示。
40 1
行为检测代码(一):超详细介绍C3D架构训练+测试步骤
|
1月前
|
机器学习/深度学习 人工智能 监控
提升软件质量的关键路径:高效测试策略与实践在软件开发的宇宙中,每一行代码都如同星辰般璀璨,而将这些星辰编织成星系的过程,则依赖于严谨而高效的测试策略。本文将引领读者探索软件测试的奥秘,揭示如何通过精心设计的测试方案,不仅提升软件的性能与稳定性,还能加速产品上市的步伐,最终实现质量与效率的双重飞跃。
在软件工程的浩瀚星海中,测试不仅是发现缺陷的放大镜,更是保障软件质量的坚固防线。本文旨在探讨一种高效且创新的软件测试策略框架,它融合了传统方法的精髓与现代技术的突破,旨在为软件开发团队提供一套系统化、可执行性强的测试指引。我们将从测试规划的起点出发,沿着测试设计、执行、反馈再到持续优化的轨迹,逐步展开论述。每一步都强调实用性与前瞻性相结合,确保测试活动能够紧跟软件开发的步伐,及时适应变化,有效应对各种挑战。
|
7天前
|
JSON Java 测试技术
SpringCloud2023实战之接口服务测试工具SpringBootTest
SpringBootTest同时集成了JUnit Jupiter、AssertJ、Hamcrest测试辅助库,使得更容易编写但愿测试代码。
36 3
|
1月前
|
JSON 算法 数据可视化
测试专项笔记(一): 通过算法能力接口返回的检测结果完成相关指标的计算(目标检测)
这篇文章是关于如何通过算法接口返回的目标检测结果来计算性能指标的笔记。它涵盖了任务描述、指标分析(包括TP、FP、FN、TN、精准率和召回率),接口处理,数据集处理,以及如何使用实用工具进行文件操作和数据可视化。文章还提供了一些Python代码示例,用于处理图像文件、转换数据格式以及计算目标检测的性能指标。
59 0
测试专项笔记(一): 通过算法能力接口返回的检测结果完成相关指标的计算(目标检测)
|
2月前
|
Java C++
代码文件间重复性测试
本文介绍了如何使用代码相似性检测工具simian来找出代码文件中的重复行,并通过示例指令展示了如何将检测结果输出到指定的文本文件中。
|
1月前
|
JavaScript 前端开发 API
vue尚品汇商城项目-day02【9.Home组件拆分+10.postman测试接口】
vue尚品汇商城项目-day02【9.Home组件拆分+10.postman测试接口】
40 0
|
1月前
|
算法 Java 测试技术
数据结构 —— Java自定义代码实现顺序表,包含测试用例以及ArrayList的使用以及相关算法题
文章详细介绍了如何用Java自定义实现一个顺序表类,包括插入、删除、获取数据元素、求数据个数等功能,并对顺序表进行了测试,最后还提及了Java中自带的顺序表实现类ArrayList。
19 0
|
2月前
|
移动开发 JSON Java
Jmeter实现WebSocket协议的接口测试方法
WebSocket协议是HTML5的一种新协议,实现了浏览器与服务器之间的全双工通信。通过简单的握手动作,双方可直接传输数据。其优势包括极小的头部开销和服务器推送功能。使用JMeter进行WebSocket接口和性能测试时,需安装特定插件并配置相关参数,如服务器地址、端口号等,还可通过CSV文件实现参数化,以满足不同测试需求。
239 7
Jmeter实现WebSocket协议的接口测试方法
|
2月前
|
JSON 移动开发 监控
快速上手|HTTP 接口功能自动化测试
HTTP接口功能测试对于确保Web应用和H5应用的数据正确性至关重要。这类测试主要针对后台HTTP接口,通过构造不同参数输入值并获取JSON格式的输出结果来进行验证。HTTP协议基于TCP连接,包括请求与响应模式。请求由请求行、消息报头和请求正文组成,响应则包含状态行、消息报头及响应正文。常用的请求方法有GET、POST等,而响应状态码如2xx代表成功。测试过程使用Python语言和pycurl模块调用接口,并通过断言机制比对实际与预期结果,确保功能正确性。
247 3
快速上手|HTTP 接口功能自动化测试
|
2月前
|
JavaScript 前端开发 测试技术
ChatGPT与接口测试
ChatGPT与接口测试,测试通过
48 5