Skip to main content

Execute pipelines based on files and containers.

Project description

Proceed

Declarative file processing with YAML and containers.

Proceed is a Python library and CLI tool for declarative batch processing. It reads a pipeline specification declared in YAML. A pipeline contains a list of steps that are based on Docker images and containers.

Each pipeline execution accepts values for declared args, allowing controlled, explicit configuration of steps at runtime. Each execution produces an execution record that accounts for accepted arg values, step logs, and checksums of input and output files.

Hopefully, Proceed will allow you to express everything you need to know about your processing pipeline in a "nothing up my sleeves" way. The pipeline specification should be complete enough to share with others who have Proceed and Docker installed. The execution record should allow for auditing of expected outcomes and reproducibility.

docs

Here are the main docs for Proceed.

Installation

Proceed requires Python and Docker to be installed. With those, it should be able to run a wide variety pipelines and steps via containers.

pip

Proceed itself is available on PyPI. This is the recommended way to install Proceed:

$ pip install proceed

git and pip

You can also install Proceed from source.

$ pip install git+https://https://github.com/benjamin-heasly/proceed.git

# editable mode
$ git checkout https://github.com/benjamin-heasly/proceed.git
$ pip install -e ./proceed

check installation

You can check if Proceed installed correctly using the proceed command.

$ proceed --version
Proceed x.y.z

$ proceed --help
usage etc...

development and testing

You can set up a development environment with conda and dev-environment.yml.

conda env create -f dev-environment.yml
# or
conda env update -f dev-environment.yml

With that, you should be able to run through the Proceed unit and integration tests.

conda activate proceed-dev
hatch run test:cov

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

proceed-0.1.3.tar.gz (44.1 kB view details)

Uploaded Source

Built Distribution

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

proceed-0.1.3-py3-none-any.whl (28.5 kB view details)

Uploaded Python 3

File details

Details for the file proceed-0.1.3.tar.gz.

File metadata

  • Download URL: proceed-0.1.3.tar.gz
  • Upload date:
  • Size: 44.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: Hatch/1.17.0 {"ci":true,"cpu":"x86_64","distro":{"id":"noble","libc":{"lib":"glibc","version":"2.39"},"name":"Ubuntu","version":"24.04"},"implementation":{"name":"CPython","version":"3.12.3"},"installer":{"name":"hatch","version":"1.17.0"},"openssl_version":"OpenSSL 3.0.13 30 Jan 2024","python":"3.12.3","system":{"name":"Linux","release":"6.17.0-1018-azure"}} HTTPX2/2.4.0

File hashes

Hashes for proceed-0.1.3.tar.gz
Algorithm Hash digest
SHA256 e02927739ad8e7a9348f7807bf05bc07a45f6357ba304dda84ff1557ee4275cc
MD5 069c2c745f9eb429f4706c1555f5b581
BLAKE2b-256 4441e4dae4a24e8a90e9c5a18770bf037bc736f7e01da8701c9f13973b0bb3e8

See more details on using hashes here.

File details

Details for the file proceed-0.1.3-py3-none-any.whl.

File metadata

  • Download URL: proceed-0.1.3-py3-none-any.whl
  • Upload date:
  • Size: 28.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: Hatch/1.17.0 {"ci":true,"cpu":"x86_64","distro":{"id":"noble","libc":{"lib":"glibc","version":"2.39"},"name":"Ubuntu","version":"24.04"},"implementation":{"name":"CPython","version":"3.12.3"},"installer":{"name":"hatch","version":"1.17.0"},"openssl_version":"OpenSSL 3.0.13 30 Jan 2024","python":"3.12.3","system":{"name":"Linux","release":"6.17.0-1018-azure"}} HTTPX2/2.4.0

File hashes

Hashes for proceed-0.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 3c98cb0edc69c40bd86fb06d6ababa336ba443e60f366729a12e24d293b2c614
MD5 a363407112b06d7eb8d3082e13f130d1
BLAKE2b-256 8c8d1571337a957bdfcdf0ad6674d8b496d63e6c7c882ba816e68c57af012454

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