Skip to main content

A Python3 script for checking syntax and correctness of crontab files

Project description

Checkcrontab - check syntax in crontab files

CI Coverage PyPI Downloads License Python

A Python script for checking syntax of crontab files. Cross-platform support for Linux, macOS, and Windows.

English | Español | Português | Français | Deutsch | Italiano | Русский | 中文 | 日本語 | हिन्दी

Requirements

  • Python 3.7 or higher
  • Linux: Linux system with systemctl (for daemon checks), read access to /etc/crontab
  • macOS: Unix system with read access to /etc/crontab (systemctl not available)
  • Windows: No additional requirements (file-based validation only)

Platform Support

Linux (Full Support):

  • ✅ System crontab validation (/etc/crontab)
  • ✅ User crontab validation (via crontab -l -u username)
  • ✅ User existence validation
  • ✅ Daemon/service checks via systemctl
  • ✅ All crontab syntax features
  • ✅ File permissions validation
  • ✅ Cron daemon status checks

macOS (Partial Support):

  • ✅ System crontab validation (/etc/crontab)
  • ✅ User crontab validation (via crontab -l -u username)
  • ✅ User existence validation
  • ❌ Daemon/service checks (systemctl not available)
  • ✅ All crontab syntax features
  • ✅ File permissions validation
  • ❌ Cron daemon status checks

Windows (Limited Support):

  • ✅ File-based crontab syntax validation
  • ❌ User existence checks (no user management integration)
  • ❌ System crontab access (no /etc/crontab)
  • ❌ Daemon/service checks (no systemctl)
  • ✅ All crontab syntax features supported
  • ❌ File permissions validation (no Unix permissions)
  • ❌ Cron daemon status checks (no cron daemon)

Installation

pip3 install checkcrontab

Or from GitHub:

pip3 install git+https://github.com/wachawo/checkcrontab.git

Usage

# Check system crontab (Linux/macOS only)
checkcrontab

# Check crontab file
checkcrontab /etc/crontab

# Check user crontab (Linux/macOS only)
checkcrontab username

# Check with explicit type flags
checkcrontab -S system.cron -U user.cron -u username1 -u username2

# Check crontab directory
checkcrontab /etc/cron.d

# Show help
checkcrontab --help

# Show version
checkcrontab --version

Platform-specific behavior:

  • Linux: Full functionality including daemon checks and user validation
  • macOS: Full functionality except daemon checks (systemctl not available)
  • Windows: File-based validation only, no system integration

TEXT Output

To redirect output from STDERR to STDOUT (for example, in CI), use --format text:

checkcrontab --format text examples/user_valid.txt

SARIF Output

For SARIF output, use the --format sarif flag:

checkcrontab --format sarif examples/user_valid.txt

JSON Output

For machine-readable output, use the --format json flag:

checkcrontab --format json examples/user_valid.txt

Example JSON output:

{
  "success": true,
  "total_files": 2,
  "total_rows": 27,
  "total_rows_errors": 0,
  "total_errors": 0,
  "files": [
    {
      "file": "/etc/crontab",
      "is_system_crontab": true,
      "rows": 5,
      "rows_errors": 0,
      "errors_count": 0,
      "errors": [],
      "success": true
    },
    {
      "file": "examples/user_valid.txt",
      "is_system_crontab": false,
      "rows": 22,
      "rows_errors": 0,
      "errors_count": 0,
      "errors": [],
      "success": true
    }
  ]
}

Exit codes

Code Meaning
0 No errors (warnings allowed). With --exit-zero always 0.
1 Findings present: any error, or any warning when --strict is set.
2 Runtime/usage error (unexpected failure, bad CLI args, etc.).

Command Line Options

  • -S, --system - System crontab files
  • -U, --user - User crontab files
  • -u, --username - Usernames to check
  • -v, --version - Show version
  • -d, --debug - Debug output
  • -n, --no-colors - Disable colored output
  • --format {text,json,sarif} - Output format
  • --strict - Treat warnings as errors
  • --exit-zero - Always return exit code 0

Features

  • Cross-platform syntax validation (Linux, macOS, Windows)
  • Platform-specific features:
    • Linux/macOS: System and user crontab validation, user existence checks, daemon validation
    • Windows: File-based validation only
  • Time field validation (minutes, hours, days, months, weekdays)
  • Dangerous command detection
  • Special keyword support (@reboot, @daily, etc.)
  • Multi-line command support

Features Documentation - Comprehensive guide to supported syntax, valid values, examples, and error messages.

Development Tools

pip3 install pre-commit flake8 pytest mypy ruff
pre-commit install
pre-commit run --all-files
pre-commit autoupdate

Testing

pytest --cov=checkcrontab --cov-report=term-missing
coverage html  # optional local HTML report in htmlcov/index.html
# CI automatically uploads coverage.xml to Codecov
# python -m coverage_badge -o docs/coverage.svg

Usage with pre-commit

You can use checkcrontab as a pre-commit hook in your projects:

  1. Add to your .pre-commit-config.yaml:
repos:
  - repo: https://github.com/wachawo/checkcrontab
    rev: 0.0.8  # Use the latest version
    hooks:
      - id: checkcrontab
        files: \.(cron|crontab|tab|conf)$
        exclude: (\.git|node_modules|__pycache__)/
        args: [--format, json, --strict]
  1. Install pre-commit:
pip install pre-commit
pre-commit install
  1. The hook will automatically check all .cron, .crontab, and .tab files in your repository.

License

MIT License

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

checkcrontab-0.0.12.tar.gz (34.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

checkcrontab-0.0.12-py3-none-any.whl (18.6 kB view details)

Uploaded Python 3

File details

Details for the file checkcrontab-0.0.12.tar.gz.

File metadata

  • Download URL: checkcrontab-0.0.12.tar.gz
  • Upload date:
  • Size: 34.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for checkcrontab-0.0.12.tar.gz
Algorithm Hash digest
SHA256 ac11d55e7db1620e2086f2869602f973b452ffd223670eae017e4da7d1c738d0
MD5 ce1d72f544350fce7227fcb7eea90dd0
BLAKE2b-256 789e6c771e26bf6aee32046ab546fcdcc3e48f1253ad918b6e6f08d8f0fd675e

See more details on using hashes here.

Provenance

The following attestation bundles were made for checkcrontab-0.0.12.tar.gz:

Publisher: publish.yml on wachawo/checkcrontab

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file checkcrontab-0.0.12-py3-none-any.whl.

File metadata

  • Download URL: checkcrontab-0.0.12-py3-none-any.whl
  • Upload date:
  • Size: 18.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for checkcrontab-0.0.12-py3-none-any.whl
Algorithm Hash digest
SHA256 9b7c526465a30bbe36a8880a4cd7b1a09c1314032fa67745dd6679bd4e4cb682
MD5 c0c440079bbe01d29227dcb38d8d2664
BLAKE2b-256 d9c84a5490363fc02cee1e8d65eacc8f06889513d36339c44d777d8de23ad0a0

See more details on using hashes here.

Provenance

The following attestation bundles were made for checkcrontab-0.0.12-py3-none-any.whl:

Publisher: publish.yml on wachawo/checkcrontab

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page