A Task Runner written in Python.
pyTaskify
is a pure Python task runner for automating repetitive tasks in projects.
pyTaskify
is available on PyPi
. Install the package with
pip install pytaskify
Check that the installation was done correctly by checking the version with the --version
argument
taskify --version
To use pyTaskify
, execute the taskify
command with the appropriate arguments. For example, to run the build task:
taskify build
You can also pass arguments to the task. For example, to run the test
task with the --verbose
argument:
taskify test --verbose
You can configure pyTaskify
by creating a taskify.yml
file in the root directory of your project. This file should contain a list of tasks with their respective configurations.
Here's an example taskify.yml
file:
version: 1
tasks:
build:
cmds:
- rm -rf build
- mkdir build
- cd build && cmake .. && make
env:
CFLAGS: -O3
LDFLAGS: -lm
continue_on_error: true
check: true
test:
cmd: ./build/tests --verbose={verbose}
args:
verbose:
is_flag: true
alias:
- -v
- --verbose
In this example, we have defined two tasks: build
and test
.
The build
task has a list of commands that will be executed in order, and some environment variables that will be set before the commands are run. The continue_on_error
flag is set to true
, which means that if one of the commands fails, the remaining commands will still be executed. The check
flag is set to true
, which means that if one of the commands fails, the program will exit with a non-zero status code.
The test
task has a single command, which takes a verbose
argument. The args
dictionary defines the verbose
argument, which is a flag with the -v
and --verbose
alias. The continue_on_error
flag is set to false
, which means that if the command fails, the program will exit with a non-zero status code. The check
flag is set to true
, which means that if the command fails, the program will exit with a non-zero status code.
pyTaskify
recognizes a variety of file names that can contain task configurations. These include:
taskify.yml
taskify.yaml
You can define environment variables that will be available to all tasks by adding them to the env
section of the taskify.yml
file.
version: 1
env:
FOO: bar
tasks:
default:
cmd: echo taskify
You can also define environment variables for a specific task by adding them to the env
section of the task configuration.
version: 1
tasks:
default:
cmd: echo taskify
env:
FOO: bar
If you use both forms simultaneously, task environment variables will overwrite those previously declared.
version: 1
env:
FOO: bar
tasks:
default:
cmd: echo taskify
env:
FOO: foobar
pyTaskify
lets you import modules and use their functions in your task commands. This can be helpful for organizing your tasks and avoiding code repetition.
version: 1
modules:
foo: ./foo
bar: ./bar
The pyTaskify
configuration file allows defining tasks with arguments. Arguments can be used in task commands and can have default values or be marked as required.
These arguments can be used in task commands by using the curly brace syntax {arg_name}
to reference the argument in the command.
A task argument can have the following properties:
-
is_flag
(optional): If set to True, the argument is treated as a flag and does not require a value. Defaults to False. -
required
(optional): If set to True, the argument is marked as required and must be provided when calling the task. Defaults to False. -
default
(optional): The default value for the argument. If the argument is not provided, this value will be used instead. If the argument is a flag, the value should be True or False. Defaults to None. -
alias
(required): A list of aliases for the argument. Aliases can be used in place of the argument name in the task command. -
placeholder
(optional): The placeholder value for the argument in the task command. This field serves as a mask for the argument, using the{value}
braces syntax, the argument entry is replaced by the Placeholder and then in the command. Defaults to a string{value}
.
version: 1
tasks:
foo:
cmd: echo foo {verbose}
args:
verbose:
is_flag: true
placeholder: --verbose
alias:
- -v
bar:
cmd: echo bar {color}
args:
color:
placeholder: --color={value}
default: red
alias:
- -c
foobar:
cmd: echo foobar {color} {size}
args:
color:
placeholder: --color={value}
required: true
alias:
- -c
size:
placeholder: --size={value}
alias:
- -s
pytaskify foobar -c blue
pytaskify foobar -c blue -s large
version: 1
tasks:
mytask:
cmd: echo {myarg}
args:
myarg:
required: true
alias:
- -m
- --myarg
placeholder: --myarg={value}
default: 'foo'
pytaskify mytask --myarg bar
You can define dependencies between your tasks with pyTaskify
. When you run a task, its dependencies will be executed first, if any, the dependency entry is an array.
version: 1
tasks:
build:
cmd: python build.py
deploy:
deps:
- build
cmd: python deploy.py ./dist
pyTaskify
lets you define commands for your tasks. These commands can be shell commands, Python scripts, or even other tasks. pyTaskify
only accepts 1 type of command per task, you must define only 1 between cmd
, cmds
, task
and tasks
.
version: 1
tasks:
calling_command:
cmd: echo "Foobar" {FOO}
args:
FOO:
alias: -f
calling_commands:
cmds:
- echo "Step 1"
- echo "Step 2"
calling_task:
task:
name: calling_command
calling_tasks:
tasks:
- name: calling_command
args:
FOO: bar
Sometimes it can be useful to ignore errors and continue executing tasks. pyTaskify
supports this with the continue_on_error
option.
version: 1
tasks:
calling_commands:
cmds:
- echo "Step 1"
- exit 1
- echo "Step 3"
continue_on_error: true
If check is true, and the process exits with a non-zero exit code, a CalledProcessError exception will be raised. Attributes of that exception hold the arguments, the exit code, and stdout and stderr if they were captured.
version: 1
tasks:
calling_commands:
cmds:
- echo "Step 1"
- echo "Step 2"
check: true
Feel free to post an issue about any bugs you find, or to ask any questions!
This project uses the Python subprocess to execute the commands, see the documentation if you need to clarify any doubts!
Inside the project folder you can run the command.
git clone https://github.com/AlisonVilela/pyTaskify.git
cd pyTaskify
pip install -r requirements.txt
python .\pytaskify\cli.py --version
We follow Google Python Style Guide to maintain a good quality of code written, please read carefully to write correctly to keep the code organized and clean.
We use PyLint to keep the code organized. Make sure your IDE is respecting the .editorconfig
file, you may need to install a plugin or extension.
To check for programming errors, bugs, stylistic errors and suspicious constructions you can run the command:
python .\pytaskify\cli.py lint
python .\pytaskify\cli.py test
Feel free to use any IDE, but we do recommend VS Code.
If you want to contribute to pyTaskify
, follow these steps:
- Fork this repository
- Create a new branch (
git checkout -b my-new-feature
) - Make your changes and commit (
git commit -am 'I added a new feature'
) - Push to the branch (
git push origin my-new-feature
) - Open a Pull Request
- Unit Tests
- Github workflow
- Github issue template
- Do not allow tasks with required arguments to be added as a dependency of another task, or allow passing the necessary arguments
- Dotenv file support
- Parallel execution of tasks
- Task timeout
- Dynamic variables
- Forwarding CLI arguments to commands
- Task status to prevent unnecessary work
- Platform specific tasks and commands
- Dry run mode
- Watch tasks
See CHANGELOG for a list of changes.
This project is licensed under the MIT License - see the LICENSE file for details.
This project was inspired by Task written in Go.
If you rely on pytask to manage your research project, please cite it with the following key to help others to discover the tool.
@Unpublished{Vilela2023,
Title = {A Task Runner written in Python.},
Author = {Alison Vilela},
Year = {2023},
Url = {https://github.com/AlisonVilela/pyTaskify}
}