目录
前言:
Python 是一种广泛使用的编程语言,它可以用于开发各种软件和应用程序。pytest 是一个广泛使用的自动化测试框架,它可以帮助我们更轻松地执行测试,并使测试结果更加可靠。requests 是一个广泛使用的 Python 库,它可以帮助我们模拟用户的 HTTP 请求。
环境准备
本次选用的是Python+Pytest+requests
来搭建自动化框架,需要有 Python 环境(3.x 版本),安装pytest
和requests
,不会安装的自行去网上搜教程。
关于 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()
def get(self, path, **kwargs):
return self.__request(