Skip to content

Update dependencies #66

Update dependencies

Update dependencies #66

Workflow file for this run

# 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