120 lines
3.4 KiB
YAML
120 lines
3.4 KiB
YAML
name: Tests
|
||
|
||
on:
|
||
pull_request:
|
||
branches:
|
||
- master
|
||
types: [opened, synchronize]
|
||
paths-ignore:
|
||
- '*.md'
|
||
workflow_dispatch:
|
||
|
||
env:
|
||
GO111MODULE: "on"
|
||
|
||
jobs:
|
||
test_cover:
|
||
name: Coverage
|
||
runs-on: ubuntu-latest
|
||
|
||
env:
|
||
CGO_ENABLED: 0
|
||
steps:
|
||
- uses: actions/checkout@v4
|
||
with:
|
||
fetch-depth: 0
|
||
|
||
- name: Set up Go
|
||
uses: actions/setup-go@v5
|
||
with:
|
||
go-version: 1.25
|
||
|
||
- name: Write coverage profile
|
||
run: go test -v ./... -coverprofile=./coverage.txt -covermode=atomic
|
||
|
||
- name: Upload coverage results to Codecov
|
||
uses: codecov/codecov-action@v2
|
||
with:
|
||
fail_ci_if_error: false
|
||
path_to_write_report: ./coverage.txt
|
||
verbose: true
|
||
|
||
tests:
|
||
name: Go
|
||
runs-on: ${{ matrix.os }}
|
||
strategy:
|
||
matrix:
|
||
go_versions: [ '1.24', '1.25' ]
|
||
os: [ubuntu-latest, windows-latest, macos-latest]
|
||
exclude:
|
||
# Only latest Go version for Windows and MacOS.
|
||
- os: windows-latest
|
||
go_versions: '1.24'
|
||
- os: macos-latest
|
||
go_versions: '1.24'
|
||
# Exclude latest Go version for Ubuntu as Coverage uses it.
|
||
- os: ubuntu-latest
|
||
go_versions: '1.25'
|
||
fail-fast: false
|
||
steps:
|
||
- uses: actions/checkout@v4
|
||
with:
|
||
fetch-depth: 0
|
||
|
||
- name: Set up Go
|
||
uses: actions/setup-go@v5
|
||
with:
|
||
go-version: '${{ matrix.go_versions }}'
|
||
|
||
- name: Run tests
|
||
run: go test -v -race ./...
|
||
|
||
lint:
|
||
name: Linter
|
||
uses: nspcc-dev/.github/.github/workflows/go-linter.yml@master
|
||
|
||
codeql:
|
||
name: CodeQL
|
||
runs-on: ubuntu-latest
|
||
|
||
strategy:
|
||
fail-fast: false
|
||
matrix:
|
||
language: [ 'go' ]
|
||
# CodeQL supports [ 'cpp', 'csharp', 'go', 'java', 'javascript', 'python' ]
|
||
# Learn more:
|
||
# https://docs.github.com/en/free-pro-team@latest/github/finding-security-vulnerabilities-and-errors-in-your-code/configuring-code-scanning#changing-the-languages-that-are-analyzed
|
||
|
||
steps:
|
||
- name: Checkout repository
|
||
uses: actions/checkout@v4
|
||
|
||
# Initializes the CodeQL tools for scanning.
|
||
- name: Initialize CodeQL
|
||
uses: github/codeql-action/init@v3
|
||
with:
|
||
languages: ${{ matrix.language }}
|
||
# If you wish to specify custom queries, you can do so here or in a config file.
|
||
# By default, queries listed here will override any specified in a config file.
|
||
# Prefix the list here with "+" to use these queries and those in the config file.
|
||
# queries: ./path/to/local/query, your-org/your-repo/queries@main
|
||
|
||
# Autobuild attempts to build any compiled languages (C/C++, C#, or Java).
|
||
# If this step fails, then you should remove it and run the build manually (see below)
|
||
- name: Autobuild
|
||
uses: github/codeql-action/autobuild@v3
|
||
|
||
# ℹ️ Command-line programs to run using the OS shell.
|
||
# 📚 https://git.io/JvXDl
|
||
|
||
# ✏️ If the Autobuild fails above, remove it and uncomment the following three lines
|
||
# and modify them (or add more) to build your code if your project
|
||
# uses a compiled language
|
||
|
||
#- run: |
|
||
# make bootstrap
|
||
# make release
|
||
|
||
- name: Perform CodeQL Analysis
|
||
uses: github/codeql-action/analyze@v3
|