-
Notifications
You must be signed in to change notification settings - Fork 27
Description
Overview
Explore integrating Renovatebot as our automated dependency management solution. This complements our recent migration to uv while providing automated dependency updates without requiring migration to pyproject.toml immediately.
Why Renovatebot?
Following discussion in #184, Renovatebot emerged as a superior alternative to Dependabot for our workflow:
✅ Advantages over Manual Workflow
- Automated security updates: Get notified of vulnerabilities with automated fix PRs
- Time savings: No more manual
task dependencies:upgraderuns - Granular control: Group related updates (e.g., Django ecosystem), schedule updates (e.g., Mondays only)
- Better visibility: Track all dependency updates in one place with proper PR descriptions
✅ Advantages over Dependabot
Based on research and community feedback (see #184):
- ✅ Native
uvsupport: Handles bothuv.lockand pip-compile workflows - ✅ Better lock file handling: No issues with marking security fixes as resolved without updating locks
- ✅ More mature: ~10 years old, actively maintained
- ✅ Better configuration: Advanced grouping, scheduling, automerge options
- ✅ Higher API limits: 15,000 requests/hour vs 5,000/hour
✅ Works with Our Current Workflow
Renovatebot supports our current requirements/*.in → requirements/*.txt (pip-compile) workflow:
- Updates source files (
.in) - Automatically regenerates compiled files (
.txt) - Creates PRs with both changes included
Heroku Native uv Support
Heroku now supports uv natively (announcement, docs) as of May 2025.
Requirements for Heroku uv support:
pyproject.toml+uv.lock+.python-version- Must remove
requirements.txtfiles (other package managers take precedence)
Implication: To use Heroku's native uv support, we'd need to migrate from our current .in/.txt workflow to pyproject.toml + uv.lock.
Renovatebot advantage: Supports BOTH workflows, so we can:
- Enable Renovatebot now with our current pip-compile setup
- Migrate to
pyproject.toml+uv.lockwhen ready for Heroku's native uv support - Renovatebot will continue working seamlessly after migration
Implementation Cost
Zero cost, minimal setup:
- ✅ Free: Mend Renovate GitHub App is free for open source projects
- ✅ No infrastructure: Cloud-hosted, no self-hosting required
- ✅ 5-minute setup: Install GitHub App + merge onboarding PR
- ✅ No scripts: Just a
renovate.jsonconfig file
Proposed Configuration
{
"$schema": "https://docs.renovatebot.com/renovate-schema.json",
"extends": ["config:recommended"],
"pip-compile": {
"managerFilePatterns": ["requirements/.*\\.txt$"]
},
"pip_requirements": { "enabled": false },
"packageRules": [
{
"groupName": "Django ecosystem",
"matchPackagePatterns": ["^[Dd]jango", "^[Ww]agtail"],
"schedule": ["before 9am on monday"]
},
{
"matchUpdateTypes": ["patch"],
"automerge": true,
"automergeType": "pr"
}
],
"lockFileMaintenance": {
"enabled": true,
"schedule": ["before 9am on the first day of the month"]
}
}Key features:
- Groups Django/Wagtail updates together
- Schedules updates for Monday mornings
- Auto-merges patch updates (e.g., 6.0.1 → 6.0.2)
- Monthly lock file refresh for transitive dependencies
Migration Path
Phase 1: Enable Renovatebot (current workflow)
- Install Mend Renovate GitHub App
- Configure for pip-compile workflow
- Merge onboarding PR
- Monitor and tune configuration
Phase 2 (Future): Migrate to pyproject.toml + uv.lock
When ready to use Heroku's native uv support:
- Migrate to
pyproject.toml+uv.lock - Update Renovatebot config to use PEP 621 manager
- Remove pip-compile configuration
- Benefit from Heroku's faster uv deployments
Comparison with Manual Workflow
| Aspect | Manual (task dependencies:upgrade) |
Renovatebot |
|---|---|---|
| Frequency | When we remember | Automated schedule |
| Security alerts | Manual monitoring | Automated PRs |
| Granularity | All-or-nothing | Per-package or grouped |
| Test before merge | Manual | CI runs automatically |
| Time investment | ~30min monthly | ~5min to review PRs |
Next Steps
- Community feedback on this proposal
- Install Mend Renovate GitHub App: https://github.com/apps/renovate
- Create
renovate.jsonwith proposed configuration - Merge onboarding PR
- Monitor first round of dependency update PRs
- Fine-tune configuration based on experience