Python+pytest+requests 自动化测试框架

本文介绍了如何使用Python的pytest和requests库构建自动化测试框架。内容包括环境准备、简单Demo、yml文件读取、数据层和业务层的封装、测试用例层的组织,以及日志记录功能的实现。最后,提供了福利资源,帮助读者进一步提升自动化测试能力。
摘要由CSDN通过智能技术生成

环境准备

本次选用的是Python+Pytest+requests来搭建自动化框架,需要有 Python 环境(3.x 版本),安装pytestrequests,不会安装的自行去网上搜教程。

关于 Pytest 的基本使用,这里不作讲解,不清楚的可以看我之前的文章。

简单 Demo

我们先创建一个项目,取名api-test,然后在下面创建一个test_api.py的文件

# test_api.py

import pytest
import requests


def test_01():
    response = requests.get('http://127.0.0.1:5000/login').json()
    print(response)
    assert response.get('success') == 'ok'

if __name__ == '__main__':
    pytest.main()

直接运行,结果如下

============================= test session starts =============================
platform win32 -- Python 3.7.1, pytest-6.2.1, py-1.10.0, pluggy-0.13.1
rootdir: D:\study\api-test
plugins: allure-pytest-2.8.31, dependency-0.5.1, forked-1.3.0, ordering-0.6, rerunfailures-9.1.1, xdist-2.2.1collected 1 item

test_api.py .{'success': 'ok', 'token': 'sdkhasgdhgasjhdgasgda'}
                                                            [100%]

============================== 1 passed in 0.16s ==============================
Process finished with exit code 0

一个简单的测试用例就完成了。

自动化测试工作中,往往会有很多测试文件,每次都需要导入 requests 库吗?

域名都是写在用例一起吗?

如果要记录日志,每次都在用例里面记录吗?

测试数据也写在用例里吗?

等等,答案显然是否定的,下面就让我们一起踏上框架封装之路。

首先我们创建一个包:base,用于存放最基础的封装方法,在包下创建一个模块http_client.py,此处用于封装 requests 发送请求的方法。

封装思路:

  • 创建 HttpClient 类,方便后续 api 继承后直接调用类下面的 get 和 post 方法
  • 创建__request 私有方法,作为发送请求公共方法,方便后面日志搜集请求信息和返回信息
  • 使用 requests.session(),requests 库的 session 会话对象可以跨请求保持某些参数
# base/http_client.py

import requests


class HttpClient():

    def __init__(self):
        self.__session = requests.session(
  • 6
    点赞
  • 134
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 5
    评论
1. 确定测试用例 首先,需要确定测试用例,即要测试的功能和场景。可以根据产品需求文档或者功能列表来确定测试用例,尽量覆盖所有的功能和场景。 2. 安装pytestrequests pytestPython的一个单元测试框架,可以方便地进行测试用例的编写和执行。requestsPython的一个HTTP库,可以方便地进行网络请求。 可以使用pip命令来安装这两个库: pip install pytest pip install requests 3. 编写测试用例 测试用例应该按照功能和场景分组,每个测试用例应该有一个明确的描述和预期结果。可以使用pytest的装饰器来标记测试用例: import pytest import requests @pytest.mark.parametrize('url, expected', [ ('http://example.com', 200), ('http://example.com/notfound', 404), ]) def test_requests(url, expected): r = requests.get(url) assert r.status_code == expected 这个测试用例中,使用了pytest的parametrize装饰器来指定不同的URL和期望的HTTP响应码。然后,使用requests库来发送HTTP请求,并使用assert语句来判断响应码是否符合预期。 4. 运行测试用例 使用pytest命令来运行测试用例: pytest test_requests.py 如果所有测试用例都通过,那么pytest会输出一个“PASSED”字样。如果有测试用例失败,pytest会输出一个“FAILED”字样,并显示具体的错误信息。 5. 生成测试报告 可以使用pytest-html插件来生成测试报告: pip install pytest-html pytest --html=report.html 这样就可以生成一个HTML格式的测试报告,并保存到report.html文件中。测试报告会包含所有测试用例的运行结果和错误信息。可以将测试报告发送给开发人员或者项目经理,以便于跟踪测试进度和问题。
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

酔清风

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值