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

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. Examples of CI/CD flows in Jenkins or Dagster are included.
  • Minimal footprint: It is self-contained and has very few external dependencies (e.g. Git, Docker or HELM). It can be run anywhere, also on your local machine.
  • Accessible and maintainable
    • Written in Python, probably the most widely adopted scripting language.
    • 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. Te 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

Download files

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

Source Distribution

mpyl-0.0.25.linux-x86_64.tar.gz (92.6 kB view hashes)

Uploaded Source

Built Distributions

mpyl-0.0.25-py3.9.egg (116.9 kB view hashes)

Uploaded Source

mpyl-0.0.25-py3-none-any.whl (124.2 kB view hashes)

Uploaded Python 3

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