mirror of
https://github.com/AdguardTeam/AdGuardHome.git
synced 2025-01-07 06:27:22 +03:00
7f83707449
Squashed commit of the following:
commit c004644dd6b86847a654764e2055349919ac0de0
Merge: f26ec4440 24baee0f8
Author: Eugene Burkov <E.Burkov@AdGuard.COM>
Date: Fri Feb 9 13:09:44 2024 +0300
Merge branch 'master' into AG-29441-qa-versions
commit f26ec4440cd406d0753d1225313b3cc5f60bf3e2
Author: Eugene Burkov <E.Burkov@AdGuard.COM>
Date: Wed Feb 7 13:27:15 2024 +0300
github: imp workflow doc
commit 825a00c8dde47f9bc9b837885978a135bfb1dc61
Author: Eugene Burkov <E.Burkov@AdGuard.COM>
Date: Tue Feb 6 18:53:32 2024 +0300
scripts: imp doc
commit ef62d96cec66f186799db175a813fca0913482b7
Author: Eugene Burkov <E.Burkov@AdGuard.COM>
Date: Tue Feb 6 15:00:42 2024 +0300
scrits: imp count
commit 2d02b23da426063b9a852c06a04ba2fef874b9bf
Author: Eugene Burkov <E.Burkov@AdGuard.COM>
Date: Tue Feb 6 14:22:28 2024 +0300
scripts: imp code, docs
commit 549bfb982fa32cd30aa339f4458e60b6fc22e53a
Author: Eugene Burkov <E.Burkov@AdGuard.COM>
Date: Mon Feb 5 18:54:55 2024 +0300
scripts: imp dev version
137 lines
4.3 KiB
YAML
137 lines
4.3 KiB
YAML
'name': 'build'
|
|
|
|
'env':
|
|
'GO_VERSION': '1.21.7'
|
|
'NODE_VERSION': '16'
|
|
|
|
'on':
|
|
'push':
|
|
'branches':
|
|
- '*'
|
|
'tags':
|
|
- 'v*'
|
|
'pull_request':
|
|
|
|
'jobs':
|
|
'test':
|
|
'runs-on': '${{ matrix.os }}'
|
|
'env':
|
|
'GO111MODULE': 'on'
|
|
'GOPROXY': 'https://goproxy.cn'
|
|
'strategy':
|
|
'fail-fast': false
|
|
'matrix':
|
|
'os':
|
|
- 'ubuntu-latest'
|
|
- 'macOS-latest'
|
|
- 'windows-latest'
|
|
'steps':
|
|
- 'name': 'Checkout'
|
|
'uses': 'actions/checkout@v2'
|
|
'with':
|
|
'fetch-depth': 0
|
|
- 'name': 'Set up Go'
|
|
'uses': 'actions/setup-go@v3'
|
|
'with':
|
|
'go-version': '${{ env.GO_VERSION }}'
|
|
- 'name': 'Set up Node'
|
|
'uses': 'actions/setup-node@v1'
|
|
'with':
|
|
'node-version': '${{ env.NODE_VERSION }}'
|
|
- 'name': 'Set up Go modules cache'
|
|
'uses': 'actions/cache@v2'
|
|
'with':
|
|
'path': '~/go/pkg/mod'
|
|
'key': "${{ runner.os }}-go-${{ hashFiles('go.sum') }}"
|
|
'restore-keys': '${{ runner.os }}-go-'
|
|
- 'name': 'Get npm cache directory'
|
|
'id': 'npm-cache'
|
|
'run': 'echo "::set-output name=dir::$( npm config get cache )"'
|
|
- 'name': 'Set up npm cache'
|
|
'uses': 'actions/cache@v2'
|
|
'with':
|
|
'path': '${{ steps.npm-cache.outputs.dir }}'
|
|
'key': "${{ runner.os }}-node-${{ hashFiles('client/package-lock.json') }}"
|
|
'restore-keys': '${{ runner.os }}-node-'
|
|
- 'name': 'Run make ci'
|
|
'shell': 'bash'
|
|
'run': 'make VERBOSE=1 ci'
|
|
- 'name': 'Upload coverage'
|
|
'uses': 'codecov/codecov-action@v1'
|
|
'if': "success() && matrix.os == 'ubuntu-latest'"
|
|
'with':
|
|
'token': '${{ secrets.CODECOV_TOKEN }}'
|
|
'file': './coverage.txt'
|
|
|
|
'build-release':
|
|
'runs-on': 'ubuntu-latest'
|
|
'needs': 'test'
|
|
'steps':
|
|
- 'name': 'Checkout'
|
|
'uses': 'actions/checkout@v2'
|
|
'with':
|
|
'fetch-depth': 0
|
|
- 'name': 'Set up Go'
|
|
'uses': 'actions/setup-go@v3'
|
|
'with':
|
|
'go-version': '${{ env.GO_VERSION }}'
|
|
- 'name': 'Set up Node'
|
|
'uses': 'actions/setup-node@v1'
|
|
'with':
|
|
'node-version': '${{ env.NODE_VERSION }}'
|
|
- 'name': 'Set up Go modules cache'
|
|
'uses': 'actions/cache@v2'
|
|
'with':
|
|
'path': '~/go/pkg/mod'
|
|
'key': "${{ runner.os }}-go-${{ hashFiles('go.sum') }}"
|
|
'restore-keys': '${{ runner.os }}-go-'
|
|
- 'name': 'Get npm cache directory'
|
|
'id': 'npm-cache'
|
|
'run': 'echo "::set-output name=dir::$(npm config get cache)"'
|
|
- 'name': 'Set up npm cache'
|
|
'uses': 'actions/cache@v2'
|
|
'with':
|
|
'path': '${{ steps.npm-cache.outputs.dir }}'
|
|
'key': "${{ runner.os }}-node-${{ hashFiles('client/package-lock.json') }}"
|
|
'restore-keys': '${{ runner.os }}-node-'
|
|
- 'name': 'Set up Snapcraft'
|
|
'run': 'sudo apt-get -yq --no-install-suggests --no-install-recommends install snapcraft'
|
|
- 'name': 'Set up QEMU'
|
|
'uses': 'docker/setup-qemu-action@v1'
|
|
- 'name': 'Set up Docker Buildx'
|
|
'uses': 'docker/setup-buildx-action@v1'
|
|
- 'name': 'Run snapshot build'
|
|
# Set a custom version string, since the checkout@v2 action does not seem
|
|
# to know about the master branch, while the version script uses it to
|
|
# count the number of commits within the branch.
|
|
'run': 'make SIGN=0 VERBOSE=1 VERSION="v0.0.0-github" build-release build-docker'
|
|
|
|
'notify':
|
|
'needs':
|
|
- 'build-release'
|
|
# Secrets are not passed to workflows that are triggered by a pull request
|
|
# from a fork.
|
|
#
|
|
# Use always() to signal to the runner that this job must run even if the
|
|
# previous ones failed.
|
|
'if':
|
|
${{
|
|
always() &&
|
|
github.repository_owner == 'AdguardTeam' &&
|
|
(
|
|
github.event_name == 'push' ||
|
|
github.event.pull_request.head.repo.full_name == github.repository
|
|
)
|
|
}}
|
|
'runs-on': 'ubuntu-latest'
|
|
'steps':
|
|
- 'name': 'Conclusion'
|
|
'uses': 'technote-space/workflow-conclusion-action@v1'
|
|
- 'name': 'Send Slack notif'
|
|
'uses': '8398a7/action-slack@v3'
|
|
'with':
|
|
'status': '${{ env.WORKFLOW_CONCLUSION }}'
|
|
'fields': 'repo, message, commit, author, workflow'
|
|
'env':
|
|
'GITHUB_TOKEN': '${{ secrets.GITHUB_TOKEN }}'
|
|
'SLACK_WEBHOOK_URL': '${{ secrets.SLACK_WEBHOOK_URL }}'
|