A simple CLI tool to automate Pull Request creation and management for Cal.com with standardized templates and conventions.
- Automatically generates PR titles from branch names following Cal.com conventions
- Uses standardized PR template with mandatory tasks
- Supports draft PRs
- Updates multiple PRs with main branch in bulk
- Detects and reports merge conflicts
- Configurable via environment variables
- Branch name validation (feat/fix/chore/perf)
- Clone the repository:
git clone /~https://github.com/yourusername/cal-pr-agent.git
cd cal-pr-agent
- Install dependencies:
pip install -r requirements.txt
- Create a
.env
file in the project root:
GITHUB_TOKEN=your_github_token_here
GITHUB_REPO=calcom/cal.com # write the name of your fork repo if you are using a fork
Basic usage:
python pr.py create feat/new-feature
Full options for PR creation:
python pr.py create <branch> [options]
Arguments:
branch Branch name (must start with feat/fix/chore/perf)
Options:
-t, --title TEXT Custom PR title (optional, generated from branch name if not provided)
--ticket TEXT Linear CAL ticket number (optional)
--base TEXT Base branch (default: main)
-d, --draft Create as draft PR
Examples of PR creation:
# Simple usage
python pr.py create feat/new-onboarding
# With ticket number
python pr.py create perf/speed-update --ticket 1234
# Create draft PR
python pr.py create fix/bug-fix -d
# Custom title
python pr.py create feat/new-feature -t "feat: implement amazing new feature"
You can update all your open PRs with the main branch using the refresh command:
# Show what changes would be made without actually making them
python pr.py refresh --dry-run
# Actually update the PRs
python pr.py refresh
The refresh command will:
- List all your open PRs
- Check each PR for merge conflicts with main
- Show which PRs can be updated and which have conflicts
- Update conflict-free PRs with main (after confirmation)
- Display URLs of PRs that need manual conflict resolution
Branch names must follow the pattern: {type}/{description}
Valid types:
feat
: New featurefix
: Bug fixchore
: Maintenance tasksperf
: Performance improvements
Examples:
feat/new-onboarding
fix/login-issue
chore/cleanup-deps
perf/reduce-bundle-size
PR titles are automatically generated from branch names in the format:
type: description
Examples:
feat: new onboarding
fix: login issue
chore: cleanup deps
perf: reduce bundle size
MIT