Skip to main content

Run and handle the output of multiple executables in pyallel (as in parallel)

Project description

Pyallel

Run and handle the output of multiple executables in pyallel (as in parallel)

https://github.com/Danthewaann/pyallel/assets/22531177/be12efc4-439d-416d-8112-dc57cc4c291a

Requires Python >=3.8

Tested on Linux and MacOS only

Quick start

pyallel can be installed using pip:

pip install pyallel

Once installed, you can run pyallel to see usage information, like so:

usage: pyallel [-h] [-d] [-n] [-s] [-V] [-v] [commands ...]

Run and handle the output of multiple executables in pyallel (as in parallel)

positional arguments:
  commands              list of quoted commands to run e.g "mypy ." "black ."

                        can provide environment variables to each command like so:

                             "MYPY_FORCE_COLOR=1 mypy ."

                        command modes:

                        can also provide modes to commands to do extra things:

                            "tail=10 :: pytest ." <-- only output the last 10 lines, doesn't work in --no-stream mode

options:
  -h, --help            show this help message and exit
  -d, --debug           output debug info for each command
  -n, --non-interactive
                        run in non-interactive mode
  -s, --no-stream       don't stream output of each command
  -V, --verbose         run in verbose mode
  -v, --version         print version and exit

Currently you can provide a variable number of commands to run to pyallel, like so:

[!IMPORTANT] If you need to provide arguments to a command, you must surround the command and it's arguments in quotes!

pyallel "MYPY_FORCE_COLOR=1 mypy ." \
        "black --check --diff ." \
        "tail=20 :: pytest ."

TODOs

  • Allow output for all provided commands to be streamed to stdout (this will require a re-work of how we print command output as we currently just print output once the command finishes)
  • Add CI checks to run the tests and linters against Python versions > 3.8
  • Add command mode arguments to support things like only tailing the last 10 lines of a command whilst it is running e.g. "tail=10 :: pytest ."
  • Add visual examples of pyallel in action
  • Fix bug in non-interactive streamed mode where all commands share the same amount of time taken as the longest running command
  • Fix bug in non-interactive streamed mode where calling readline doesn't account for EOF (if we are at EOF we shouldn't append a newline as more output could be appended to the current line)
  • Fix bug in streamed mode where we should use the number of terminal columns when determining when to truncate the line to fit within the screen (or properly handle wrapped lines)
  • Add custom parsing of command output to support filtering for errors (like vim's errorformat)
  • Add graceful Ctrl-C interrupt handling
  • Add something like a dump mode to print out all the output for a command after it finishes (to combine with the tail mode)
  • Provide a way to set environment variables for each command to run with
  • Allow list of files to be provided to supply as input arguments to each command
  • Allow input to be piped into pyallel via stdin to supply as standard input to each command
  • Add custom config file for pyallel to read from as an alternative to providing arguments via the command line
  • Add support for providing config via a [tool.pyallel] section in a pyproject.toml file in the current working directory
  • Maybe allow command dependencies to be defined in a python file where commands are decorated with info that details it's dependencies?
  • Add test suite
  • Improve error handling when parsing provided commands (check they are valid executables)

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

pyallel-0.7.0.tar.gz (9.0 kB view details)

Uploaded Source

Built Distribution

pyallel-0.7.0-py3-none-any.whl (9.6 kB view details)

Uploaded Python 3

File details

Details for the file pyallel-0.7.0.tar.gz.

File metadata

  • Download URL: pyallel-0.7.0.tar.gz
  • Upload date:
  • Size: 9.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.0

File hashes

Hashes for pyallel-0.7.0.tar.gz
Algorithm Hash digest
SHA256 e31a4408085a621311074a912de6f4f63489f203003a42a66f2d600dfca47d98
MD5 bf18a0cb53480b6b9145acd159e010b2
BLAKE2b-256 6d9718131c205156d062571825de8b53ee26dedeb64b229144b702104448713a

See more details on using hashes here.

File details

Details for the file pyallel-0.7.0-py3-none-any.whl.

File metadata

  • Download URL: pyallel-0.7.0-py3-none-any.whl
  • Upload date:
  • Size: 9.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.0

File hashes

Hashes for pyallel-0.7.0-py3-none-any.whl
Algorithm Hash digest
SHA256 0d0397dcf0711de51770607aabf6b9b655b086bcf0f12177f572919f4e30d7eb
MD5 c60ac205776d1de04cfa5e1a223ebe65
BLAKE2b-256 85a59bb5593a1b2089c7e009aceae4c148c3dadd2fe2957471e0107f5a169a07

See more details on using hashes here.

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