Skip to content

Commit

Permalink
Enable more linters
Browse files Browse the repository at this point in the history
  • Loading branch information
lucacome committed Jun 4, 2024
1 parent 212c0f6 commit 283b084
Show file tree
Hide file tree
Showing 114 changed files with 635 additions and 48 deletions.
9 changes: 8 additions & 1 deletion .golangci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,11 @@ linters-settings:
- name: blank-imports
- name: context-as-argument
- name: context-keys-type
- name: dot-imports
arguments:
- allowedPackages:
- github.com/onsi/gomega
- github.com/onsi/ginkgo/v2
- name: empty-block
- name: error-naming
- name: error-return
Expand Down Expand Up @@ -44,6 +49,7 @@ linters:
- errorlint
- ginkgolinter
- gocyclo
- godot
- gofmt
- gofumpt
- goimports
Expand All @@ -56,15 +62,16 @@ linters:
- misspell
- nilerr
- noctx
- paralleltest
- predeclared
- revive
- staticcheck
- tparallel
- typecheck
- unconvert
- unparam
- unused
- wastedassign
disable-all: true
issues:
max-issues-per-linter: 0
max-same-issues: 0
Expand Down
2 changes: 1 addition & 1 deletion Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -178,7 +178,7 @@ check-golangci-lint:

.PHONY: lint
lint: check-golangci-lint ## Run golangci-lint against code
golangci-lint run
golangci-lint run --fix

