pytest-项目结构

项目结构

python 复制代码
api_test_project/
├── config/
│   └── config.py  # 配置文件,存储接口的基本信息,如 URL、请求头、认证信息等
├── data/
│   └── test_data.json  # 测试数据文件,存储接口的请求参数、预期结果等
├── tests/
│   ├── __init__.py
│   ├── test_single_api.py  # 单接口测试用例文件
├── utils/
│   ├── __init__.py
│   └── api_client.py  # 封装接口请求的工具类
├── report/
│   └── report.html  # 测试报告文件
├── requirements.txt  # 项目依赖文件
└── run_tests.py  # 运行测试用例的脚本

1. config目录------存放项目的配置文件

python 复制代码
# config.py
# 接口的基本 URL
BASE_URL = 'https://api.example.com'
# 公共请求头
HEADERS = {
    'Content-Type': 'application/json',
    'Authorization': 'Bearer your_token'
}

2. data目录------存放测试数据

python 复制代码
// test_data.json
{
    "get_user": {
        "request": {
            "method": "GET",
            "endpoint": "/users/1",
            "params": {}
        },
        "expected": {
            "status_code": 200,
            "data": {
                "id": 1,
                "name": "John Doe"
            }
        }
    }
}

3. test 目录------存放测试用例文件

python 复制代码
# tests/test_single_api.py
import pytest
import requests
from config.config import BASE_URL, HEADERS
import json

# 读取测试数据
with open('../data/test_data.json', 'r', encoding='utf-8') as f:
    TEST_DATA = json.load(f)

@pytest.mark.parametrize("test_case", TEST_DATA.values())
def test_single_api(test_case):
    request_info = test_case['request']
    expected = test_case['expected']

    method = request_info['method']
    endpoint = request_info['endpoint']
    params = request_info.get('params', {})

    url = BASE_URL + endpoint

    if method == 'GET':
        response = requests.get(url, headers=HEADERS, params=params)
    elif method == 'POST':
        response = requests.post(url, headers=HEADERS, json=params)
    # 可以根据需要添加更多的请求方法

    # 断言响应状态码
    assert response.status_code == expected['status_code']

    # 断言响应数据
    if 'data' in expected:
        assert response.json() == expected['data']

4. utils目录------存放工具类

python 复制代码
# utils/api_client.py
import requests
from config.config import BASE_URL, HEADERS

class APIClient:
    def __init__(self):
        self.base_url = BASE_URL
        self.headers = HEADERS

    def send_request(self, method, endpoint, params=None):
        url = self.base_url + endpoint
        if method == 'GET':
            response = requests.get(url, headers=self.headers, params=params)
        elif method == 'POST':
            response = requests.post(url, headers=self.headers, json=params)
        # 可以根据需要添加更多的请求方法
        return response

5. report目录------存放测试报告文件

运行测试用例后会生成 report.html 文件。

6. requirements.txt文件

该文件列出了项目的依赖库,例如:

pytest

requests

pytest-html

7. run_tests.py文件

该文件用于运行测试用例并生成测试报告:

python 复制代码
# run_tests.py
import pytest

if __name__ == "__main__":
    pytest.main(['-s', '-v', '--html=report/report.html', 'tests/'])
相关推荐
峥无1 小时前
Linux系统编程基石:静态库·动态库·ELF文件·进程地址空间全景图
linux·运维·服务器
码云数智-大飞1 小时前
本地部署大模型:隐私安全与多元优势一站式解读
运维·网络·人工智能
Harvy_没救了2 小时前
【网络部署】 Win11 + VMware CentOS8 + Nginx 文件共享服务 Wiki
运维·网络·nginx
春风有信2 小时前
【2026.05.01】Windows10安装Docker Desktop 4.71.0.0步骤及问题解决
运维·docker·容器
lzhdim3 小时前
SQL 入门 12:SQL 视图:创建、修改与可更新视图
java·大数据·服务器·数据库·sql
2401_873479403 小时前
断网时如何实时判断IP归属?嵌入本地离线库,保障风控不中断
运维·服务器·网络
守城小轩3 小时前
基于Chrome140的Yahoo自动化(关键词浏览)——需求分析&环境搭建(一)
运维·自动化·chrome devtools·浏览器自动化·指纹浏览器·浏览器开发
handler014 小时前
Linux 内核剖析:进程优先级、上下文切换与 O(1) 调度算法
linux·运维·c语言·开发语言·c++·笔记·算法
草履虫君6 小时前
VMware 虚拟机网络性能优化指南:从 11 秒到 4 秒的完整调优实践
服务器·网络·经验分享·性能优化
日取其半万世不竭6 小时前
LVM 逻辑卷管理:不停机扩容磁盘的正确方式
运维·服务器