Skip to main content

Enforce Best Practices for all your Airflow DAGs. ⭐

Project description

airflint

pre-commit.ci status test workflow codeql-analysis workflow codecov PyPI version License PyPI - Python Version PyPI version

Enforce Best Practices for all your Airflow DAGs. ⭐

⚠️ airflint is still in alpha stage and has not been tested with real world Airflow DAGs. Please report any issues you face via GitHub Issues, thank you. 🙏

🧑‍🏫 Rules

[^1]: There is a PEP for Lazy Imports targeted to arrive in Python 3.12 which would supersede this rule.

[^2]: To remove top-level imports after running UseFunctionLevelImports rule, use a tool such as autoflake.

based on official Best Practices

🚀 Get started

To install it from PyPI run:

pip install airflint

NOTE: It is recommended to install airflint into your existing airflow environment with all your providers included. This way UseJinjaVariableGet rule can detect all template_fields and airflint works as expected.

Then just call it like this:

usage

pre-commit

Alternatively you can add the following repo to your pre-commit-config.yaml:

  - repo: https://github.com/feluelle/airflint
    rev: v0.3.1-alpha
    hooks:
      - id: airflint
        args: ["-a"]  # Use -a to apply the suggestions
        additional_dependencies:  # Add all package dependencies you have in your dags, preferable with version spec
          - apache-airflow
          - apache-airflow-providers-cncf-kubernetes

To complete the UseFunctionlevelImports rule, please add the autoflake hook after the airflint hook, as below:

  - repo: https://github.com/pycqa/autoflake
    rev: v1.4
    hooks:
      - id: autoflake
        args: ["--remove-all-unused-imports", "--in-place"]

This will remove unused imports.

❤️ Contributing

I am looking for contributors who are interested in..

  • testing airflint with real world Airflow DAGs and reporting issues as soon as they face them
  • optimizing the ast traversing for existing rules
  • adding new rules based on best practices or bottlenecks you have experienced during Airflow DAGs authoring
  • documenting about what is being supported in particular by each rule
  • defining supported airflow versions i.e. some rules are bound to specific Airflow features and version

For questions, please don't hesitate to open a GitHub issue.

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

airflint-0.3.1a0.tar.gz (10.7 kB view details)

Uploaded Source

Built Distribution

airflint-0.3.1a0-py3-none-any.whl (11.8 kB view details)

Uploaded Python 3

File details

Details for the file airflint-0.3.1a0.tar.gz.

File metadata

  • Download URL: airflint-0.3.1a0.tar.gz
  • Upload date:
  • Size: 10.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.13 CPython/3.9.13 Linux/5.13.0-1031-azure

File hashes

Hashes for airflint-0.3.1a0.tar.gz
Algorithm Hash digest
SHA256 8a2d3a60f175ffc621f4e832ecebce8863348b472a90ed0cc1ca941328525c50
MD5 55e81fd6fa6f71de83fc4fe8ff0ff2ff
BLAKE2b-256 4c5ae5649a70e8f864cde791648a491a868616ae390c47bb871093ae59e71e99

See more details on using hashes here.

File details

Details for the file airflint-0.3.1a0-py3-none-any.whl.

File metadata

  • Download URL: airflint-0.3.1a0-py3-none-any.whl
  • Upload date:
  • Size: 11.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.13 CPython/3.9.13 Linux/5.13.0-1031-azure

File hashes

Hashes for airflint-0.3.1a0-py3-none-any.whl
Algorithm Hash digest
SHA256 85eb411a72506df19a4cc8d61687dfbc94807fc26747866bac49432225ae1fcc
MD5 97beeca93e34be1ef7a7d49316a77413
BLAKE2b-256 db6ee7e21d2a8dcacbfd2d0fa6e80a3d203718046b5af18a53f6b425e669b582

See more details on using hashes here.

Supported by

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