接口测试平台178:并发用例继续

简介: 接口测试平台178:并发用例继续

上节课我们略微重构了一下这个wqrf_run_case.py。

   本节课继续开发,开始要发送请求了:

   而请求要分为以下几个情况

   (注意,其中实现代码均为postman生成源码参考并增加了灵活度,且经过了漫长的千余位同行的使用和数次纠正及优化,若仍有bug,请及时反馈,感谢贡献。)

image.png

image.png

image.png

image.png

可复制版本:

 '执行请求'
    ## none请求
    if api_body_method == 'none' or api_body_method == 'null':
        if type(login_res) == dict:
            response = requests.request(api_method.upper(), url, headers=header, data={}, cert=cert_name)
        else:
            response = login_res.request(api_method.upper(), url, headers=header, data={}, cert=cert_name)
    ## form-data请求
    elif api_body_method == 'form-data':
        files = []
        payload = ()
        for i in eval(api_body):
            payload += ((i[0], i[1]),)
        if type(login_res) == dict:
            for i in login_res.keys():
                payload += ((i, login_res[i]),)
            response = requests.request(api_method.upper(), url, headers=header, data=payload, files=files,
                                        cert=cert_name)
        else:
            response = login_res.request(api_method.upper(), url, headers=header, data=payload, files=files,
                                         cert=cert_name)
    ## x-www-form-urlencoded请求
    elif api_body_method == 'x-www-form-urlencoded':
        header['Content-Type'] = 'application/x-www-form-urlencoded'
        payload = ()
        for i in eval(api_body):
            payload += ((i[0], i[1]),)
        if type(login_res) == dict:
            for i in login_res.keys():
                payload += ((i, login_res[i]),)
        if type(login_res) == dict:
            response = requests.request(api_method.upper(), url, headers=header, data=payload, cert=cert_name)
        else:
            response = login_res.request(api_method.upper(), url, headers=header, data=payload, cert=cert_name)
    ## GraphQL请求
    elif api_body_method == 'GraphQL':
        header['Content-Type'] = 'application/json'
        query = api_body.split('*WQRF*')[0]
        graphql = api_body.split('*WQRF*')[1]
        try:
            eval(graphql)
        except:
            graphql = '{}'
        payload = '{"query":"%s","variables":%s}' % (query, graphql)
        if type(login_res) == dict:
            response = requests.request(api_method.upper(), url, headers=header, data=payload, cert=cert_name)
        else:
            response = login_res.request(api_method.upper(), url, headers=header, data=payload, cert=cert_name)
    ## raw的五种请求
    else:  # 这时肯定是raw的五个子选项:
        if api_body_method == 'Text':
            header['Content-Type'] = 'text/plain'
        if api_body_method == 'JavaScript':
            header['Content-Type'] = 'text/plain'
        if api_body_method == 'Json':
            api_body = json.loads(api_body)
            for i in login_res.keys():
                api_body[i] = login_res[i]
            api_body = json.dumps(api_body)
            header['Content-Type'] = 'text/plain'
        if api_body_method == 'Html':
            header['Content-Type'] = 'text/plain'
        if api_body_method == 'Xml':
            header['Content-Type'] = 'text/plain'
        if type(login_res) == dict:
            response = requests.request(api_method.upper(), url, headers=header, data=api_body.encode('utf-8'),
                                        cert=cert_name)
        else:
            response = login_res.request(api_method.upper(), url, headers=header, data=api_body.encode('utf-8'),
                                         cert=cert_name)
    response.encoding = "utf-8"
    res = response.text #最终结果文案

注意,还有以下可选:


这里奉上另一种简易化的发送代码,大家也可以替换这个:

data = {}
if data["method"] == "GET":
    response = requests.get(
        data["url"], params=data["body"], headers=data["header"],          cookies=data["cookies"], proxies=data["proxy"])
elif data["header"]["Content-Type"] == "application/json":
    response = requests.post(
        data["url"], json=data["body"], headers=data["header"], cookies=data["cookies"], proxies=data["proxy"])
else :
    response = requests.post(
        data["url"], data=data["body"], headers=data["header"], cookies=data["cookies"], proxies=data["proxy"])

然后是 具体去哪里矫正和参考:

