Skip to main content

基于交互模式的现代化测试自动化框架,支持多种测试场景

Project description

DF Test Framework

简单、强大、可扩展的现代化 Python 测试自动化框架

PyPI version Python License


核心特性

v4.0.0 全面异步化 - 性能飞跃 🚀

  • AsyncHttpClient - 异步 HTTP 客户端,并发性能提升 10-30 倍
  • AsyncDatabase - 异步数据库客户端,基于 SQLAlchemy 2.0 AsyncEngine
  • AsyncRedis - 异步 Redis 客户端,缓存操作提升 5-10 倍
  • AsyncAppActions - 异步 UI 测试,Playwright 异步 API,性能提升 2-3 倍
  • 完全向后兼容 - 同步 API 完整保留,升级路径平滑

完整功能

  • HTTP 客户端 - 同步/异步,拦截器链,自动重试
  • GraphQL/gRPC 客户端 - 完整协议支持
  • 数据库访问 - SQLAlchemy 2.0,Repository + UnitOfWork 模式
  • 消息队列 - Kafka/RabbitMQ/RocketMQ 统一接口
  • 存储客户端 - LocalFile/S3/阿里云 OSS
  • 可观测性 - OpenTelemetry 追踪 + Prometheus 监控
  • 测试工具 - Fixtures、数据构建器、Mock 工具、Allure 集成

安装

# 使用 uv(推荐 - 更快更可靠)
uv add df-test-framework

# 使用 pip
pip install df-test-framework

# 可选依赖
uv add "df-test-framework[ui]"            # UI 测试(Playwright)
uv add "df-test-framework[mq]"            # 消息队列
uv add "df-test-framework[observability]" # 可观测性
uv add "df-test-framework[storage]"       # 存储客户端
uv add "df-test-framework[all]"           # 所有功能

快速开始

脚手架创建项目

df-test init my-test-project
cd my-test-project
cp .env.example .env
pytest -v

手动使用

from df_test_framework import Bootstrap, FrameworkSettings
from pydantic import Field

class DemoSettings(FrameworkSettings):
    api_base_url: str = Field(default="https://api.example.com")

runtime = (
    Bootstrap()
    .with_settings(DemoSettings)
    .build()
    .run()
)

http = runtime.http_client()
response = http.get("/users/1")
assert response.status_code == 200

异步高性能模式

import asyncio
from df_test_framework import AsyncHttpClient

async def test_concurrent():
    async with AsyncHttpClient("https://api.example.com") as client:
        tasks = [client.get(f"/users/{i}") for i in range(100)]
        responses = await asyncio.gather(*tasks)
        assert len(responses) == 100

asyncio.run(test_concurrent())

架构

Layer 4 ─── bootstrap/          # 引导层:Bootstrap、Providers、Runtime
Layer 3 ─── testing/ + cli/     # 门面层:Fixtures、CLI 工具、脚手架
Layer 2 ─── capabilities/       # 能力层:HTTP/UI/DB/MQ/Storage
Layer 1 ─── infrastructure/     # 基础设施:config/logging/events/plugins
Layer 0 ─── core/               # 核心层:纯抽象(无依赖)
横切 ───── plugins/             # 插件:MonitoringPlugin、AllurePlugin

文档

完整文档请访问 GitHub 仓库


许可证

MIT License

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

df_test_framework-4.4.2.tar.gz (2.5 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

df_test_framework-4.4.2-py3-none-any.whl (725.5 kB view details)

Uploaded Python 3

File details

Details for the file df_test_framework-4.4.2.tar.gz.

File metadata

  • Download URL: df_test_framework-4.4.2.tar.gz
  • Upload date:
  • Size: 2.5 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for df_test_framework-4.4.2.tar.gz
Algorithm Hash digest
SHA256 9e14f5d3da3b0b87742e2fa6d85f47541a976bbe6d453bdbf5a4b3806453b3c0
MD5 88bcb831dbf3dfaabe28f7df57989fe0
BLAKE2b-256 bb19f1aebf1245763550b1a9b870fa16cf845529b2fe8f73544937a08d4971d8

See more details on using hashes here.

File details

Details for the file df_test_framework-4.4.2-py3-none-any.whl.

File metadata

File hashes

Hashes for df_test_framework-4.4.2-py3-none-any.whl
Algorithm Hash digest
SHA256 e016b45766b06fc4ffcbc551e1077ba02b50874a22a234385075d939337fb33d
MD5 14efd120c2bebc63a8b40de81bd84ae4
BLAKE2b-256 529356917d0be6a74e8dfeb8c02bb9cb0034c3fd8e0180381d7f98bcb8dca6a9

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page