Poe the Poet
A batteries included task runner that works well with poetry.
Features
-
β Straight forward declaration of project tasks in your pyproject.toml -
β Tasks are run in poetry's virtualenv (or another env you specify) -
β Shell completion of task names (and global options too for zsh) -
β The poe CLI can be used standalone, or as a plugin for the poetry -
β Tasks can be commands, shell scripts, python expressions, or references to python functions -
β Concise commands with extra arguments passed to the taskpoe [options] task [task_args]
-
β Easily define CLI arguments for your tasks -
β Tasks can specify and reference environment variables, even without a shell -
β Tasks are self documenting, with optional help messages (just runpoe
with no arguments) -
β Tasks can be composed into sequences or DAGs -
β Works with.env
files
Quick start
- Install the Poe the Poet via pipx or another method.
pipx install poethepoet
- Define some tasks in your pyproject.toml
[tool.poe.tasks]
test = "pytest --cov=my_app" # a simple command task
serve.script = "my_app.service:run(debug=True)" # python script based task
tunnel.shell = "ssh -N -L 0.0.0.0:8080:$PROD:8080 $PROD &" # (posix) shell based task
- Run your tasks via the CLI
$ poe test -v tests/unit # extra CLI arguments are appended to the underlying command
Poe => pytest --cov=my_app
...
If you're using poetry, then poe will automatically use CLI tools and libraries from your poetry managed virtualenv without you having to run poetry run
or poetry shell
Poe can also be used without poetry.
Contributing
There's plenty to do, come say hi in the discussions or open an issue!
Also check out the CONTRIBUTING guide