From 7d5cf4b530df79023036fc919bbd78aced288f64 Mon Sep 17 00:00:00 2001 From: civisrom <167646351+civisrom@users.noreply.github.com> Date: Tue, 4 Mar 2025 12:02:37 +0300 Subject: [PATCH] Update update-dependencies.yml --- .github/workflows/update-dependencies.yml | 112 ++++++++++++++-------- 1 file changed, 70 insertions(+), 42 deletions(-) diff --git a/.github/workflows/update-dependencies.yml b/.github/workflows/update-dependencies.yml index 8e63b623..d0564634 100644 --- a/.github/workflows/update-dependencies.yml +++ b/.github/workflows/update-dependencies.yml @@ -2,22 +2,23 @@ name: Update Go Dependencies on: schedule: - - cron: '0 0 * * 1' - workflow_dispatch: + - cron: '0 0 * * 1' # Запуск каждую неделю в понедельник в 00:00 UTC + workflow_dispatch: # Возможность ручного запуска permissions: - contents: write + contents: write # Явное указание разрешений jobs: update: - runs-on: ubuntu-latest - timeout-minutes: 30 + runs-on: ubuntu-latest # Используем последнюю версию Ubuntu + + timeout-minutes: 30 # Добавляем таймаут для предотвращения зависания steps: - name: Checkout repository uses: actions/checkout@v4 with: - fetch-depth: 0 + fetch-depth: 0 # Загружаем всю историю token: ${{ secrets.GITHUB_TOKEN }} - name: Setup Go @@ -25,66 +26,93 @@ jobs: with: go-version-file: go.mod check-latest: true - cache: true + cache: true # Включаем кэширование модулей - name: Check go.mod and go.sum exist run: | - [ -f go.mod ] || (echo "Error: go.mod not found" && exit 1) - [ -f go.sum ] || (go mod tidy && echo "Initialized go.sum") + if [ ! -f go.mod ]; then + 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 - run: go clean -modcache && go clean -cache + run: | + go clean -modcache + go clean -cache - name: Update dependencies id: update run: | - set -euo pipefail - - # Обновляем стандартные зависимости - 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 - - # Получаем последний релизный тег и его коммит - echo "Fetching latest xray-core release tag..." - latest_tag=$(git ls-remote --tags https://github.com/xtls/xray-core \ - | awk -F'[/ ]' '{print $3}' \ - | grep '^v' \ - | sort -V \ - | tail -n1) - - echo "Latest release tag: $latest_tag" + set -euo pipefail # Строгий режим для bash - # Получаем хэш коммита для тега - commit_hash=$(git ls-remote https://github.com/xtls/xray-core refs/tags/$latest_tag \ - | awk '{print $1}') - - 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) + echo "Updating standard Go dependencies..." + + # Обновляем стандартные зависимости с исключением gvisor + go list -f '{{if not (or .Main .Indirect)}}{{.Path}}{{end}}' -m all | \ + grep -v 'gvisor.dev/gvisor' | \ + grep -v 'github.com/xtls/xray-core' | \ + xargs -r go get -u + + echo "Specifically updating xray-core to latest commit..." + go get github.com/xtls/xray-core@main + # Проверяем, какую версию получили + echo "Updated xray-core to:" + go list -m github.com/xtls/xray-core + # Очистка и проверка go mod tidy - go mod verify + go mod verify || exit 1 + + # Выводим изменения для лога + echo "Updated dependencies:" + go list -m all - name: Check for changes id: check run: | if git diff --quiet go.mod go.sum; then echo "changes=false" >> $GITHUB_OUTPUT + echo "No changes detected in dependencies" else echo "changes=true" >> $GITHUB_OUTPUT - git diff go.mod + echo "Changes detected in dependencies:" + # Добавляем || true чтобы предотвратить код ошибки, если grep ничего не находит + git diff go.mod || true fi - name: Commit and push changes if: steps.check.outputs.changes == 'true' run: | 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 commit -m "chore(deps): update xray-core to pseudo-version" - git push origin HEAD:${{ github.ref }} + git commit -m "chore(deps): update Go dependencies + + 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