Skip to main content

TDD framework for AI workflows - define agent/skill/command standards in .drift.yaml and validate project structure programmatically

Project description

Drift

PyPI version Python 3.10+

Test-driven development for AI workflows - define your standards, validate your project, iterate to compliance.

What It Does

Drift validates your AI agent projects against custom rules you define. No built-in opinions - you write the rules in .drift.yaml, Drift validates against them.

Quick Example

1. Create .drift.yaml with your rules:

rule_definitions:
  claude_md_exists:
    description: "Project must have CLAUDE.md"
    scope: project_level
    phases:
      - name: check_file
        type: file_exists
        file_path: CLAUDE.md
        failure_message: "CLAUDE.md is missing"

2. Run validation:

uvx --from ai-drift drift

3. Fix issues, re-run until green.

That's it. Define standards → validate → fix → iterate.

Installation

Run directly with uv (no installation needed):

uvx --from ai-drift drift

Or install with uv:

uv pip install ai-drift

Common Workflow

# 1. Define your standards in .drift.yaml
# 2. Run validation
uvx --from ai-drift drift

# 3. Generate AI prompts to create missing files
uvx --from ai-drift drift draft --target-rule skill_validation > prompt.md

# 4. Fix issues manually or with AI
# 5. Re-validate until green
uvx --from ai-drift drift

What You Can Validate

Define rules to check:

  • Required files exist (CLAUDE.md, README.md, etc.)
  • Link integrity (no broken file references)
  • YAML frontmatter structure
  • Dependency health (no redundant transitive dependencies)
  • File format compliance (regex patterns)
  • Content quality (with optional LLM-based rules)

Examples: See .drift.yaml in this repo.

Documentation

Development

./test.sh          # Run tests (90%+ coverage required)
./lint.sh          # Run linters
./lint.sh --fix    # Auto-fix formatting

License

MIT

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

ai_drift-0.9.0.tar.gz (103.5 kB view details)

Uploaded Source

Built Distribution

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

ai_drift-0.9.0-py3-none-any.whl (132.7 kB view details)

Uploaded Python 3

File details

Details for the file ai_drift-0.9.0.tar.gz.

File metadata

  • Download URL: ai_drift-0.9.0.tar.gz
  • Upload date:
  • Size: 103.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.12

File hashes

Hashes for ai_drift-0.9.0.tar.gz
Algorithm Hash digest
SHA256 dcff8fc852fbe8f65fe92e00788ca86b88f2b14f9157e3d0eb41209b3a677a16
MD5 aa0ab0355086262deb2478fa660fe567
BLAKE2b-256 444a51fc6270e5c14843caad9c7eb42b5ea105bba3777ef20c8ea0b20d599895

See more details on using hashes here.

File details

Details for the file ai_drift-0.9.0-py3-none-any.whl.

File metadata

  • Download URL: ai_drift-0.9.0-py3-none-any.whl
  • Upload date:
  • Size: 132.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.12

File hashes

Hashes for ai_drift-0.9.0-py3-none-any.whl
Algorithm Hash digest
SHA256 f0cceda29af5d10dccb1792de3e835576421ebd1b145f0f0bbc9922a5ed4d759
MD5 736e0e2dca0e0f444898f57751e8248b
BLAKE2b-256 7ff96e8881d6089f14dde24268beaeb56317e097088e8af6f8c5152ec503401b

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