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