Skip to main content

A pipen cli plugin to check requirements for processes of a pipeline

Project description

pipen-cli-require

Checking the requirements for processes of a pipen pipeline

Install

pip install -U pipen-cli-require

Usage

Defining requirements of a process

# example_pipeline.py
from pipen import Pipen, Proc

class P1(Proc):
    """Process 1

    Requires:
        pipen: Run `pip install -U pipen` to install
          - check: |
            {{proc.lang}} -c "import pipen"
        liquidpy: Run `pip install -U liquidpy` to install
          - check: |
            {{proc.lang}} -c "import liquid"
        nonexist: Run `pip install -U nonexist` to install
          - check: |
            {{proc.lang}} -c "import nonexist"
        conditional:
          - if: {{envs.require_conditional}}
          - check:
            {{proc.lang}} -c "import optional"

    """
    input = "a"
    output = "outfile:file:out.txt"
    envs = {"require_conditional": False}
    lang = "python"

# Setup the pipeline
# Must be outside __main__
# Or define a function to return the pipeline
class Pipeline(Pipen):
    starts = P1


if __name__ == '__main__':
    # Pipeline must run with __main__
    Pipeline().run()

Parsing process requirements using API

from pipen_cli_require import parse_proc_requirements


def parse_proc_requirements(
    proc: Type[Proc]
) -> Tuple[OrderedDiot, OrderedDiot]:
    """Parse the requirements of a process

    Args:
        proc: The process class

    Returns:
        A tuple of two OrderedDiot's.
        The first one is the annotated sections by pipen_annotate
        The second one is the requirements. The key is the name of the
            requirement, the value is a dict with message, check and if_ keys.
    """

Checking the requirements via the CLI

> pipen require --verbose --ncores 2 -p example_pipeline.py:pipeline

Checking requirements for pipeline: PIPEN-0
│
└── P1: Process 1
    ├──  pipen
    ├──  liquidpy
    ├──  nonexist: Run `pip install -U nonexist` to install
       └── Traceback (most recent call last):
             File "<string>", line 1, in <module>
           ModuleNotFoundError: No module named 'nonexist'
        └──  conditional (skipped by if-statement)

Checking requirements with runtime arguments

For example, when I use a different python to run the pipeline:

Add this to the head of example_pipeline.py:

import pipen_args

See also tests/pipen_args_pipeline.py

Then specify the path of the python to use:

pipen require example_pipeline.py:pipeline --P1.lang /path/to/another/python

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

pipen_cli_require-1.0.3.tar.gz (5.7 kB view details)

Uploaded Source

Built Distribution

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

pipen_cli_require-1.0.3-py3-none-any.whl (6.5 kB view details)

Uploaded Python 3

File details

Details for the file pipen_cli_require-1.0.3.tar.gz.

File metadata

  • Download URL: pipen_cli_require-1.0.3.tar.gz
  • Upload date:
  • Size: 5.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.3.2 CPython/3.12.3 Linux/6.17.0-1008-azure

File hashes

Hashes for pipen_cli_require-1.0.3.tar.gz
Algorithm Hash digest
SHA256 0f1663bbb7705a6bc15c7b4bb76f0cf72b3da7d2ebe1c9100d3af9c6b1663e68
MD5 8355445ec3e8332bf646c0f2dd5300ef
BLAKE2b-256 d3f8ad25845f7b424461db5ac6a7333551868dc54d3ce7771391409166e25100

See more details on using hashes here.

File details

Details for the file pipen_cli_require-1.0.3-py3-none-any.whl.

File metadata

  • Download URL: pipen_cli_require-1.0.3-py3-none-any.whl
  • Upload date:
  • Size: 6.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.3.2 CPython/3.12.3 Linux/6.17.0-1008-azure

File hashes

Hashes for pipen_cli_require-1.0.3-py3-none-any.whl
Algorithm Hash digest
SHA256 6700b5e603e504aa7dc4cbf70f65f3e2d8b30d387810dfa9fff713c804dff2af
MD5 2ee4158555094bc56de2354adc83f39c
BLAKE2b-256 8775b0e6d5d30da5a83a7f8619bf9bd36b2d12e90bdfb062fcb5174030c0475b

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