一、简单的api自动化Demo
环境准备
本次选用的是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库吗?
域名都是写在用例一起吗?
如果要记录日志,每次都在用例里面记录吗?
测试数据也写在用例里吗?
等等,答案显然是否定的,下面就让我们一起踏上框架封装之路。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列1:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
· 【杂谈】分布式事务——高大上的无用知识?