2023-03-28 21:12:41 +01:00
|
|
|
# Copyright (c) HashiCorp, Inc.
|
2023-08-11 09:12:13 -04:00
|
|
|
# SPDX-License-Identifier: BUSL-1.1
|
2023-03-28 21:12:41 +01:00
|
|
|
|
2020-03-11 21:18:03 -04:00
|
|
|
linters:
|
|
|
|
disable-all: true
|
|
|
|
enable:
|
|
|
|
- gofmt
|
|
|
|
- govet
|
2020-04-16 13:35:28 -04:00
|
|
|
- unconvert
|
2020-05-14 17:02:52 -04:00
|
|
|
- staticcheck
|
2020-06-05 18:08:30 -04:00
|
|
|
- ineffassign
|
2020-06-23 13:43:24 -04:00
|
|
|
- unparam
|
2022-01-20 11:36:29 -06:00
|
|
|
- forbidigo
|
2022-09-02 09:56:40 -07:00
|
|
|
- gomodguard
|
|
|
|
- depguard
|
2020-03-11 21:18:03 -04:00
|
|
|
|
|
|
|
issues:
|
|
|
|
# Disable the default exclude list so that all excludes are explicitly
|
|
|
|
# defined in this file.
|
|
|
|
exclude-use-default: false
|
|
|
|
|
2020-05-14 17:02:52 -04:00
|
|
|
exclude-rules:
|
|
|
|
# Temp Ignore SA9004: only the first constant in this group has an explicit type
|
|
|
|
# https://staticcheck.io/docs/checks#SA9004
|
|
|
|
- linters: [staticcheck]
|
2023-04-28 12:14:37 -05:00
|
|
|
text: "SA9004:"
|
2022-05-24 18:44:54 -07:00
|
|
|
|
2022-10-24 12:33:22 -04:00
|
|
|
- linters: [staticcheck]
|
|
|
|
text: 'SA1019: "io/ioutil" has been deprecated since Go 1.16'
|
|
|
|
|
2023-09-06 16:46:25 -06:00
|
|
|
# Allow usage of deprecated values.
|
|
|
|
- linters: [ staticcheck ]
|
|
|
|
text: 'SA1019:'
|
2024-04-09 19:23:04 -06:00
|
|
|
path: "(agent/grpc-external|agent/grpc-internal)"
|
2023-09-06 16:46:25 -06:00
|
|
|
|
2020-06-23 13:43:24 -04:00
|
|
|
# An argument that always receives the same value is often not a problem.
|
|
|
|
- linters: [unparam]
|
2023-04-28 12:14:37 -05:00
|
|
|
text: "always receives"
|
2020-06-23 13:43:24 -04:00
|
|
|
|
|
|
|
# Often functions will implement an interface that returns an error without
|
|
|
|
# needing to return an error. Sometimes the error return value is unnecessary
|
|
|
|
# but a linter can not tell the difference.
|
|
|
|
- linters: [unparam]
|
|
|
|
text: 'result \d+ \(error\) is always nil'
|
|
|
|
|
|
|
|
# Allow unused parameters to start with an underscore. Arguments with a name
|
|
|
|
# of '_' are already ignored.
|
|
|
|
# Ignoring longer names that start with underscore allow for better
|
|
|
|
# self-documentation than a single underscore by itself. Underscore arguments
|
|
|
|
# should generally only be used when a function is implementing an interface.
|
|
|
|
- linters: [unparam]
|
2023-04-28 12:14:37 -05:00
|
|
|
text: "`_[^`]*` is unused"
|
2020-06-23 13:43:24 -04:00
|
|
|
|
|
|
|
# Temp ignore some common unused parameters so that unparam can be added
|
|
|
|
# incrementally.
|
|
|
|
- linters: [unparam]
|
2023-04-28 12:14:37 -05:00
|
|
|
text: "`(t|resp|req|entMeta)` is unused"
|
2020-06-23 13:43:24 -04:00
|
|
|
|
2023-08-22 09:46:03 -05:00
|
|
|
# Temp ignore everything in _ce(_test).go and _ent(_test).go. Many of these
|
2020-06-23 13:43:24 -04:00
|
|
|
# could use underscore to ignore the unused arguments, but the "always returns"
|
2023-08-22 09:46:03 -05:00
|
|
|
# issue will likely remain in CE, and will need to be excluded.
|
2020-06-23 13:43:24 -04:00
|
|
|
- linters: [unparam]
|
2023-08-22 09:46:03 -05:00
|
|
|
path: "(_ce.go|_ce_test.go|_ent.go|_ent_test.go)"
|
2020-05-14 17:02:52 -04:00
|
|
|
|
2020-03-11 21:18:03 -04:00
|
|
|
linters-settings:
|
2022-10-24 11:48:02 -05:00
|
|
|
govet:
|
|
|
|
check-shadowing: true
|
|
|
|
enable-all: true
|
|
|
|
disable:
|
|
|
|
- fieldalignment
|
|
|
|
- nilness
|
|
|
|
- shadow
|
|
|
|
- unusedwrite
|
2020-03-11 21:18:03 -04:00
|
|
|
gofmt:
|
2020-06-16 13:19:31 -04:00
|
|
|
simplify: true
|
2022-01-20 11:36:29 -06:00
|
|
|
forbidigo:
|
|
|
|
# Forbid the following identifiers (list of regexp).
|
2024-06-11 15:17:12 -05:00
|
|
|
# Format includes custom message based on https://github.com/ashanbrown/forbidigo/pull/11
|
2022-01-20 11:36:29 -06:00
|
|
|
forbid:
|
2024-06-11 15:17:12 -05:00
|
|
|
- '\bhtml\/template\b(# Use text/template instead)?'
|
2022-11-10 10:26:01 -06:00
|
|
|
- '\bioutil\b(# Use io and os packages instead of ioutil)?'
|
2022-01-20 13:07:10 -05:00
|
|
|
- '\brequire\.New\b(# Use package-level functions with explicit TestingT)?'
|
|
|
|
- '\bassert\.New\b(# Use package-level functions with explicit TestingT)?'
|
2022-01-20 11:36:29 -06:00
|
|
|
# Exclude godoc examples from forbidigo checks.
|
|
|
|
# Default: true
|
|
|
|
exclude_godoc_examples: false
|
2022-09-02 09:56:40 -07:00
|
|
|
gomodguard:
|
|
|
|
blocked:
|
|
|
|
# List of blocked modules.
|
|
|
|
modules:
|
|
|
|
# Blocked module.
|
|
|
|
- github.com/hashicorp/net-rpc-msgpackrpc:
|
|
|
|
recommendations:
|
|
|
|
- github.com/hashicorp/consul-net-rpc/net-rpc-msgpackrpc
|
|
|
|
- github.com/hashicorp/go-msgpack:
|
|
|
|
recommendations:
|
|
|
|
- github.com/hashicorp/consul-net-rpc/go-msgpack
|
2023-06-05 16:08:39 -04:00
|
|
|
- github.com/golang/protobuf:
|
|
|
|
recommendations:
|
|
|
|
- google.golang.org/protobuf
|
2022-09-02 09:56:40 -07:00
|
|
|
|
|
|
|
depguard:
|
2024-01-12 09:57:38 -05:00
|
|
|
rules:
|
|
|
|
main:
|
|
|
|
listMode: lax
|
|
|
|
deny:
|
|
|
|
- pkg: net/rpc
|
|
|
|
desc: "only use forked copy in github.com/hashicorp/consul-net-rpc/net/rpc"
|
|
|
|
- pkg: github.com/golang/protobuf
|
|
|
|
desc: "only use google.golang.org/protobuf"
|
2020-03-24 16:14:12 -04:00
|
|
|
|
|
|
|
run:
|
2020-06-03 16:50:35 -04:00
|
|
|
timeout: 10m
|
2022-05-05 12:42:52 -05:00
|
|
|
concurrency: 4
|
2023-06-05 16:08:39 -04:00
|
|
|
skip-dirs-use-default: false
|