Update update-dependencies.yml

This commit is contained in:
civisrom 2025-03-04 12:02:37 +03:00 committed by GitHub
parent 72f40564c4
commit 7d5cf4b530
No known key found for this signature in database
GPG key ID: B5690EEEBB952194

View file

@ -2,22 +2,23 @@ name: Update Go Dependencies
on: on:
schedule: schedule:
- cron: '0 0 * * 1' - cron: '0 0 * * 1' # Запуск каждую неделю в понедельник в 00:00 UTC
workflow_dispatch: workflow_dispatch: # Возможность ручного запуска
permissions: permissions:
contents: write contents: write # Явное указание разрешений
jobs: jobs:
update: update:
runs-on: ubuntu-latest runs-on: ubuntu-latest # Используем последнюю версию Ubuntu
timeout-minutes: 30
timeout-minutes: 30 # Добавляем таймаут для предотвращения зависания
steps: steps:
- name: Checkout repository - name: Checkout repository
uses: actions/checkout@v4 uses: actions/checkout@v4
with: with:
fetch-depth: 0 fetch-depth: 0 # Загружаем всю историю
token: ${{ secrets.GITHUB_TOKEN }} token: ${{ secrets.GITHUB_TOKEN }}
- name: Setup Go - name: Setup Go
@ -25,66 +26,93 @@ jobs:
with: with:
go-version-file: go.mod go-version-file: go.mod
check-latest: true check-latest: true
cache: true cache: true # Включаем кэширование модулей
- name: Check go.mod and go.sum exist - name: Check go.mod and go.sum exist
run: | run: |
[ -f go.mod ] || (echo "Error: go.mod not found" && exit 1) if [ ! -f go.mod ]; then
[ -f go.sum ] || (go mod tidy && echo "Initialized go.sum") echo "Error: go.mod file not found"
exit 1
fi
# Проверка наличия go.sum и создание, если отсутствует
if [ ! -f go.sum ]; then
echo "go.sum file not found, initializing it..."
go mod tidy
fi
- name: Clean Go module cache - name: Clean Go module cache
run: go clean -modcache && go clean -cache run: |
go clean -modcache
go clean -cache
- name: Update dependencies - name: Update dependencies
id: update id: update
run: | run: |
set -euo pipefail set -euo pipefail # Строгий режим для bash
# Обновляем стандартные зависимости echo "Updating standard Go dependencies..."
go list -f '{{if not (or .Main .Indirect)}}{{.Path}}{{end}}' -m all \
| grep -v -e 'gvisor.dev/gvisor' -e 'github.com/xtls/xray-core' \
| xargs -r go get -u
# Получаем последний релизный тег и его коммит # Обновляем стандартные зависимости с исключением gvisor
echo "Fetching latest xray-core release tag..." go list -f '{{if not (or .Main .Indirect)}}{{.Path}}{{end}}' -m all | \
latest_tag=$(git ls-remote --tags https://github.com/xtls/xray-core \ grep -v 'gvisor.dev/gvisor' | \
| awk -F'[/ ]' '{print $3}' \ grep -v 'github.com/xtls/xray-core' | \
| grep '^v' \ xargs -r go get -u
| sort -V \
| tail -n1)
echo "Latest release tag: $latest_tag" echo "Specifically updating xray-core to latest commit..."
go get github.com/xtls/xray-core@main
# Получаем хэш коммита для тега # Проверяем, какую версию получили
commit_hash=$(git ls-remote https://github.com/xtls/xray-core refs/tags/$latest_tag \ echo "Updated xray-core to:"
| awk '{print $1}') go list -m github.com/xtls/xray-core
echo "Associated commit hash: $commit_hash"
# Обновляем до конкретного коммита (будет сгенерирована псевдоверсия)
go get github.com/xtls/xray-core@$commit_hash
# Форсируем правильный формат псевдоверсии
go mod edit -require github.com/xtls/xray-core@v0.0.0-$(echo $commit_hash | sed 's/\(.\{12\}\).*/\1/')-$(date -d @$(echo $commit_hash | cut -c1-8) +%Y%m%d%H%M%S)
# Очистка и проверка
go mod tidy go mod tidy
go mod verify go mod verify || exit 1
# Выводим изменения для лога
echo "Updated dependencies:"
go list -m all
- name: Check for changes - name: Check for changes
id: check id: check
run: | run: |
if git diff --quiet go.mod go.sum; then if git diff --quiet go.mod go.sum; then
echo "changes=false" >> $GITHUB_OUTPUT echo "changes=false" >> $GITHUB_OUTPUT
echo "No changes detected in dependencies"
else else
echo "changes=true" >> $GITHUB_OUTPUT echo "changes=true" >> $GITHUB_OUTPUT
git diff go.mod echo "Changes detected in dependencies:"
# Добавляем || true чтобы предотвратить код ошибки, если grep ничего не находит
git diff go.mod || true
fi fi
- name: Commit and push changes - name: Commit and push changes
if: steps.check.outputs.changes == 'true' if: steps.check.outputs.changes == 'true'
run: | run: |
git config --global user.name "github-actions[bot]" git config --global user.name "github-actions[bot]"
git config --global user.email "41898282+github-actions[bot]@users.noreply.github.com" git config --global user.email "github-actions[bot]@users.noreply.github.com"
git add go.mod go.sum git add go.mod go.sum
git commit -m "chore(deps): update xray-core to pseudo-version" git commit -m "chore(deps): update Go dependencies
git push origin HEAD:${{ github.ref }}
Automated update of Go dependencies including xray-core to latest stable version"
# Попытка push с повторами при ошибках
max_attempts=3
attempt=1
while [ $attempt -le $max_attempts ]; do
if git push origin ${{ github.ref }}; then
echo "Successfully pushed changes on attempt $attempt"
break
else
if [ $attempt -eq $max_attempts ]; then
echo "Failed to push after $max_attempts attempts"
exit 1
fi
echo "Push failed on attempt $attempt, retrying..."
attempt=$((attempt + 1))
git pull --rebase
sleep 5
fi
done