mirror of
https://codeberg.org/forgejo/forgejo.git
synced 2024-12-27 06:03:51 +03:00
Merge pull request 'build: only require go minor' (#6151) from viceice/forgejo:build/pin-go-to-minor-only into forgejo
Reviewed-on: https://codeberg.org/forgejo/forgejo/pulls/6151 Reviewed-by: Gusted <gusted@noreply.codeberg.org>
This commit is contained in:
commit
70892c4813
3 changed files with 61 additions and 2 deletions
59
.forgejo/workflows-composite/setup-cache-go/action.yaml
Normal file
59
.forgejo/workflows-composite/setup-cache-go/action.yaml
Normal file
|
@ -0,0 +1,59 @@
|
||||||
|
# SPDX-License-Identifier: MIT
|
||||||
|
name: 'Forgejo Actions to setup Go and cache dependencies'
|
||||||
|
author: 'Forgejo authors'
|
||||||
|
description: |
|
||||||
|
Wrap the setup-go with improved dependency caching.
|
||||||
|
inputs:
|
||||||
|
username:
|
||||||
|
description: 'User for which to manage the dependency cache'
|
||||||
|
default: root
|
||||||
|
|
||||||
|
runs:
|
||||||
|
using: "composite"
|
||||||
|
steps:
|
||||||
|
- name: "Install zstd for faster caching"
|
||||||
|
run: |
|
||||||
|
apt-get update -qq
|
||||||
|
apt-get -q install -qq -y zstd
|
||||||
|
|
||||||
|
- name: "Set up Go using setup-go"
|
||||||
|
uses: https://code.forgejo.org/actions/setup-go@v5
|
||||||
|
id: go-version
|
||||||
|
with:
|
||||||
|
go-version-file: "go.mod"
|
||||||
|
# do not cache dependencies, we do this manually
|
||||||
|
cache: false
|
||||||
|
|
||||||
|
- name: "Get go environment information"
|
||||||
|
id: go-environment
|
||||||
|
run: |
|
||||||
|
echo "modcache=$(su ${RUN_AS_USER} -c '/opt/hostedtoolcache/go/${GO_VERSION}/x64/bin/go env GOMODCACHE')" >> "$GITHUB_OUTPUT"
|
||||||
|
echo "cache=$(su ${RUN_AS_USER} -c '/opt/hostedtoolcache/go/${GO_VERSION}/x64/bin/go env GOCACHE')" >> "$GITHUB_OUTPUT"
|
||||||
|
env:
|
||||||
|
RUN_AS_USER: ${{ inputs.username }}
|
||||||
|
GO_VERSION: ${{ steps.go-version.outputs.go-version }}
|
||||||
|
|
||||||
|
- name: "Create cache folders with correct permissions (for non-root users)"
|
||||||
|
if: inputs.username != 'root'
|
||||||
|
# when the cache is restored, only the permissions of the last part are restored
|
||||||
|
# so assuming that /home/user exists and we are restoring /home/user/go/pkg/mod,
|
||||||
|
# both folders will have the correct permissions, but
|
||||||
|
# /home/user/go and /home/user/go/pkg might be owned by root
|
||||||
|
run: |
|
||||||
|
su ${RUN_AS_USER} -c 'mkdir -p "${MODCACHE_DIR}" "${CACHE_DIR}"'
|
||||||
|
env:
|
||||||
|
RUN_AS_USER: ${{ inputs.username }}
|
||||||
|
MODCACHE_DIR: ${{ steps.go-environment.outputs.modcache }}
|
||||||
|
CACHE_DIR: ${{ steps.go-environment.outputs.cache }}
|
||||||
|
|
||||||
|
- name: "Restore Go dependencies from cache or mark for later caching"
|
||||||
|
id: cache-deps
|
||||||
|
uses: actions/cache@v4
|
||||||
|
with:
|
||||||
|
key: setup-cache-go-deps-${{ runner.os }}-${{ inputs.username }}-${{ steps.go-version.outputs.go_version }}-${{ hashFiles('go.sum', 'go.mod') }}
|
||||||
|
restore-keys: |
|
||||||
|
setup-cache-go-deps-${{ runner.os }}-${{ inputs.username }}-${{ steps.go-version.outputs.go_version }}-
|
||||||
|
setup-cache-go-deps-${{ runner.os }}-${{ inputs.username }}-
|
||||||
|
path: |
|
||||||
|
${{ steps.go-environment.outputs.modcache }}
|
||||||
|
${{ steps.go-environment.outputs.cache }}
|
|
@ -10,7 +10,7 @@ runs:
|
||||||
adduser --quiet --comment forgejo --disabled-password forgejo || true
|
adduser --quiet --comment forgejo --disabled-password forgejo || true
|
||||||
chown -R forgejo:forgejo .
|
chown -R forgejo:forgejo .
|
||||||
|
|
||||||
- uses: https://codeberg.org/fnetx/setup-cache-go@4b50dd28b1068fa06d433c5fabed3f6f4d4ccddf
|
- uses: ./.forgejo/workflows-composite/setup-cache-go
|
||||||
with:
|
with:
|
||||||
username: forgejo
|
username: forgejo
|
||||||
|
|
||||||
|
|
2
go.mod
2
go.mod
|
@ -1,6 +1,6 @@
|
||||||
module code.gitea.io/gitea
|
module code.gitea.io/gitea
|
||||||
|
|
||||||
go 1.23.1
|
go 1.23
|
||||||
|
|
||||||
toolchain go1.23.4
|
toolchain go1.23.4
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue