Skip to main content

AURA: an automated dependency update agent that searches for safe modernized requirements using your existing validation.

Project description

AURA: Automated Updater and Restoration Agent aura-dep-agent is a Python tool that helps you safely modernize your project’s dependencies. It can also be used to maintain your dependencies in the long run and does not probe or open a PR like Dependabot; it only commits changes when the update passes your validation tests.

You give it a repository and a validation entry point (a Python script or a pytest suite). AURA then searches for newer dependency versions that still pass your validation. If an update breaks your validation, AURA does not submit that change.

Installation: pip install aura-dep-agent This installs the aura command-line tool.

Quick start: Go to your project repo cd /path/to/your-project

Make sure you have:

a requirements.txt file

either:

a Python script you can run with python your_script.py, or

a pytest test suite (for example, a tests/ folder)

Run the AURA initializer:

aura init
The wizard will:

    detect whether your project is an installable package or not

    ask how to run your validation (script path or pytest target)

    ask which Python version to use in CI

    generate:

        dependency_agent.py in your repo

        .github/workflows/aura.yml GitHub Actions workflow

Commit and push:

git add dependency_agent.py .github/workflows/aura.yml
git commit -m "Add AURA dependency agent"
git push
Run AURA in GitHub Actions

In your GitHub repo, go to the Actions tab.

Find the “AURA Speed Run” workflow.

Click “Run workflow” to start your first run.

AURA will run your validation as it explores dependency updates and only keep an update when your validation still passes.

How it works (high level): dependency_agent.py contains a configuration dictionary (AGENT_CONFIG) for your repository and a small runner that calls the AURA dependency agent.

The GitHub Actions workflow:

sets up Python

installs aura-dep-agent

runs dependency_agent.py    

The AURA agent:

proposes candidate dependency upgrades

runs your validation for each candidate

writes a summary log (for example, aura_ua_execution.log)

can commit and push a modernized requirements.txt when validation passes.

Requirements and limitations:

Requires Python 3.10+ (3.10 or 3.11 recommended).

Requires a working requirements.txt.

Requires an existing validation entry point (script or pytest); AURA does not
automatically generate full test suites.

License: This project is licensed under the 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

aura_dep_agent-0.1.1.tar.gz (21.9 kB view details)

Uploaded Source

Built Distribution

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

aura_dep_agent-0.1.1-py3-none-any.whl (22.6 kB view details)

Uploaded Python 3

File details

Details for the file aura_dep_agent-0.1.1.tar.gz.

File metadata

  • Download URL: aura_dep_agent-0.1.1.tar.gz
  • Upload date:
  • Size: 21.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.11

File hashes

Hashes for aura_dep_agent-0.1.1.tar.gz
Algorithm Hash digest
SHA256 12beb6f62845fc726ca12d8eddb6845cc7bb419c304b2b6e491414b0900cbdaa
MD5 f1a6733a2221fcf5c4e793d0e9f3573b
BLAKE2b-256 2dfe83b6257ecda930f44a8737a01f8c4897a67c16f086eed2f13186864b48c5

See more details on using hashes here.

File details

Details for the file aura_dep_agent-0.1.1-py3-none-any.whl.

File metadata

  • Download URL: aura_dep_agent-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 22.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.11

File hashes

Hashes for aura_dep_agent-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 9054a45f7568e8f1c77f43bae22d79289cd438fb742765439ed06db968e412be
MD5 3136dbc480dbc90196622b9a35220a5b
BLAKE2b-256 d8e959fab24c2da2f21f6cf910f8d29c9cce192ff38de0322e215539965ecb28

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