-
Notifications
You must be signed in to change notification settings - Fork 23
/
.golangci.yaml
64 lines (61 loc) · 2.42 KB
/
.golangci.yaml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
# See https://github.com/golangci/golangci-lint/blob/master/.golangci.yml for an updated example.
run:
# If set we pass it to "go list -mod={option}". From "go help modules":
# If invoked with -mod=readonly, the go command is disallowed from the implicit
# automatic updating of go.mod described above. Instead, it fails when any changes
# to go.mod are needed. This setting is most useful to check that go.mod does
# not need updates, such as in a continuous integration and testing system.
# If invoked with -mod=vendor, the go command assumes that the vendor
# directory holds the correct copies of dependencies and ignores
# the dependency descriptions in go.mod.
#
# Allowed values: readonly|vendor|mod
modules-download-mode: readonly
linters-settings:
depguard:
rules:
tests:
deny:
- pkg: github.com/stretchr/testify/assert
desc: "Use github.com/stretchr/testify/require instead of testify/assert"
- pkg: github.com/onsi/gomega
desc: "Although Ginkgo is used in kubebuilder, use testify instead. Ginkgo is bloated providing little value."
- pkg: github.com/onsi/ginkgo/v2
desc: "Although Ginkgo is used in kubebuilder, use testify instead. Ginkgo is bloated providing little value."
- pkg: github.com/onsi/ginkgo
desc: "Although Ginkgo is used in kubebuilder, use testify instead. Ginkgo is bloated providing little value."
govet:
check-shadowing: true
misspell:
locale: US
ignore-words:
- "statuser"
nakedret:
# make an issue if func has more lines of code than this setting and it has naked returns; default is 30
max-func-lines: 0 # completely disallow naked returns
nolintlint:
allow-leading-space: true # don't require machine-readable nolint directives (i.e. with no leading space)
allow-unused: false # report any unused nolint directives
require-explanation: false # don't require an explanation for nolint directives
require-specific: false # don't require nolint directives to be specific about which linter is being skipped
linters:
disable-all: true
enable:
- bodyclose
- depguard
- errcheck
- exportloopref
- goimports
- goprintffuncname
- gosimple
- govet
- ineffassign
- misspell
- nakedret
- noctx
- nolintlint
- staticcheck
- stylecheck # replacement for golint
- unconvert
- unused
- whitespace