@zemerik/task-runner
v1.0.4
Published
A fast and flexible CLI task runner for managing development workflows
Maintainers
Readme
Task Runner
A fast and flexible CLI task runner for managing development workflows. Built in Rust for maximum performance and reliability.
Features
- ⚡ 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 with variable expansion
- 🔄 Variable Expansion - Use
${VAR}or$VARsyntax in commands and paths - ⏱️ Timeout Support - Set timeouts for long-running tasks
- 🛡️ Error Handling - Robust error handling with continue-on-error options
Installation
From NPM (Recommended)
npm install -g task-runnerFrom Source
# Clone the repository
git clone https://github.com/Zemerik/task-runner.git
cd task-runner
# Build and install
cargo build --release
cargo install --path .Quick Start
- 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 deployConfiguration
Task Runner supports multiple configuration file formats:
task-runner.json(JSON)task-runner.yamlortask-runner.yml(YAML)task-runner.toml(TOML)
Configuration Structure
{
"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
}
}
}Environment Variable Expansion
Task Runner supports environment variable expansion in command strings and working directory paths. You can use either ${VAR} or $VAR syntax:
{
"env": {
"NODE_ENV": "production",
"PORT": "3000",
"BUILD_DIR": "./dist"
},
"tasks": {
"build": {
"commands": [
"npm run build -- --out-dir ${BUILD_DIR}",
"echo Server will run on port $PORT"
],
"working_dir": "${BUILD_DIR}/src"
}
}
}Environment variables are expanded in the following order:
- System environment variables
- Global
envfrom configuration - Task-specific
env(task env overrides global env)
Variables are expanded in:
- Command strings
- Working directory paths (
working_diranddefault_working_dir)
Task Properties
| Property | Type | Description |
|----------|------|-------------|
| description | string | Human-readable task description |
| commands | string[] | Commands to execute (supports ${VAR} and $VAR expansion) |
| 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 (supports variable expansion) |
| timeout | number | Timeout in seconds |
| continue_on_error | boolean | Continue if commands fail |
| hidden | boolean | Hide from task list |
Usage
Commands
List Tasks
# List all tasks
task-runner list
# List with details
task-runner list --detailsRun Tasks
# 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-errorTask Information
# Show task details
task-runner info buildValidate Configuration
# Validate config file
task-runner validateOptions
| Option | Description |
|--------|-------------|
| --config, -c | Specify configuration file path |
| --verbose, -v | Enable verbose output |
| --env, -e | Set environment for task execution |
Examples
Frontend Development Workflow
{
"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"
]
}
}
}Full-Stack Development
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: "."Error Handling
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
Performance
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
Contributing
- Fork the repository
- Create a feature branch
- Make your changes
- Add tests
- Submit a pull request
License
MIT License - see LICENSE file for details.