image.png

好了,本期内容到此结束,欢迎继续追更。

相关文章
|
4天前
|
监控 JavaScript 测试技术
postman接口测试工具详解
Postman是一个功能强大且易于使用的API测试工具。通过详细的介绍和实际示例,本文展示了Postman在API测试中的各种应用。无论是简单的请求发送,还是复杂的自动化测试和持续集成,Postman都提供了丰富的功能来满足用户的需求。希望本文能帮助您更好地理解和使用Postman,提高API测试的效率和质量。
30 11
|
1月前
|
人工智能 供应链 安全
AI辅助安全测试案例某电商-供应链平台平台安全漏洞
【11月更文挑战第13天】该案例介绍了一家电商供应链平台如何利用AI技术进行全面的安全测试,包括网络、应用和数据安全层面,发现了多个潜在漏洞,并采取了有效的修复措施,提升了平台的整体安全性。
|
1月前
|
JSON Java 测试技术
SpringCloud2023实战之接口服务测试工具SpringBootTest
SpringBootTest同时集成了JUnit Jupiter、AssertJ、Hamcrest测试辅助库,使得更容易编写但愿测试代码。
60 3
|
1月前
|
监控 安全 测试技术
构建高效的精准测试平台:设计与实现指南
在软件开发过程中,精准测试是确保产品质量和性能的关键环节。一个精准的测试平台能够自动化测试流程,提高测试效率,缩短测试周期,并提供准确的测试结果。本文将分享如何设计和实现一个精准测试平台,从需求分析到技术选型,再到具体的实现步骤。
133 1
|
2月前
|
人工智能 监控 测试技术
云应用开发平台测试
云应用开发平台测试
77 2
|
1月前
|
监控 安全 测试技术
构建高效精准测试平台:设计与实现全攻略
在软件开发过程中,精准测试是确保产品质量的关键环节。一个高效、精准的测试平台能够自动化测试流程,提高测试覆盖率,缩短测试周期。本文将分享如何设计和实现一个精准测试平台,从需求分析到技术选型,再到具体的实现步骤。
64 0
|
2月前
|
JSON 算法 数据可视化
测试专项笔记(一): 通过算法能力接口返回的检测结果完成相关指标的计算(目标检测)
这篇文章是关于如何通过算法接口返回的目标检测结果来计算性能指标的笔记。它涵盖了任务描述、指标分析(包括TP、FP、FN、TN、精准率和召回率),接口处理,数据集处理,以及如何使用实用工具进行文件操作和数据可视化。文章还提供了一些Python代码示例,用于处理图像文件、转换数据格式以及计算目标检测的性能指标。
77 0
测试专项笔记(一): 通过算法能力接口返回的检测结果完成相关指标的计算(目标检测)
|
3月前
|
移动开发 JSON Java
Jmeter实现WebSocket协议的接口测试方法
WebSocket协议是HTML5的一种新协议,实现了浏览器与服务器之间的全双工通信。通过简单的握手动作,双方可直接传输数据。其优势包括极小的头部开销和服务器推送功能。使用JMeter进行WebSocket接口和性能测试时,需安装特定插件并配置相关参数,如服务器地址、端口号等,还可通过CSV文件实现参数化,以满足不同测试需求。
263 7
Jmeter实现WebSocket协议的接口测试方法
|
3月前
|
JSON 移动开发 监控
快速上手|HTTP 接口功能自动化测试
HTTP接口功能测试对于确保Web应用和H5应用的数据正确性至关重要。这类测试主要针对后台HTTP接口,通过构造不同参数输入值并获取JSON格式的输出结果来进行验证。HTTP协议基于TCP连接,包括请求与响应模式。请求由请求行、消息报头和请求正文组成,响应则包含状态行、消息报头及响应正文。常用的请求方法有GET、POST等,而响应状态码如2xx代表成功。测试过程使用Python语言和pycurl模块调用接口,并通过断言机制比对实际与预期结果,确保功能正确性。
273 3
快速上手|HTTP 接口功能自动化测试
|
3月前
|
JavaScript 前端开发 测试技术
ChatGPT与接口测试
ChatGPT与接口测试,测试通过
57 5
下一篇
DataWorks