FastAPI 全栈后端(七):测试与自动化

创作者: Yardon | GitHub: github.com/YardonYan | 版本: v1.0 |



测试框架 pytest

bash 复制代码
pip install pytest pytest-asyncio httpx
python 复制代码
# test_main.py
def test_root():
    assert True

def test_add():
    assert 1 + 1 == 2
bash 复制代码
pytest test_main.py -v

FastAPI TestClient

python 复制代码
from fastapi.testclient import TestClient
from main import app

client = TestClient(app)

def test_login_success():
    response = client.post(
        "/api/v1/auth/token",
        data={"username": "yardon", "password": "secret123"},
    )
    assert response.status_code == 200
    assert "access_token" in response.json()

def test_login_wrong_password():
    response = client.post(
        "/api/v1/auth/token",
        data={"username": "yardon", "password": "wrong"},
    )
    assert response.status_code == 401

TestClient 让同步测试不需要启动真实服务器,响应速度极快。


异步测试

python 复制代码
import pytest
from httpx import AsyncClient, ASGITransport
from main import app

@pytest.mark.asyncio
async def test_list_users():
    transport = ASGITransport(app=app)
    async with AsyncClient(transport=transport, base_url="http://test") as ac:
        response = await ac.get("/api/v1/users")
    assert response.status_code == 200

Fixture 与依赖覆盖

python 复制代码
from pytest import fixture
from main import app
from db import get_db, override_get_db

@fixture
def test_db():
    # 创建测试数据库
    Base.metadata.create_all(bind=test_engine)
    yield
    Base.metadata.drop_all(bind=test_engine)

def test_with_db(test_db):
    app.dependency_overrides[get_db] = override_get_db
    # 测试结束后清理
    app.dependency_overrides.clear()

本章小结

pytest + TestClient 是 FastAPI 测试的核心组合。记住:用 fixture 管理测试数据,用 override_get_db 隔离数据库测试。


📌 创作者: Yardon | 🏠 个人网站: GlimmerAI.top

📖 本章是「FastAPI 全栈后端 」系列的第 7 章。下一章:部署与运维

🌟 欢迎大家来观看!

相关推荐
怕浪猫1 小时前
Electron 开发实战(十四):实战项目|从零搭建轻量化桌面代码编辑器
前端·electron·node.js
DS随心转APP1 小时前
Claude 导出对话多方案横向测评来袭,借助 AI 导出鸭对比各类导出工具优劣,筛选最优处理办法
人工智能·ai·chatgpt·deepseek·ai导出鸭
诺***帝1 小时前
GPT-Image-2技术架构深度拆解:2026年图像生成模型全面解析
人工智能·gpt
java_cj1 小时前
从kubectl源码学Cobra:打造专业级Go命令行工具的完整实践
运维·开发语言·后端·云原生·golang·kubernetes·k8s
晓13131 小时前
【Cocos Creator 3.x】篇——第五章 项目实战优化技术
前端·javascript·游戏引擎
chen_zn951 小时前
OpenPi、GR00T的视觉语言模型与动作模型连接方式差异分析总结
人工智能·深度学习·具身智能·vla
有梦想的程序星空1 小时前
【环境配置】使用 Vue CLI 构建 Vue 项目脚手架完整指南
前端·javascript·vue.js
闵孚龙1 小时前
Autograd 自动求导:PyTorch 训练模型的发动机
人工智能·pytorch·python
云和数据.ChenGuang1 小时前
大模型厂商常用的数据库有哪些?
数据库·人工智能·pytorch·深度学习·numpy