Update dependencies #66
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
# based on https://brandur.org/fragments/mostly-automatic-deps | |
name: Update dependencies | |
env: | |
GO_VERSION: '1.22' | |
on: | |
workflow_dispatch: | |
schedule: | |
- cron: "0 0 * * 1" | |
permissions: | |
contents: write | |
pull-requests: write | |
jobs: | |
dep_update: | |
runs-on: ubuntu-latest | |
timeout-minutes: 10 | |
steps: | |
- name: Install Go | |
uses: actions/setup-go@v2 | |
with: | |
go-version: ${{ env.GO_VERSION }} | |
- name: Install Nix | |
uses: cachix/install-nix-action@v26 | |
with: | |
nix_path: nixpkgs=channel:nixos-unstable | |
- name: Checkout | |
uses: actions/checkout@v4 | |
- name: Update Nix flake | |
run: nix flake update | |
- name: Build upstream tailscale source | |
run: 'nix build nixpkgs#tailscale.src -o result_ts' | |
- name: Fetch lockfile from Tailscale | |
run: cp result_ts/{go.mod,go.sum} . && sed -i 's;module tailscale\.com; module github.com/lucasew/ts-proxy;' go.mod | |
- name: Go get the rest | |
run: go get -t ./... | |
- name: Go mod tidy | |
run: go mod tidy | |
- name: Update Nix hashes | |
run: ./.github/update-nix-hashes.py | |
- name: Try to build it | |
run: 'nix build .#' | |
- name: Create pull request | |
uses: peter-evans/create-pull-request@v4 | |
with: | |
title: "Update package dependencies + tidy" | |
body: | | |
This is a change initiated automatically by a | |
GitHub Action that updates the projects dependencies to their latest | |
minor and patch-level versions. This lets us stay up to date | |
incrementally so that updates are less effort to get merged compared | |
to large monolithic updates, and gets us security updates more | |
expediently. | |
If the build passes, you are probably A-OK to merge and deploy this. | |
If not, try to dig into what's not working and see if you can fix it | |
so that the dep train stays on its rails. | |
Note that although minor/patch level changes are handled | |
automatically, notably major version changes like you'd find in | |
stripe-go are not and those upgrades need to be performed manually. | |
That should theoretically not be a problem if fixes are backported | |
to all previous majors, but in practice they are often not, so it's | |
worthwhile to occasionally look for new majors and integrate them. | |
branch: "dep-update" | |
commit-message: | | |
Update package dependencies + tidy | |
Automatic update to the project's package dependencies initiated by an | |
automatic GitHub Action running on cron. Keeps upgrades less of a | |
monolithic task and lets security-related patches trickle in more | |
quickly. | |
author: "A helpful machine <actions@github.com>" | |
committer: "A helpful machine <actions@github.com>" | |
delete-branch: true | |
reviewers: | | |
lucasew |