117 lines
3.2 KiB
YAML
117 lines
3.2 KiB
YAML
name: Tests
|
||
|
||
on:
|
||
pull_request:
|
||
branches:
|
||
- master
|
||
types: [ opened, synchronize ]
|
||
workflow_dispatch:
|
||
|
||
jobs:
|
||
lint:
|
||
name: Lint
|
||
uses: nspcc-dev/.github/.github/workflows/go-linter.yml@master
|
||
|
||
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'
|
||
cache: true
|
||
|
||
- name: Write coverage profile
|
||
run: go test ./... -coverprofile=./coverage.txt -covermode=atomic
|
||
|
||
- name: Upload coverage results to Codecov
|
||
uses: codecov/codecov-action@v4
|
||
with:
|
||
fail_ci_if_error: false
|
||
slug: nspcc-dev/rfc6979
|
||
token: ${{ secrets.CODECOV_TOKEN }}
|
||
files: ./coverage.txt
|
||
verbose: true
|
||
|
||
tests:
|
||
name: Run tests
|
||
runs-on: ${{ matrix.os }}
|
||
strategy:
|
||
matrix:
|
||
os: [ ubuntu-latest, windows-latest, macos-latest ]
|
||
go_versions: [ '1.24', '1.25' ]
|
||
exclude:
|
||
- os: macos-latest
|
||
go_versions: '1.24'
|
||
- os: windows-latest
|
||
go_versions: '1.24'
|
||
- 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 }}'
|
||
cache: true
|
||
|
||
- name: Run tests
|
||
run: go test -race ./...
|
||
|
||
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@v2
|
||
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@v2
|
||
|
||
# ℹ️ 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@v2
|