cronlint
by @suhteevah
Scheduled task & cron job anti-pattern analyzer -- detects overlapping execution risks, timezone scheduling errors, missing error recovery, resource contenti...
clawhub install cronlintπ About This Skill
name: CronLint version: 1.0.0 description: "Scheduled task & cron job anti-pattern analyzer -- detects overlapping execution risks, timezone scheduling errors, missing error recovery, resource contention, lifecycle management issues, and observability gaps in cron jobs, schedulers, and periodic task code" homepage: https://cronlint.pages.dev metadata: { "openclaw": { "emoji": "\u23f0", "primaryEnv": "CRONLINT_LICENSE_KEY", "requires": { "bins": ["git", "bash", "python3", "jq"] }, "configPaths": ["~/.openclaw/openclaw.json"], "install": [ { "id": "lefthook", "kind": "brew", "formula": "lefthook", "bins": ["lefthook"], "label": "Install lefthook (git hooks manager)" } ], "os": ["darwin", "linux", "win32"] } } user-invocable: true disable-model-invocation: false
CronLint -- Scheduled Task & Cron Job Anti-Pattern Analyzer
CronLint scans codebases for scheduled task and cron job anti-patterns: overlapping execution risks, timezone scheduling errors, missing error recovery, resource contention, lifecycle management issues, and observability gaps. It uses regex-based pattern matching against 90 scheduling-specific patterns across 6 categories, lefthook for git hook integration, and produces markdown reports with actionable remediation guidance. 100% local. Zero telemetry.
Note: CronLint focuses on cron jobs, schedulers (node-cron, APScheduler, Quartz, Celery beat, Bull/BullMQ), setInterval/setTimeout scheduling, Kubernetes CronJobs, and periodic task code. It detects anti-patterns in scheduling logic, not HTTP cron endpoints.
Commands
Free Tier (No license required)
#### cronlint scan [file|directory]
One-shot scheduling quality scan of files or directories.
How to execute:
bash "/scripts/dispatcher.sh" --path [target]
What it does: 1. Accepts a file path or directory (defaults to current directory) 2. Discovers all source files (skips .git, node_modules, binaries, images, .min.js) 3. Runs 30 scheduling patterns against each file (free tier limit) 4. Calculates a scheduling quality score (0-100) per file and overall 5. Grades: A (90-100), B (80-89), C (70-79), D (60-69), F (<60) 6. Outputs findings with: file, line number, check ID, severity, description, recommendation 7. Exit code 0 if score >= 70, exit code 1 if scheduling quality is poor 8. Free tier limited to first 30 patterns (OE + TZ categories)
Example usage scenarios:
cronlint scan .cronlint scan src/scheduler.tscronlint scan src/cronlint scan .cronlint scan .Pro Tier ($19/user/month -- requires CRONLINT_LICENSE_KEY)
#### cronlint scan --tier pro [file|directory]
Extended scan with 60 patterns covering overlap, timezone, error recovery, and resource contention.
How to execute:
bash "/scripts/dispatcher.sh" --path [target] --tier pro
What it does: 1. Validates Pro+ license 2. Runs 60 scheduling patterns (OE, TZ, ER, RC categories) 3. Detects missing error recovery and retry logic in scheduled jobs 4. Identifies resource contention: every-minute crons, unbounded queries, no rate limiting 5. Full category breakdown reporting
#### cronlint scan --format json [directory]
Generate JSON output for CI/CD integration.
bash "/scripts/dispatcher.sh" --path [directory] --format json
#### cronlint scan --format html [directory]
Generate HTML report for browser viewing.
bash "/scripts/dispatcher.sh" --path [directory] --format html
#### cronlint scan --category OE [directory]
Filter scan to a specific check category (OE, TZ, ER, RC, LM, OB).
bash "/scripts/dispatcher.sh" --path [directory] --category OE
Team Tier ($39/user/month -- requires CRONLINT_LICENSE_KEY with team tier)
#### cronlint scan --tier team [directory]
Full scan with all 90 patterns across all 6 categories including lifecycle and observability.
How to execute:
bash "/scripts/dispatcher.sh" --path [directory] --tier team
What it does: 1. Validates Team+ license 2. Runs all 90 patterns across 6 categories 3. Includes lifecycle management checks (graceful shutdown, orphaned tasks, stale entries) 4. Includes observability checks (missing metrics, no duration logging, no alerting) 5. Full category breakdown with per-file results
#### cronlint scan --verbose [directory]
Verbose output showing every matched line and pattern details.
bash "/scripts/dispatcher.sh" --path [directory] --verbose
#### cronlint status
Show license and configuration information.
bash "/scripts/dispatcher.sh" status
#### cronlint patterns
List all detection patterns with their IDs, severities, and descriptions.
bash "/scripts/dispatcher.sh" patterns
Check Categories
CronLint detects 90 scheduled task anti-patterns across 6 categories:
| Category | Code | Patterns | Description | Severity Range | |----------|------|----------|-------------|----------------| | Overlapping Execution | OE | 15 | Missing locks, concurrent runs, no mutex, no pid file check | low -- critical | | Timezone & Scheduling | TZ | 15 | Hardcoded TZ, DST risks, UTC confusion, midnight pitfalls | low -- high | | Error & Recovery | ER | 15 | No try/catch, missing retry, silent failure, no dead letter queue | low -- critical | | Resource Contention | RC | 15 | Every-minute cron, no rate limit, unbounded queries, memory risk | low -- critical | | Lifecycle Management | LM | 15 | No graceful shutdown, orphaned tasks, stale entries, no health check | low -- high | | Observability | OB | 15 | No duration logging, no metrics, no alerting, no execution history | low -- high |
Tier-Based Pattern Access
| Tier | Patterns | Categories | |------|----------|------------| | Free | 30 | OE, TZ | | Pro | 60 | OE, TZ, ER, RC | | Team | 90 | OE, TZ, ER, RC, LM, OB | | Enterprise | 90 | OE, TZ, ER, RC, LM, OB + priority support |
Scoring
CronLint uses a deductive scoring system starting at 100 (perfect):
| Severity | Point Deduction | Description | |----------|-----------------|-------------| | Critical | -25 per finding | Severe risk (overlapping execution, silent failure, resource abuse) | | High | -15 per finding | Significant problem (missing locks, DST scheduling, no error handling) | | Medium | -8 per finding | Moderate concern (hardcoded TZ, missing retry, no rate limiting) | | Low | -3 per finding | Informational / best practice suggestion |
Grading Scale
| Grade | Score Range | Meaning | |-------|-------------|---------| | A | 90-100 | Excellent scheduling quality | | B | 80-89 | Good scheduling with minor issues | | C | 70-79 | Acceptable but needs improvement | | D | 60-69 | Poor scheduling quality | | F | Below 60 | Critical scheduling problems |
Configuration
Users can configure CronLint in ~/.openclaw/openclaw.json:
{
"skills": {
"entries": {
"cronlint": {
"enabled": true,
"apiKey": "YOUR_LICENSE_KEY_HERE",
"config": {
"severityThreshold": "medium",
"ignorePatterns": ["/test/", "/fixtures/", "**/*.test.*"],
"ignoreChecks": [],
"reportFormat": "text"
}
}
}
}
}
Important Notes
Error Handling
When to Use CronLint
The user might say things like:
βοΈ Configuration
Users can configure CronLint in ~/.openclaw/openclaw.json:
{
"skills": {
"entries": {
"cronlint": {
"enabled": true,
"apiKey": "YOUR_LICENSE_KEY_HERE",
"config": {
"severityThreshold": "medium",
"ignorePatterns": ["/test/", "/fixtures/", "**/*.test.*"],
"ignoreChecks": [],
"reportFormat": "text"
}
}
}
}
}