.PHONY: unit-test
unit-test: ## Run unit tests for the go code
Expand Down
4 changes: 2 additions & 2 deletions apis/v1alpha1/register.go
Original file line number Diff line number Diff line change
Expand Up @@ -9,10 +9,10 @@ import (
// GroupName specifies the group name used to register the objects.
const GroupName = "gateway.nginx.org"

// SchemeGroupVersion is group version used to register these objects
// SchemeGroupVersion is group version used to register these objects.
var SchemeGroupVersion = schema.GroupVersion{Group: GroupName, Version: "v1alpha1"}

// Resource takes an unqualified resource and returns a Group qualified GroupResource
// Resource takes an unqualified resource and returns a Group qualified GroupResource.
func Resource(resource string) schema.GroupResource {
return SchemeGroupVersion.WithResource(resource).GroupResource()
}
Expand Down
13 changes: 13 additions & 0 deletions cmd/gateway/commands_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -55,6 +55,7 @@ This test cannot be run with ginkgo. Ginkgo reports the following error:
* See https://github.com/spf13/cobra/issues/2104.
*/
func TestRootCmd(t *testing.T) {
t.Parallel()
testCase := flagTestCase{
name: "no flags",
args: nil,
Expand All @@ -65,6 +66,7 @@ func TestRootCmd(t *testing.T) {
}

func TestCommonFlagsValidation(t *testing.T) {
t.Parallel()
tests := []flagTestCase{
{
name: "valid flags",
Expand Down Expand Up @@ -130,16 +132,20 @@ func TestCommonFlagsValidation(t *testing.T) {
}

for _, test := range tests {
test := test
t.Run(test.name+"_static_mode", func(t *testing.T) {
t.Parallel()
testFlag(t, createStaticModeCommand(), test)
})
t.Run(test.name+"_provisioner_mode", func(t *testing.T) {
t.Parallel()
testFlag(t, createProvisionerModeCommand(), test)
})
}
}

func TestStaticModeCmdFlagValidation(t *testing.T) {
t.Parallel()
tests := []flagTestCase{
{
name: "valid flags",
Expand Down Expand Up @@ -380,14 +386,17 @@ func TestStaticModeCmdFlagValidation(t *testing.T) {
// common flags validation is tested separately

for _, test := range tests {
test := test
t.Run(test.name, func(t *testing.T) {
t.Parallel()
cmd := createStaticModeCommand()
testFlag(t, cmd, test)
})
}
}

func TestProvisionerModeCmdFlagValidation(t *testing.T) {
t.Parallel()
testCase := flagTestCase{
name: "valid flags",
args: []string{
Expand Down Expand Up @@ -418,6 +427,7 @@ This test cannot be run with ginkgo. Ginkgo reports the following error for the
* See https://github.com/spf13/cobra/issues/2104.
*/
func TestSleepCmdFlagValidation(t *testing.T) {
t.Parallel()
tests := []flagTestCase{
{
name: "valid flags",
Expand Down Expand Up @@ -450,14 +460,17 @@ func TestSleepCmdFlagValidation(t *testing.T) {
}

for _, test := range tests {
test := test
t.Run(test.name, func(t *testing.T) {
t.Parallel()
cmd := createSleepCommand()
testFlag(t, cmd, test)
})
}
}

func TestParseFlags(t *testing.T) {
t.Parallel()
g := NewWithT(t)

flagSet := pflag.NewFlagSet("flagSet", 0)
Expand Down
2 changes: 1 addition & 1 deletion cmd/gateway/main.go
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ import (
"os"
)

// Set during go build
// Set during go build.
var (
version string
commit string
Expand Down
4 changes: 2 additions & 2 deletions cmd/gateway/validation.go
Original file line number Diff line number Diff line change
Expand Up @@ -163,15 +163,15 @@ func validateEndpoint(endpoint string) error {
return fmt.Errorf("%q must be in the format <host>:<port>", endpoint)
}

// validatePort makes sure a given port is inside the valid port range for its usage
// validatePort makes sure a given port is inside the valid port range for its usage.
func validatePort(port int) error {
if port < 1024 || port > 65535 {
return fmt.Errorf("port outside of valid port range [1024 - 65535]: %v", port)
}
return nil
}

// ensureNoPortCollisions checks if the same port has been defined multiple times
// ensureNoPortCollisions checks if the same port has been defined multiple times.
func ensureNoPortCollisions(ports ...int) error {
seen := make(map[int]struct{})

Expand Down
28 changes: 28 additions & 0 deletions cmd/gateway/validation_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@ import (
)

func TestValidateGatewayControllerName(t *testing.T) {
t.Parallel()
tests := []struct {
name string
value string
Expand Down Expand Up @@ -51,7 +52,9 @@ func TestValidateGatewayControllerName(t *testing.T) {
}

for _, test := range tests {
test := test
t.Run(test.name, func(t *testing.T) {
t.Parallel()
g := NewWithT(t)

err := validateGatewayControllerName(test.value)
Expand All @@ -66,6 +69,7 @@ func TestValidateGatewayControllerName(t *testing.T) {
}

func TestValidateResourceName(t *testing.T) {
t.Parallel()
tests := []struct {
name string
value string
Expand Down Expand Up @@ -114,7 +118,9 @@ func TestValidateResourceName(t *testing.T) {
}

for _, test := range tests {
test := test
t.Run(test.name, func(t *testing.T) {
t.Parallel()
g := NewWithT(t)

err := validateResourceName(test.value)
Expand All @@ -129,6 +135,7 @@ func TestValidateResourceName(t *testing.T) {
}

func TestValidateNamespaceName(t *testing.T) {
t.Parallel()
tests := []struct {
name string
value string
Expand Down Expand Up @@ -177,7 +184,9 @@ func TestValidateNamespaceName(t *testing.T) {
}

for _, test := range tests {
test := test
t.Run(test.name, func(t *testing.T) {
t.Parallel()
g := NewWithT(t)

err := validateNamespaceName(test.value)
Expand All @@ -192,6 +201,7 @@ func TestValidateNamespaceName(t *testing.T) {
}

func TestParseNamespacedResourceName(t *testing.T) {
t.Parallel()
tests := []struct {
name string
value string
Expand Down Expand Up @@ -239,7 +249,9 @@ func TestParseNamespacedResourceName(t *testing.T) {
}

for _, test := range tests {
test := test
t.Run(test.name, func(t *testing.T) {
t.Parallel()
g := NewWithT(t)

nsName, err := parseNamespacedResourceName(test.value)
Expand All @@ -256,6 +268,7 @@ func TestParseNamespacedResourceName(t *testing.T) {
}

func TestValidateQualifiedName(t *testing.T) {
t.Parallel()
tests := []struct {
name string
value string
Expand Down Expand Up @@ -304,7 +317,9 @@ func TestValidateQualifiedName(t *testing.T) {
}

for _, test := range tests {
test := test
t.Run(test.name, func(t *testing.T) {
t.Parallel()
g := NewWithT(t)

err := validateQualifiedName(test.value)
Expand All @@ -318,6 +333,7 @@ func TestValidateQualifiedName(t *testing.T) {
}

func TestValidateURL(t *testing.T) {
t.Parallel()
tests := []struct {
name string
url string
Expand Down Expand Up @@ -366,7 +382,9 @@ func TestValidateURL(t *testing.T) {
}

for _, tc := range tests {
tc := tc
t.Run(tc.name, func(t *testing.T) {
t.Parallel()
g := NewWithT(t)

err := validateURL(tc.url)
Expand All @@ -380,6 +398,7 @@ func TestValidateURL(t *testing.T) {
}

func TestValidateIP(t *testing.T) {
t.Parallel()
tests := []struct {
name string
expSubMsg string
Expand All @@ -406,7 +425,9 @@ func TestValidateIP(t *testing.T) {
}

for _, tc := range tests {
tc := tc
t.Run(tc.name, func(t *testing.T) {
t.Parallel()
g := NewWithT(t)

err := validateIP(tc.ip)
Expand All @@ -420,6 +441,7 @@ func TestValidateIP(t *testing.T) {
}

func TestValidateEndpoint(t *testing.T) {
t.Parallel()
tests := []struct {
name string
endp string
Expand Down Expand Up @@ -473,7 +495,9 @@ func TestValidateEndpoint(t *testing.T) {
}

for _, tc := range tests {
tc := tc
t.Run(tc.name, func(t *testing.T) {
t.Parallel()
g := NewWithT(t)

err := validateEndpoint(tc.endp)
Expand All @@ -487,6 +511,7 @@ func TestValidateEndpoint(t *testing.T) {
}

func TestValidatePort(t *testing.T) {
t.Parallel()
tests := []struct {
name string
port int
Expand All @@ -510,7 +535,9 @@ func TestValidatePort(t *testing.T) {
}

for _, tc := range tests {
tc := tc
t.Run(tc.name, func(t *testing.T) {
t.Parallel()
g := NewWithT(t)

err := validatePort(tc.port)
Expand All @@ -524,6 +551,7 @@ func TestValidatePort(t *testing.T) {
}

func TestEnsureNoPortCollisions(t *testing.T) {
t.Parallel()
g := NewWithT(t)

g.Expect(ensureNoPortCollisions(9113, 8081)).To(Succeed())
Expand Down
1 change: 1 addition & 0 deletions go.mod
Original file line number Diff line number Diff line change
Expand Up @@ -72,6 +72,7 @@ require (
go.opentelemetry.io/otel/sdk v1.27.0 // indirect
go.opentelemetry.io/otel/trace v1.27.0 // indirect
go.opentelemetry.io/proto/otlp v1.2.0 // indirect
go.uber.org/goleak v1.3.0 // indirect
go.uber.org/multierr v1.11.0 // indirect
golang.org/x/exp v0.0.0-20240416160154-fe59bbe5cc7f // indirect
golang.org/x/mod v0.17.0 // indirect
Expand Down
2 changes: 2 additions & 0 deletions internal/framework/conditions/conditions_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@ import (
)

func TestDeduplicateConditions(t *testing.T) {
t.Parallel()
conds := []Condition{
{
Type: "Type1",
Expand Down Expand Up @@ -61,6 +62,7 @@ func TestDeduplicateConditions(t *testing.T) {
}

func TestConvertConditions(t *testing.T) {
t.Parallel()
conds := []Condition{
{
Type: "Type1",
Expand Down
1 change: 1 addition & 0 deletions internal/framework/controller/controller_suite_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@ import (
)

func TestControllers(t *testing.T) {
t.Parallel()
RegisterFailHandler(Fail)
RunSpecs(t, "Controller Suite")
}
3 changes: 3 additions & 0 deletions internal/framework/controller/filter/filter_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@ import (
)

func TestCreateSingleResourceFilter(t *testing.T) {
t.Parallel()
targetNsName := types.NamespacedName{Namespace: "test", Name: "resource"}

g := NewWithT(t)
Expand Down Expand Up @@ -50,7 +51,9 @@ func TestCreateSingleResourceFilter(t *testing.T) {
}

for _, test := range tests {
test := test
t.Run(test.name, func(t *testing.T) {
t.Parallel()
g := NewWithT(t)
shouldProcess, msg := filter(test.nsname)
g.Expect(shouldProcess).To(Equal(test.expectedShouldProcess))
Expand Down
Loading

0 comments on commit 283b084

Please sign in to comment.