Skip to main content

A tool to enforce architectural patterns in python projects

Project description

Deply

Deply is a static code analysis tool for Python that helps you communicate, visualize and enforce architectural decisions in your projects. You can freely define your architectural layers over classes and which rules should apply to them.

For example, you can use Deply to ensure that modules/packages in your project are truly independent of each other to make them easier to reuse.

Deply can be used in a CI pipeline to make sure a pull request does not violate any of the architectural rules you defined. With the optional Mermaid formatter you can visualize your layers, rules and violations.

Static Badge Static Badge Static Badge Static Badge Static Badge

Documentation

You can find the documentation in the /doc directory or visit the doc page: https://vashkatsi.github.io/deply

Getting Started

You can install Deply via pip:

pip install deply

Once you have installed Deply, you will need to create a configuration file, where you define your layers and communication ruleset. This configuration file is written in YAML and, by default, is stored with the name deply.yaml in your project's root directory.

When you have this file, you can analyse your code by running the analyze command:

deply analyze

# which is equivalent to
deply analyze --config-file=deply.yaml

In order to run Deply you need at least Python 3.8. Supported and tested versions: Python 3.8 to 3.14.

Example Configuration

Here's a simple example of a deply.yaml configuration file:

deply:
  paths:
    - /path/to/your/project

  exclude_files:
    - ".*\\.venv/.*"

  layers:
    - name: models
      collectors:
        - type: class_inherits
          base_class: "django.db.models.Model"

    - name: views
      collectors:
        - type: file_regex
          regex: ".*/views_api.py"

    - name: services
      collectors:
        - type: class_name_regex
          class_name_regex: ".*Service$"

  ruleset:
    views:
      disallow_layer_dependencies:
        - models

Command-Line Usage

# Basic usage
deply analyze

# With a specific config file
deply analyze --config=custom_config.yaml

# Generate a Mermaid diagram
deply analyze --mermaid

# Get help
deply --help

Features

  • Layer-Based Analysis: Define project layers and restrict their dependencies to enforce modularity.
  • Dynamic Layer Configuration: Easily configure collectors for each layer using file patterns, class inheritance, and logical conditions.
  • Cross-Layer Dependency Rules: Specify rules to disallow certain layers from accessing others.
  • Extensible and Configurable: Customize layers and rules for any Python project setup.
  • Mermaid Diagrams: Visualize your architecture and dependencies with Mermaid diagrams.
  • Error Suppression: Suppress specific rule violations with inline comments.

Error Suppression

Deply provides options to suppress rule violations using comments in your code:

# Line-level suppression
user.get()  # deply:ignore:DISALLOW_LAYER_DEPENDENCIES

# File-level suppression (at the top of the file)
# deply:ignore-file:ENFORCE_INHERITANCE

How to Contribute

Feel free to contribute to this project by opening an issue or submitting a pull request! Together, we can make Deply a powerful tool for the Python community.

Running Tests

Use the following commands for local quality checks:

make check
make test
make mutation
make lint
make typing
make security
make pre-commit

Or run unittest directly:

python -m unittest discover tests

Roadmap 🚀

A plan to evolve Deply into a must-have architectural guardian for Python projects:

🔲 Skip violations skip_violations
🔲 Interactive config setup (deply init wizard)
🔲 GitHub Actions/GitLab CI templates
# deply:ignore suppression comments
🔲 Config validation command (deply validate)
✅ Parallel file analysis
✅ Custom collectors system
🔲 Dependency graph caching
🔲 Custom rules system
🔲 FastAPI/Django/Flask presets
🔲 Third-party import restrictions (disallow_external_imports)

Further Documentation

  • Core Concepts - Explains layers, rules and violations in more details.
  • Configuration - Reference for all available settings in a depfile
  • Collectors - Reference for which collectors are available in Deply to define your layers.
  • Rules - Lists the different rule types supported by Deply
  • Mermaid Diagrams - Overview of the diagram generation capabilities
  • Command Line Interface - Advice for using the CLI

License

See the LICENSE file for details.

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

deply-0.8.2.tar.gz (44.0 kB view details)

Uploaded Source

Built Distribution

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

deply-0.8.2-py3-none-any.whl (65.1 kB view details)

Uploaded Python 3

File details

Details for the file deply-0.8.2.tar.gz.

File metadata

  • Download URL: deply-0.8.2.tar.gz
  • Upload date:
  • Size: 44.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.3

File hashes

Hashes for deply-0.8.2.tar.gz
Algorithm Hash digest
SHA256 791749314d6ff037fbb0e893b6ee3da619eb863b5b271c51f497922cad454f41
MD5 1b6d44690ee4013484a0e294c7e72ce3
BLAKE2b-256 3298751126a2ea9af73070690eb7b5718cdd4a501cd7cb3e3342b101b412d976

See more details on using hashes here.

File details

Details for the file deply-0.8.2-py3-none-any.whl.

File metadata

  • Download URL: deply-0.8.2-py3-none-any.whl
  • Upload date:
  • Size: 65.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.3

File hashes

Hashes for deply-0.8.2-py3-none-any.whl
Algorithm Hash digest
SHA256 8d25cddec1468da72c35e262be5b65b8b747a60fcf1de6857124d3a49a428ce3
MD5 0e01fb4069bc43e6178377b484abb38f
BLAKE2b-256 60c9b4340019afef3ba7ba0557dc6de2189c11300cd8cbd3259f1d6b6cf6ad7f

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