A fast and flexible CLI task runner for managing development workflows. Built in Rust for maximum performance and reliability.
- β‘ Fast Execution - Built in Rust for optimal performance
- π Parallel & Sequential - Run tasks in parallel or sequentially
- π Dependency Management - Automatic dependency resolution
- π¨ Rich Output - Beautiful, colored terminal output with progress indicators
- π Multiple Formats - Support for JSON, YAML, and TOML configuration
- π§ Environment Variables - Per-task and global environment configuration
- β±οΈ Timeout Support - Set timeouts for long-running tasks
- π‘οΈ Error Handling - Robust error handling with continue-on-error options
npm install -g task-runner
# Clone the repository
git clone https://github.com/Zemerik/task-runner.git
cd task-runner
# Build and install
cargo build --release
cargo install --path .
- Create a configuration file (
task-runner.json
):
{
"env": {
"NODE_ENV": "development"
},
"tasks": {
"dev": {
"description": "Start development environment",
"commands": [
"npm run build:watch",
"npm run server:dev",
"npm run test:watch"
],
"parallel": true
},
"build": {
"description": "Build for production",
"dependencies": ["clean"],
"commands": [
"npm run compile",
"npm run bundle",
"npm run optimize"
]
},
"deploy": {
"description": "Deploy to production",
"dependencies": ["build", "test"],
"commands": [
"npm run deploy:staging",
"npm run health-check",
"npm run deploy:prod"
],
"env": {
"NODE_ENV": "production"
}
}
}
}
- Run tasks:
# List available tasks
task-runner list
# Run a single task
task-runner run build
# Run multiple tasks in parallel
task-runner run dev --parallel
# Run with dependencies
task-runner run deploy
Task Runner supports multiple configuration file formats:
task-runner.json
(JSON)task-runner.yaml
ortask-runner.yml
(YAML)task-runner.toml
(TOML)
{
"env": {
"GLOBAL_VAR": "value"
},
"default_timeout": 300,
"default_working_dir": "./src",
"tasks": {
"task-name": {
"description": "Task description",
"commands": ["command1", "command2"],
"dependencies": ["other-task"],
"env": {
"TASK_VAR": "value"
},
"parallel": false,
"sequential": true,
"working_dir": "./custom/path",
"timeout": 60,
"continue_on_error": false,
"hidden": false
}
}
}
Property | Type | Description |
---|---|---|
description |
string | Human-readable task description |
commands |
string[] | Commands to execute |
dependencies |
string[] | Tasks that must run before this task |
env |
object | Environment variables for this task |
parallel |
boolean | Run commands in parallel |
sequential |
boolean | Run commands sequentially |
working_dir |
string | Working directory for task execution |
timeout |
number | Timeout in seconds |
continue_on_error |
boolean | Continue if commands fail |
hidden |
boolean | Hide from task list |
# List all tasks
task-runner list
# List with details
task-runner list --details
# Run a single task
task-runner run build
# Run multiple tasks
task-runner run build test deploy
# Run in parallel
task-runner run build test --parallel
# Run sequentially
task-runner run build test --sequential
# Continue on error
task-runner run build test --continue-on-error
# Show task details
task-runner info build
# Validate config file
task-runner validate
Option | Description |
---|---|
--config, -c |
Specify configuration file path |
--verbose, -v |
Enable verbose output |
--env, -e |
Set environment for task execution |
{
"tasks": {
"dev": {
"description": "Start development server",
"commands": [
"npm run dev",
"npm run storybook"
],
"parallel": true
},
"build": {
"description": "Build for production",
"dependencies": ["clean"],
"commands": [
"npm run build",
"npm run test:ci"
]
},
"deploy": {
"description": "Deploy to staging",
"dependencies": ["build"],
"commands": [
"npm run deploy:staging"
]
}
}
}
env:
NODE_ENV: development
DATABASE_URL: postgresql://localhost/dev
tasks:
backend:
description: Start backend server
commands:
- "cargo run"
- "cargo test --watch"
parallel: true
working_dir: "./backend"
frontend:
description: Start frontend development
commands:
- "npm run dev"
- "npm run test:watch"
parallel: true
working_dir: "./frontend"
dev:
description: Start full development environment
dependencies: ["backend", "frontend"]
commands: []
test:
description: Run all tests
commands:
- "cargo test"
- "npm run test"
working_dir: "."
Task Runner provides comprehensive error handling:
- Task not found: Clear error message with available tasks
- Circular dependencies: Detection and reporting of dependency cycles
- Command failures: Detailed error output with exit codes
- Configuration errors: Validation with helpful error messages
Built in Rust, Task Runner is designed for speed:
- Fast startup: Minimal overhead for task execution
- Efficient parallelization: Optimal use of system resources
- Memory efficient: Low memory footprint even with many tasks
- Cross-platform: Native binaries for Windows, macOS, and Linux
- Fork the repository
- Create a feature branch
- Make your changes
- Add tests
- Submit a pull request
MIT License - see LICENSE file for details.
- π Documentation
- π Issues
- π¬ Discussions