Skip to main content

Modular Pipeline Library

Project description

Modular Pypeline Library

python build-and-test-module coverage publish-documentation version package downloads Checked with mypy linting: pylint Code style: black

What is MPyL?

MPyL stands for Modular Pipeline Library (in Python).

This library is loosely based on the principles described in https://www.jenkins.io/blog/2019/01/08/mpl-modular-pipeline-library/ but completely independent of Jenkins or any other CI/CD platform.

🔖 Documentation

Detailed, complete, searchable documentation can be found at https://vandebron.github.io/mpyl

📚 Principles

MPyL is built with the following principles in mind.

  • Not a platform It is not tied to any CI/CD platform. MPyL is a library, not a framework. It is not a runner, not a scheduler, and it doesn't have a GUI. It can be plugged into any CI/CD platform. Execution flows for Jenkins or Dagster are included as an example.
  • Minimal footprint: It is self-contained and has very few external dependencies (e.g. Git, Docker). It can be run anywhere, also on your local machine.
  • Accessible and maintainable
    • Written in Python, the most widely adopted scripting language with an extensive amount of client libraries relevant to CI/CD.
    • Strongly typed: MyPy type hints and schemas for all YAML files. Clearly defined interfaces for inputs and outputs of steps.
    • Focus on short feedback loop. Unit testable and everything can be run locally.
  • Self documented by docstrings in the code, descriptions in the schemas and explanations in the CLI.
  • Python as YAML templating engine Attempts to mix markup and logic tend to have a worst of both worlds outcome. MPyL uses YAML strictly for configuration. Where YAML needs to produced dynamically, like for CRDs via HELM charts, it is generated by Python code. The produced YAML is validated against the corresponding schemas.
  • Extensible Support for the most common use cases (e.g. Docker, Helm, Kubernetes, AWS, etc.) is built-in. But it is easy to extend with your own mpyl.steps.

💻 Technologies

Requirements

The following technologies are expected to be present on the local OS:

Bundled

MPyL is extensible and has a minimal footprint. Having said that, batteries for the following technologies are included.

CI/CD
Build
  • Docker mpyl.steps.build.dockerbuild
  • Scala (SBT) mpyl.steps.build.sbt
  • Jenkins mpyl.cli.commands.build.jenkins and mpyl.utilities.jenkins.runner.JenkinsRunner
Testing
  • Junit mpyl.steps.models.ArtifactType.JUNIT_TESTS
Deployment
  • K8S mpyl.steps.deploy.kubernetes
  • Helm mpyl.steps.deploy.k8s.helm
Reporting
  • Jira mpyl.reporting.targets.jira
  • Github mpyl.reporting.targets.github
  • Slack mpyl.reporting.targets.slack

Project details


Release history Release notifications | RSS feed

This version

1.3.1

Download files

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

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

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

mpyl-1.3.1-py3-none-any.whl (241.9 kB view details)

Uploaded Python 3

File details

Details for the file mpyl-1.3.1-py3-none-any.whl.

File metadata

  • Download URL: mpyl-1.3.1-py3-none-any.whl
  • Upload date:
  • Size: 241.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.9.18

File hashes

Hashes for mpyl-1.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 cff12c2635216e3324186ea2fa2c9d7f1a5395f8dea545e3d2b2596e33cf7d99
MD5 7bdcbdc3e23d689c2a566880452a96ea
BLAKE2b-256 e2bc8e5f84442e4b9f82bc95fde3d91037e8506aa8216ec8624650039c2ea250

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