Pytest是一个功能强大的Python测试框架,它提供了很多有用的功能和扩展机制。其中之一是Fixture,Fixture是pytest中的一个装饰器,可以用来提供测试所需的数据和对象。
本篇文章将从头开始,详细介绍如何使用Fixture进行接口自动化测试,并解释conftest.py的加载机制。
1.安装Pytest和相关库
首先,需要安装Pytest和相关库。可以使用pip命令来安装:
$ pip install pytest requests
2.创建测试文件
创建一个新的Python文件,命名为test_api.py,用于编写接口测试用例。
3.编写接口测试用例
在test_api.py文件中,编写一个简单的接口测试用例。例如,测试一个获取用户信息的接口:
import pytest
import requests@pytest.fixture
def base_url():return "https://api.example.com"def test_get_user(base_url):response = requests.get(f"{base_url}/users/1")assert response.status_code == 200assert response.json()["name"] == "John Doe"
在上面的示例中,我们定义了一个Fixture函数base_url,用于返回接口的基本URL。然后,在test_get_user函数中使用了base_url,并发送了一个GET请求来获取用户信息。
现在我也找了很多测试的朋友,做了一个分享技术的交流群,共享了很多我们收集的技术文档和视频教程。
如果你不想再体验自学时找不到资源,没人解答问题,坚持几天便放弃的感受
可以加入我们一起交流。而且还有很多在自动化,性能,安全,测试开发等等方面有一定建树的技术大牛
分享他们的经验,还会分享很多直播讲座和技术沙龙
可以免费学习!划重点!开源的!!!
qq群号:691998057【暗号:csdn999】
4.运行测试用例
运行测试用例的方法很简单,只需要在命令行中运行pytest命令即可:
$ pytest
Pytest会自动查找当前目录及其子目录中所有以test_开头的文件,并运行其中的测试用例。
5、使用Fixture提供测试数据和对象
除了提供接口的基本URL,Fixture还可以用来提供测试数据和对象。例如,我们可以使用Fixture来创建一个测试用户并返回用户ID:
@pytest.fixture
def test_user(base_url):user_data = {"name": "John Doe","email": "john.doe@example.com"}response = requests.post(f"{base_url}/users", json=user_data)user_id = response.json()["id"]yield user_id# 在测试用例执行完毕后,做一些清理工作requests.delete(f"{base_url}/users/{user_id}")def test_update_user(base_url, test_user):new_name = "Jane Doe"response = requests.put(f"{base_url}/users/{test_user}", json={"name": new_name})assert response.status_code == 200response = requests.get(f"{base_url}/users/{test_user}")assert response.status_code == 200assert response.json()["name"] == new_name
在上面的示例中,我们定义了一个新的Fixture函数test_user,用于创建一个测试用户,并返回用户ID。在test_update_user函数中,我们使用了test_user Fixture来获取用户ID,并发送一个PUT请求来更新用户信息。
Fixture函数可以使用yield语句来分隔测试用例的执行阶段。在yield语句之前的代码会在测试用例开始前执行,而在yield语句之后的代码会在测试用例结束后执行。这样可以方便地进行一些清理工作,例如删除测试用户。
6.使用conftest.py共享Fixture
Pytest还提供了conftest.py文件来共享Fixture。conftest.py是一个特殊的文件名,可以在任何测试目录中创建。它可以包含多个Fixture函数,这些Fixture函数将自动加载并可以在任何测试文件中使用。
例如,我们可以将之前的base_url Fixture移动到conftest.py中:
import pytest@pytest.fixture
def base_url():return "https://api.example.com"
然后,在test_api.py中可以直接使用base_url Fixture,而无需再定义一遍。
7.conftest.py加载机制
conftest.py文件的加载机制是按照以下顺序进行的:
- 当前测试目录及其子目录
- conftest.py文件所在的目录及其子目录
- conftest.py文件所在的父目录及其子目录
- ...
也就是说,conftest.py文件可以在整个测试项目中共享Fixture。可以根据需要在不同的目录中创建conftest.py文件,并在其中定义不同的Fixture函数。
总结
本文从0到1讲解了如何使用Pytest和Fixture进行接口自动化测试,并详细解释了conftest.py的加载机制。通过使用Fixture,我们可以方便地提供测试数据和对象,并进行一些初始化和清理工作。conftest.py的加载机制使得Fixture函数可以在整个测试项目中共享,方便地复用和扩展。希望本文对你理解和使用Pytest的Fixture有所帮助!
下面是配套资料,对于做【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!
最后: 可以在公众号:程序员小濠 ! 免费领取一份216页软件测试工程师面试宝典文档资料。以及相对应的视频学习教程免费分享!,其中包括了有基础知识、Linux必备、Shell、互联网程序原理、Mysql数据库、抓包工具专题、接口测试工具、测试进阶-Python编程、Web自动化测试、APP自动化测试、接口自动化测试、测试高级持续集成、测试架构开发测试框架、性能测试、安全测试等。
如果我的博客对你有帮助、如果你喜欢我的博客内容,请 “点赞” “评论” “收藏” 一键三连哦!