-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #1 from golang-cz/err_checker
Implement static analysis tool for checking if we correctly wrap errors in fmt.Errorf
- Loading branch information
Showing
2,928 changed files
with
755,558 additions
and
2 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,25 @@ | ||
name: Build static analysis tool with custom plugins | ||
on: | ||
push: | ||
branches: | ||
- master | ||
pull_request: | ||
|
||
concurrency: | ||
group: ${{ github.ref }} | ||
cancel-in-progress: true | ||
|
||
jobs: | ||
docker-build: | ||
runs-on: ubuntu-latest | ||
steps: | ||
- name: Git clone | ||
uses: actions/checkout@v3 | ||
with: | ||
ref: ${{ github.event.pull_request.head.sha }} | ||
- name: Log into Github registry | ||
run: echo "${{ secrets.GITHUB_TOKEN }}" | docker login ghcr.io -u ${{ github.actor }} --password-stdin | ||
- name: Docker build | ||
run: | | ||
docker build -t ghcr.io/golang-cz/static-analysis . | ||
docker push ghcr.io/golang-cz/static-analysis |
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,16 @@ | ||
# stage 1 building the code | ||
FROM golang:1.20 as builder | ||
|
||
COPY / /golangci | ||
WORKDIR /golangci | ||
RUN CGO_ENABLED=1 go build -trimpath -ldflags "-s -w -X main.version=master -X main.commit=master -X main.date=custom" -o golangci-lint ./cmd/golangci/main.go | ||
RUN CGO_ENABLED=1 go build -trimpath -ldflags "-s -w" -buildmode=plugin -o wrap-err-checker.so ./cmd/plugin/plugin.go | ||
|
||
# stage 2 | ||
FROM golang:1.20 | ||
# related to https://github.com/golangci/golangci-lint/issues/3107 | ||
ENV GOROOT /usr/local/go | ||
# don't place it into $GOPATH/bin because Drone mounts $GOPATH as volume | ||
COPY --from=builder /golangci/golangci-lint /usr/bin/ | ||
COPY --from=builder /golangci/wrap-err-checker.so /usr/bin/ | ||
CMD ["golangci-lint"] |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1 +1,24 @@ | ||
# static-analysis | ||
# Static analysis package | ||
|
||
### Using custom golangci plugin | ||
- Documentation reference https://golangci-lint.run/contributing/new-linters/#how-to-add-a-private-linter-to-golangci-lint | ||
- To add a custom private plugin the golangci must be build with `CGO_ENABLED=1` flag | ||
- It is required to have own build golangci binary, because this way we ensure the same used dependencies for building | ||
the our own custom plugin and the golangci. Without it we would not be able to plug-in our custom plugin | ||
- Once we have a ready binary we can built `cmd/plugin` `CGO_ENABLED=1 go build -buildmode=plugin -o wraperrchecker.so cmd/plugin/plugin.go` | ||
- Then we can add this custom built in plugin in the runtime using golangci config file | ||
|
||
### Wrap error checker | ||
- Checks if we wrap our errors correctly through our codebase | ||
|
||
``` | ||
// invalid | ||
if err != nil { | ||
fmt.Errorf("something went wrong") | ||
} | ||
// valid | ||
if err != nil { | ||
fmt.Errorf("something went wrong: %w", err) | ||
} | ||
``` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,45 @@ | ||
package main | ||
|
||
import ( | ||
"fmt" | ||
"os" | ||
"runtime/debug" | ||
|
||
"github.com/golangci/golangci-lint/pkg/commands" | ||
"github.com/golangci/golangci-lint/pkg/exitcodes" | ||
) | ||
|
||
var ( | ||
goVersion = "unknown" | ||
|
||
// Populated by goreleaser during build | ||
version = "master" | ||
commit = "?" | ||
date = "" | ||
) | ||
|
||
func main() { | ||
if buildInfo, available := debug.ReadBuildInfo(); available { | ||
goVersion = buildInfo.GoVersion | ||
|
||
if date == "" { | ||
version = buildInfo.Main.Version | ||
commit = fmt.Sprintf("(unknown, mod sum: %q)", buildInfo.Main.Sum) | ||
date = "(unknown)" | ||
} | ||
} | ||
|
||
info := commands.BuildInfo{ | ||
GoVersion: goVersion, | ||
Version: version, | ||
Commit: commit, | ||
Date: date, | ||
} | ||
|
||
e := commands.NewExecutor(info) | ||
|
||
if err := e.Execute(); err != nil { | ||
fmt.Fprintf(os.Stderr, "failed executing command with error %v\n", err) | ||
os.Exit(exitcodes.Failure) | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,19 @@ | ||
//go:build tools | ||
|
||
// This must be package main | ||
package main | ||
|
||
import ( | ||
"github.com/golang-cz/static-analysis/pkg/analyzer" | ||
"golang.org/x/tools/go/analysis" | ||
) | ||
|
||
// This must be defined and named 'AnalyzerPlugin' | ||
var AnalyzerPlugin analyzerPlugin | ||
|
||
type analyzerPlugin struct{} | ||
|
||
// This must be implemented | ||
func (*analyzerPlugin) GetAnalyzers() []*analysis.Analyzer { | ||
return []*analysis.Analyzer{analyzer.NewWrapErrChecker()} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,10 @@ | ||
package main | ||
|
||
import ( | ||
"github.com/golang-cz/static-analysis/pkg/analyzer" | ||
"golang.org/x/tools/go/analysis/singlechecker" | ||
) | ||
|
||
func main() { | ||
singlechecker.Main(analyzer.NewWrapErrChecker()) | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,185 @@ | ||
module github.com/golang-cz/static-analysis | ||
|
||
go 1.20 | ||
|
||
require ( | ||
github.com/golangci/golangci-lint v1.53.2 | ||
golang.org/x/tools v0.9.3 | ||
) | ||
|
||
require ( | ||
4d63.com/gocheckcompilerdirectives v1.2.1 // indirect | ||
4d63.com/gochecknoglobals v0.2.1 // indirect | ||
github.com/4meepo/tagalign v1.2.2 // indirect | ||
github.com/Abirdcfly/dupword v0.0.11 // indirect | ||
github.com/Antonboom/errname v0.1.10 // indirect | ||
github.com/Antonboom/nilnil v0.1.5 // indirect | ||
github.com/BurntSushi/toml v1.3.0 // indirect | ||
github.com/Djarvur/go-err113 v0.0.0-20210108212216-aea10b59be24 // indirect | ||
github.com/GaijinEntertainment/go-exhaustruct/v2 v2.3.0 // indirect | ||
github.com/Masterminds/semver v1.5.0 // indirect | ||
github.com/OpenPeeDeeP/depguard/v2 v2.1.0 // indirect | ||
github.com/alexkohler/nakedret/v2 v2.0.1 // indirect | ||
github.com/alexkohler/prealloc v1.0.0 // indirect | ||
github.com/alingse/asasalint v0.0.11 // indirect | ||
github.com/ashanbrown/forbidigo v1.5.1 // indirect | ||
github.com/ashanbrown/makezero v1.1.1 // indirect | ||
github.com/beorn7/perks v1.0.1 // indirect | ||
github.com/bkielbasa/cyclop v1.2.0 // indirect | ||
github.com/blizzy78/varnamelen v0.8.0 // indirect | ||
github.com/bombsimon/wsl/v3 v3.4.0 // indirect | ||
github.com/breml/bidichk v0.2.4 // indirect | ||
github.com/breml/errchkjson v0.3.1 // indirect | ||
github.com/butuzov/ireturn v0.2.0 // indirect | ||
github.com/butuzov/mirror v1.1.0 // indirect | ||
github.com/cespare/xxhash/v2 v2.1.2 // indirect | ||
github.com/charithe/durationcheck v0.0.10 // indirect | ||
github.com/chavacava/garif v0.0.0-20230227094218-b8c73b2037b8 // indirect | ||
github.com/curioswitch/go-reassign v0.2.0 // indirect | ||
github.com/daixiang0/gci v0.10.1 // indirect | ||
github.com/davecgh/go-spew v1.1.1 // indirect | ||
github.com/denis-tingaikin/go-header v0.4.3 // indirect | ||
github.com/esimonov/ifshort v1.0.4 // indirect | ||
github.com/ettle/strcase v0.1.1 // indirect | ||
github.com/fatih/color v1.15.0 // indirect | ||
github.com/fatih/structtag v1.2.0 // indirect | ||
github.com/firefart/nonamedreturns v1.0.4 // indirect | ||
github.com/fsnotify/fsnotify v1.5.4 // indirect | ||
github.com/fzipp/gocyclo v0.6.0 // indirect | ||
github.com/go-critic/go-critic v0.8.1 // indirect | ||
github.com/go-toolsmith/astcast v1.1.0 // indirect | ||
github.com/go-toolsmith/astcopy v1.1.0 // indirect | ||
github.com/go-toolsmith/astequal v1.1.0 // indirect | ||
github.com/go-toolsmith/astfmt v1.1.0 // indirect | ||
github.com/go-toolsmith/astp v1.1.0 // indirect | ||
github.com/go-toolsmith/strparse v1.1.0 // indirect | ||
github.com/go-toolsmith/typep v1.1.0 // indirect | ||
github.com/go-xmlfmt/xmlfmt v1.1.2 // indirect | ||
github.com/gobwas/glob v0.2.3 // indirect | ||
github.com/gofrs/flock v0.8.1 // indirect | ||
github.com/golang/protobuf v1.5.2 // indirect | ||
github.com/golangci/check v0.0.0-20180506172741-cfe4005ccda2 // indirect | ||
github.com/golangci/dupl v0.0.0-20180902072040-3e9179ac440a // indirect | ||
github.com/golangci/go-misc v0.0.0-20220329215616-d24fe342adfe // indirect | ||
github.com/golangci/gofmt v0.0.0-20220901101216-f2edd75033f2 // indirect | ||
github.com/golangci/lint-1 v0.0.0-20191013205115-297bf364a8e0 // indirect | ||
github.com/golangci/maligned v0.0.0-20180506175553-b1d89398deca // indirect | ||
github.com/golangci/misspell v0.4.0 // indirect | ||
github.com/golangci/revgrep v0.0.0-20220804021717-745bb2f7c2e6 // indirect | ||
github.com/golangci/unconvert v0.0.0-20180507085042-28b1c447d1f4 // indirect | ||
github.com/google/go-cmp v0.5.9 // indirect | ||
github.com/gordonklaus/ineffassign v0.0.0-20230107090616-13ace0543b28 // indirect | ||
github.com/gostaticanalysis/analysisutil v0.7.1 // indirect | ||
github.com/gostaticanalysis/comment v1.4.2 // indirect | ||
github.com/gostaticanalysis/forcetypeassert v0.1.0 // indirect | ||
github.com/gostaticanalysis/nilerr v0.1.1 // indirect | ||
github.com/hashicorp/errwrap v1.0.0 // indirect | ||
github.com/hashicorp/go-multierror v1.1.1 // indirect | ||
github.com/hashicorp/go-version v1.6.0 // indirect | ||
github.com/hashicorp/hcl v1.0.0 // indirect | ||
github.com/hexops/gotextdiff v1.0.3 // indirect | ||
github.com/inconshreveable/mousetrap v1.1.0 // indirect | ||
github.com/jgautheron/goconst v1.5.1 // indirect | ||
github.com/jingyugao/rowserrcheck v1.1.1 // indirect | ||
github.com/jirfag/go-printf-func-name v0.0.0-20200119135958-7558a9eaa5af // indirect | ||
github.com/julz/importas v0.1.0 // indirect | ||
github.com/kisielk/errcheck v1.6.3 // indirect | ||
github.com/kisielk/gotool v1.0.0 // indirect | ||
github.com/kkHAIKE/contextcheck v1.1.4 // indirect | ||
github.com/kulti/thelper v0.6.3 // indirect | ||
github.com/kunwardeep/paralleltest v1.0.7 // indirect | ||
github.com/kyoh86/exportloopref v0.1.11 // indirect | ||
github.com/ldez/gomoddirectives v0.2.3 // indirect | ||
github.com/ldez/tagliatelle v0.5.0 // indirect | ||
github.com/leonklingele/grouper v1.1.1 // indirect | ||
github.com/lufeee/execinquery v1.2.1 // indirect | ||
github.com/magiconair/properties v1.8.6 // indirect | ||
github.com/maratori/testableexamples v1.0.0 // indirect | ||
github.com/maratori/testpackage v1.1.1 // indirect | ||
github.com/matoous/godox v0.0.0-20230222163458-006bad1f9d26 // indirect | ||
github.com/mattn/go-colorable v0.1.13 // indirect | ||
github.com/mattn/go-isatty v0.0.17 // indirect | ||
github.com/mattn/go-runewidth v0.0.9 // indirect | ||
github.com/matttproud/golang_protobuf_extensions v1.0.1 // indirect | ||
github.com/mbilski/exhaustivestruct v1.2.0 // indirect | ||
github.com/mgechev/revive v1.3.2 // indirect | ||
github.com/mitchellh/go-homedir v1.1.0 // indirect | ||
github.com/mitchellh/mapstructure v1.5.0 // indirect | ||
github.com/moricho/tparallel v0.3.1 // indirect | ||
github.com/nakabonne/nestif v0.3.1 // indirect | ||
github.com/nbutton23/zxcvbn-go v0.0.0-20210217022336-fa2cb2858354 // indirect | ||
github.com/nishanths/exhaustive v0.10.0 // indirect | ||
github.com/nishanths/predeclared v0.2.2 // indirect | ||
github.com/nunnatsa/ginkgolinter v0.12.0 // indirect | ||
github.com/olekukonko/tablewriter v0.0.5 // indirect | ||
github.com/pelletier/go-toml v1.9.5 // indirect | ||
github.com/pelletier/go-toml/v2 v2.0.5 // indirect | ||
github.com/pmezard/go-difflib v1.0.0 // indirect | ||
github.com/polyfloyd/go-errorlint v1.4.2 // indirect | ||
github.com/prometheus/client_golang v1.12.1 // indirect | ||
github.com/prometheus/client_model v0.2.0 // indirect | ||
github.com/prometheus/common v0.32.1 // indirect | ||
github.com/prometheus/procfs v0.7.3 // indirect | ||
github.com/quasilyte/go-ruleguard v0.3.19 // indirect | ||
github.com/quasilyte/gogrep v0.5.0 // indirect | ||
github.com/quasilyte/regex/syntax v0.0.0-20210819130434-b3f0c404a727 // indirect | ||
github.com/quasilyte/stdinfo v0.0.0-20220114132959-f7386bf02567 // indirect | ||
github.com/ryancurrah/gomodguard v1.3.0 // indirect | ||
github.com/ryanrolds/sqlclosecheck v0.4.0 // indirect | ||
github.com/sanposhiho/wastedassign/v2 v2.0.7 // indirect | ||
github.com/sashamelentyev/interfacebloat v1.1.0 // indirect | ||
github.com/sashamelentyev/usestdlibvars v1.23.0 // indirect | ||
github.com/securego/gosec/v2 v2.16.0 // indirect | ||
github.com/shazow/go-diff v0.0.0-20160112020656-b6b7b6733b8c // indirect | ||
github.com/sirupsen/logrus v1.9.2 // indirect | ||
github.com/sivchari/containedctx v1.0.3 // indirect | ||
github.com/sivchari/nosnakecase v1.7.0 // indirect | ||
github.com/sivchari/tenv v1.7.1 // indirect | ||
github.com/sonatard/noctx v0.0.2 // indirect | ||
github.com/sourcegraph/go-diff v0.7.0 // indirect | ||
github.com/spf13/afero v1.8.2 // indirect | ||
github.com/spf13/cast v1.5.0 // indirect | ||
github.com/spf13/cobra v1.7.0 // indirect | ||
github.com/spf13/jwalterweatherman v1.1.0 // indirect | ||
github.com/spf13/pflag v1.0.5 // indirect | ||
github.com/spf13/viper v1.12.0 // indirect | ||
github.com/ssgreg/nlreturn/v2 v2.2.1 // indirect | ||
github.com/stbenjam/no-sprintf-host-port v0.1.1 // indirect | ||
github.com/stretchr/objx v0.5.0 // indirect | ||
github.com/stretchr/testify v1.8.4 // indirect | ||
github.com/subosito/gotenv v1.4.1 // indirect | ||
github.com/t-yuki/gocover-cobertura v0.0.0-20180217150009-aaee18c8195c // indirect | ||
github.com/tdakkota/asciicheck v0.2.0 // indirect | ||
github.com/tetafro/godot v1.4.11 // indirect | ||
github.com/timakin/bodyclose v0.0.0-20230421092635-574207250966 // indirect | ||
github.com/timonwong/loggercheck v0.9.4 // indirect | ||
github.com/tomarrell/wrapcheck/v2 v2.8.1 // indirect | ||
github.com/tommy-muehle/go-mnd/v2 v2.5.1 // indirect | ||
github.com/ultraware/funlen v0.0.3 // indirect | ||
github.com/ultraware/whitespace v0.0.5 // indirect | ||
github.com/uudashr/gocognit v1.0.6 // indirect | ||
github.com/xen0n/gosmopolitan v1.2.1 // indirect | ||
github.com/yagipy/maintidx v1.0.0 // indirect | ||
github.com/yeya24/promlinter v0.2.0 // indirect | ||
github.com/ykadowak/zerologlint v0.1.1 // indirect | ||
gitlab.com/bosi/decorder v0.2.3 // indirect | ||
go.tmz.dev/musttag v0.7.0 // indirect | ||
go.uber.org/atomic v1.7.0 // indirect | ||
go.uber.org/multierr v1.6.0 // indirect | ||
go.uber.org/zap v1.24.0 // indirect | ||
golang.org/x/exp v0.0.0-20230510235704-dd950f8aeaea // indirect | ||
golang.org/x/exp/typeparams v0.0.0-20230224173230-c95f2b4c22f2 // indirect | ||
golang.org/x/mod v0.10.0 // indirect | ||
golang.org/x/sync v0.2.0 // indirect | ||
golang.org/x/sys v0.8.0 // indirect | ||
golang.org/x/text v0.9.0 // indirect | ||
google.golang.org/protobuf v1.28.0 // indirect | ||
gopkg.in/ini.v1 v1.67.0 // indirect | ||
gopkg.in/yaml.v2 v2.4.0 // indirect | ||
gopkg.in/yaml.v3 v3.0.1 // indirect | ||
honnef.co/go/tools v0.4.3 // indirect | ||
mvdan.cc/gofumpt v0.5.0 // indirect | ||
mvdan.cc/interfacer v0.0.0-20180901003855-c20040233aed // indirect | ||
mvdan.cc/lint v0.0.0-20170908181259-adc824a0674b // indirect | ||
mvdan.cc/unparam v0.0.0-20221223090309-7455f1af531d // indirect | ||
) |
Oops, something went wrong.