with one click
bump-go-dependencies
// Update direct Go module dependencies one by one, validating each bump with tests and linter, committing individually, and producing a summary table for a PR description
// Update direct Go module dependencies one by one, validating each bump with tests and linter, committing individually, and producing a summary table for a PR description
[HINT] Download the complete skill directory including SKILL.md and all related files
| name | bump-go-dependencies |
| description | Update direct Go module dependencies one by one, validating each bump with tests and linter, committing individually, and producing a summary table for a PR description |
When asked to update or bump Go dependencies, follow this procedure.
Run the following to get a list of direct dependencies that have newer versions available:
go list -m -u -json all 2>/dev/null | jq -r 'select(.Indirect != true and .Update != null) | "\(.Path) \(.Version) \(.Update.Path) \(.Update.Version)"'
This produces lines of the form:
module/path current_version update_path new_version
If the command produces no output, all direct dependencies are already up to date. Inform the user and stop.
For each outdated dependency, perform the following steps in order:
go get <module_path>@<new_version>
go mod tidy
Run the linter and the tests:
task lint
task test
If both pass: stage and commit the changes:
git add -A
git commit -m "bump <module_path> from <old_version> to <new_version>" -m "" -m "Assisted-By: docker-agent"
Record the dependency as bumped in your tracking table.
If either fails: revert all changes and move on:
git checkout -- .
Record the dependency as skipped in your tracking table, noting the reason (lint failure, test failure, or both).
After processing every dependency, output a copy-pastable Markdown table inside a fenced code block. The table must list every dependency that was considered, with columns for the module path, old version, new version, and status. Don't use emojis, just plain markdown.
Example:
```markdown
| Module | From | To | Status |
|--------|------|----|--------|
| github.com/example/foo | v1.2.0 | v1.3.0 | bumped |
| github.com/example/bar | v0.4.1 | v0.5.0 | skipped — test failure |
| golang.org/x/text | v0.21.0 | v0.22.0 | bumped |
```
This table is meant to be pasted directly into a pull-request description.