From 919ab491db50d19af531993471e02c9401f11348 Mon Sep 17 00:00:00 2001 From: Christian Muehlhaeuser Date: Mon, 31 Jan 2022 19:54:50 +0100 Subject: [PATCH] Add separate sets of hard- and soft-enforced linters --- .github/workflows/lint-soft.yml | 23 ++++++++++++++++ .github/workflows/lint.yml | 11 ++++---- .golangci-soft.yml | 47 +++++++++++++++++++++++++++++++++ .golangci.yml | 18 ++++++++----- 4 files changed, 87 insertions(+), 12 deletions(-) create mode 100644 .github/workflows/lint-soft.yml create mode 100644 .golangci-soft.yml diff --git a/.github/workflows/lint-soft.yml b/.github/workflows/lint-soft.yml new file mode 100644 index 0000000..b6c06e6 --- /dev/null +++ b/.github/workflows/lint-soft.yml @@ -0,0 +1,23 @@ +name: lint-soft +on: + push: + pull_request: + +permissions: + contents: read + # Optional: allow read access to pull request. Use with `only-new-issues` option. + pull-requests: read + +jobs: + golangci: + name: lint-soft + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v2 + - name: golangci-lint + uses: golangci/golangci-lint-action@v2 + with: + # Optional: golangci-lint command line arguments. + args: --config .golangci-soft.yml --issues-exit-code=0 + # Optional: show only new issues if it's a pull request. The default value is `false`. + only-new-issues: true diff --git a/.github/workflows/lint.yml b/.github/workflows/lint.yml index e85fdcd..74f4c5c 100644 --- a/.github/workflows/lint.yml +++ b/.github/workflows/lint.yml @@ -3,6 +3,11 @@ on: push: pull_request: +permissions: + contents: read + # Optional: allow read access to pull request. Use with `only-new-issues` option. + pull-requests: read + jobs: golangci: name: lint @@ -12,11 +17,7 @@ jobs: - name: golangci-lint uses: golangci/golangci-lint-action@v2 with: - # Required: the version of golangci-lint is required and must be specified without patch version: we always use the latest patch version. - version: v1.31 # Optional: golangci-lint command line arguments. - args: --issues-exit-code=0 - # Optional: working directory, useful for monorepos - # working-directory: somedir + #args: # Optional: show only new issues if it's a pull request. The default value is `false`. only-new-issues: true diff --git a/.golangci-soft.yml b/.golangci-soft.yml new file mode 100644 index 0000000..ef456e0 --- /dev/null +++ b/.golangci-soft.yml @@ -0,0 +1,47 @@ +run: + tests: false + +issues: + include: + - EXC0001 + - EXC0005 + - EXC0011 + - EXC0012 + - EXC0013 + + max-issues-per-linter: 0 + max-same-issues: 0 + +linters: + enable: + # - dupl + - exhaustive + # - exhaustivestruct + - goconst + - godot + - godox + - gomnd + - gomoddirectives + - goprintffuncname + - ifshort + # - lll + - misspell + - nakedret + - nestif + - noctx + - nolintlint + - prealloc + - wrapcheck + + # disable default linters, they are already enabled in .golangci.yml + disable: + - deadcode + - errcheck + - gosimple + - govet + - ineffassign + - staticcheck + - structcheck + - typecheck + - unused + - varcheck diff --git a/.golangci.yml b/.golangci.yml index 0a17bad..a5a91d0 100644 --- a/.golangci.yml +++ b/.golangci.yml @@ -2,24 +2,28 @@ run: tests: false issues: + include: + - EXC0001 + - EXC0005 + - EXC0011 + - EXC0012 + - EXC0013 + max-issues-per-linter: 0 max-same-issues: 0 linters: enable: - bodyclose - - dupl - exportloopref - - goconst - - godot - - godox - goimports - - goprintffuncname - gosec - - misspell - - prealloc + - nilerr + - predeclared + - revive - rowserrcheck - sqlclosecheck + - tparallel - unconvert - unparam - whitespace