接口测试平台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

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

相关文章
|
23天前
|
移动开发 JSON Java
Jmeter实现WebSocket协议的接口测试方法
WebSocket协议是HTML5的一种新协议,实现了浏览器与服务器之间的全双工通信。通过简单的握手动作,双方可直接传输数据。其优势包括极小的头部开销和服务器推送功能。使用JMeter进行WebSocket接口和性能测试时,需安装特定插件并配置相关参数,如服务器地址、端口号等,还可通过CSV文件实现参数化,以满足不同测试需求。
106 7
Jmeter实现WebSocket协议的接口测试方法
|
23天前
|
测试技术
软件测试用例设计之微信群抢红包经典用例
作者在浏览招聘网站时遇到为微信群发和抢红包设计测试用例的问题,作为软件测试新手,作者通过实际体验并撰写测试案例来加深对业务的理解,并分享了测试案例表格。需要注意的是,该用例未考虑添加银行卡支付、红包类型选择及红包描述。
37 5
软件测试用例设计之微信群抢红包经典用例
|
23天前
|
JSON 移动开发 监控
快速上手|HTTP 接口功能自动化测试
HTTP接口功能测试对于确保Web应用和H5应用的数据正确性至关重要。这类测试主要针对后台HTTP接口,通过构造不同参数输入值并获取JSON格式的输出结果来进行验证。HTTP协议基于TCP连接,包括请求与响应模式。请求由请求行、消息报头和请求正文组成,响应则包含状态行、消息报头及响应正文。常用的请求方法有GET、POST等,而响应状态码如2xx代表成功。测试过程使用Python语言和pycurl模块调用接口,并通过断言机制比对实际与预期结果,确保功能正确性。
101 3
快速上手|HTTP 接口功能自动化测试
|
8天前
|
人工智能 测试技术 Python
基于 LangChain 的自动化测试用例的生成与执行
本章节详细介绍了如何利用人工智能技术自动化完成Web、App及接口测试用例的生成与执行过程,避免了手动粘贴和调整测试用例的繁琐操作。通过封装工具包与Agent,不仅提升了测试效率,还实现了从生成到执行的一体化流程。应用价值在于显著节省时间并提高测试自动化水平。
25 1
|
16天前
|
测试技术
基于LangChain手工测试用例转App自动化测试生成工具
在传统App自动化测试中,测试工程师需手动将功能测试用例转化为自动化用例。市面上多数产品通过录制操作生成测试用例,但可维护性差。本文探讨了利用大模型直接生成自动化测试用例的可能性,介绍了如何使用LangChain将功能测试用例转换为App自动化测试用例,大幅节省人力与资源。通过封装App底层工具并与大模型结合,记录执行步骤并生成自动化测试代码,最终实现高效自动化的测试流程。
30 4
|
23天前
|
JavaScript 前端开发 测试技术
ChatGPT与接口测试
ChatGPT与接口测试,测试通过
31 5
|
2月前
|
测试技术
基于LangChain手工测试用例转Web自动化测试生成工具
该方案探索了利用大模型自动生成Web自动化测试用例的方法,替代传统的手动编写或录制方式。通过清晰定义功能测试步骤,结合LangChain的Agent和工具包,实现了从功能测试到自动化测试的转换,极大提升了效率。不仅减少了人工干预,还提高了测试用例的可维护性和实用性。
47 4
|
2月前
|
网络协议 测试技术 网络安全
Python进行Socket接口测试的实现
在现代软件开发中,网络通信是不可或缺的一部分。无论是传输数据、获取信息还是实现实时通讯,都离不开可靠的网络连接和有效的数据交换机制。而在网络编程的基础中,Socket(套接字)技术扮演了重要角色。 Socket 允许计算机上的程序通过网络进行通信,它是网络通信的基础。Python 提供了强大且易于使用的 socket 模块,使开发者能够轻松地创建客户端和服务器应用,实现数据传输和交互。 本文将深入探讨如何利用 Python 编程语言来进行 Socket 接口测试。我们将从基础概念开始介绍,逐步引导大家掌握创建、测试和优化 socket 接口的关键技能。希望本文可以给大家的工作带来一些帮助~
|
2月前
|
网络协议 测试技术 网络安全
Python进行Socket接口测试的实现
在现代软件开发中,网络通信是不可或缺的一部分。无论是传输数据、获取信息还是实现实时通讯,都离不开可靠的网络连接和有效的数据交换机制。而在网络编程的基础中,Socket(套接字)技术扮演了重要角色。 Socket 允许计算机上的程序通过网络进行通信,它是网络通信的基础。Python 提供了强大且易于使用的 socket 模块,使开发者能够轻松地创建客户端和服务器应用,实现数据传输和交互。 本文将深入探讨如何利用 Python 编程语言来进行 Socket 接口测试。我们将从基础概念开始介绍,逐步引导大家掌握创建、测试和优化 socket 接口的关键技能。希望本文可以给大家的工作带来一些帮助~
|
2月前
|
SQL Java 测试技术
SpringBoot单元测试快速写法问题之PorkService 接口中的 getPork 方法的作用如何解决
SpringBoot单元测试快速写法问题之PorkService 接口中的 getPork 方法的作用如何解决
下一篇
无影云桌面