-
Notifications
You must be signed in to change notification settings - Fork 18
/
Copy path.golangci.yaml
114 lines (99 loc) · 3.3 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
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
version: "2"
linters:
default: all
disable:
# disabled, but which we should enable with discussion
- wrapcheck # checks that errors are wrapped; currently not done anywhere
# disabled because we're not compliant, but which we should think about
- exhaustruct # checks that properties in structs are exhaustively defined; may be a good idea
- testpackage # requires tests in test packages like `river_test`
# disabled because they're annoying/bad
- cyclop # screams into the void at "cyclomatic complexity"
- funlen # screams when functions are more than 60 lines long; what are we even doing here guys
- interfacebloat # we do in fact want >10 methods on the Adapter interface or wherever we see fit.
- gocognit # yells that "cognitive complexity" is too high; why
- gocyclo # ANOTHER "cyclomatic complexity" checker (see also "cyclop" and "gocyclo")
- godox # bans TODO statements; total non-starter at the moment
- err113 # wants all errors to be defined as variables at the package level; quite obnoxious
- maintidx # ANOTHER ANOTHER "cyclomatic complexity" lint (see also "cyclop" and "gocyclo")
- mnd # detects "magic numbers", which it defines as any number; annoying
- nestif # yells when if blocks are nested; what planet do these people come from?
- ireturn # bans returning interfaces; questionable as is, but also buggy as hell; very, very annoying
- lll # restricts maximum line length; annoying
- nlreturn # requires a blank line before returns; annoying
- wsl # a bunch of style/whitespace stuff; annoying
settings:
depguard:
rules:
all:
files: ["$all"]
deny:
- desc: Use `github.com/google/uuid` package for UUIDs instead.
pkg: github.com/xtgo/uuid
forbidigo:
forbid:
- msg: Use `require` variants instead.
pattern: ^assert\.
- msg: Use `Func` suffix for function variables instead.
pattern: Fn\b
- msg: Use built-in `max` function instead.
pattern: \bmath\.Max\b
- msg: Use built-in `min` function instead.
pattern: \bmath\.Min\b
gomoddirectives:
replace-local: true
gosec:
excludes:
- G404 # use of non-crypto random; overly broad for our use case
revive:
rules:
- name: unused-parameter
disabled: true
tagliatelle:
case:
rules:
json: snake
testifylint:
enable-all: true
disable:
- go-require
varnamelen:
ignore-names:
- db
- eg
- f
- i
- id
- j
- mu
- r
- rw # common convention for http.ResponseWriter
- sb # common convention for string builder
- t
- tt # common convention for table tests
- tx
- w
- wg
exclusions:
generated: lax
presets:
- comments
- common-false-positives
- legacy
- std-error-handling
rules:
- path: (.+)\.go$
text: Error return value of .(\w+\.Rollback(.*)). is not checked
formatters:
enable:
- gci
- gofmt
- gofumpt
- goimports
settings:
gci:
sections:
- Standard
- Default
- Prefix(github.com/riverqueue)
- Prefix(riverqueue.com/riverpro)