From 826a49e1f4bfc8c1e811268df6fa709c146d2f91 Mon Sep 17 00:00:00 2001 From: Michael Shen Date: Fri, 15 Mar 2024 12:12:32 -0400 Subject: [PATCH 1/2] Add linting to CI Signed-off-by: Michael Shen --- .github/workflows/ci-go.yml | 20 ++++++++++++++++++++ .golangci.yml | 21 +++++++++++++++++++++ Makefile | 8 ++++++++ 3 files changed, 49 insertions(+) create mode 100644 .golangci.yml diff --git a/.github/workflows/ci-go.yml b/.github/workflows/ci-go.yml index 7db52cbad..e36993d4b 100644 --- a/.github/workflows/ci-go.yml +++ b/.github/workflows/ci-go.yml @@ -26,3 +26,23 @@ jobs: - name: 'Test' run: make test + lint: + permissions: + contents: 'read' + runs-on: 'ubuntu-latest' + steps: + - uses: actions/checkout@9bb56186c3b09b4f86b1c65136769dd318469633 # v4.1.2 + with: + fetch-depth: 1 + + - name: 'Set up Go' + uses: actions/setup-go@0c52d547c9bc32b1aa3301fd7a9cb496313a4491 # v5.0.0 + with: + go-version-file: 'go.work' + check-latest: true + + - name: 'Lint' + uses: golangci/golangci-lint-action@3cfe3a4abbb849e10058ce4af15d205b6da42804 # v4.0.0 + with: + version: 'v1.56.2' + args: '-v $(go list -f ''{{.Dir}}/...'' -m | xargs)' diff --git a/.golangci.yml b/.golangci.yml new file mode 100644 index 000000000..5794826c3 --- /dev/null +++ b/.golangci.yml @@ -0,0 +1,21 @@ +run: + timeout: 10m + skip-dirs-use-default: true + modules-download-mode: readonly + +issues: + # We want to make sure we get a full report every time. Setting these + # to zero disables the limit. + max-issues-per-linter: 0 + max-same-issues: 0 + +linters: + disable-all: true + enable: + - errcheck + - gosimple + - govet + - ineffassign + - staticcheck + - typecheck + - unused diff --git a/Makefile b/Makefile index 28ae121d6..cda579298 100644 --- a/Makefile +++ b/Makefile @@ -1,6 +1,14 @@ SHELL = /bin/bash +all: test lint + # There is currently no convenient way to run tests against a whole Go workspace # https://github.com/golang/go/issues/50745 test: go list -f '{{.Dir}}/...' -m | xargs go test -cover + +# There is currently no convenient way to run golangci-lint against a whole Go workspace +# https://github.com/golang/go/issues/50745 +MODULES := $(shell go list -f '{{.Dir}}/...' -m | xargs) +lint: + golangci-lint run -v $(MODULES) From fc612edd3e7c075b41265bd82176825fa1e3600c Mon Sep 17 00:00:00 2001 From: Michael Shen Date: Fri, 15 Mar 2024 12:12:42 -0400 Subject: [PATCH 2/2] Fix linting errors Signed-off-by: Michael Shen --- frontend/frontend.go | 2 +- internal/api/arm/error.go | 2 +- internal/api/arm/error_test.go | 60 +++++++++++++++++++ internal/api/hcpopenshiftcluster.go | 4 +- internal/api/hcpopenshiftclusternodepool.go | 2 +- .../hcpopenshiftclusternodepool.go | 2 +- .../api/v20240610preview/nodepoolprofile.go | 4 +- 7 files changed, 68 insertions(+), 8 deletions(-) create mode 100644 internal/api/arm/error_test.go diff --git a/frontend/frontend.go b/frontend/frontend.go index 596fce05a..011fc02c8 100644 --- a/frontend/frontend.go +++ b/frontend/frontend.go @@ -91,7 +91,7 @@ func (f *Frontend) Run(ctx context.Context, stop <-chan struct{}) { go func() { <-stop f.ready.Store(false) - f.server.Shutdown(ctx) + _ = f.server.Shutdown(ctx) }() } diff --git a/internal/api/arm/error.go b/internal/api/arm/error.go index f85c40f46..4426484b0 100644 --- a/internal/api/arm/error.go +++ b/internal/api/arm/error.go @@ -60,7 +60,7 @@ func (body *CloudErrorBody) String() string { if len(body.Details) > 0 { details = " Details: " for i, innerErr := range body.Details { - details := innerErr.String() + details += innerErr.String() if i < len(body.Details)-1 { details += ", " } diff --git a/internal/api/arm/error_test.go b/internal/api/arm/error_test.go new file mode 100644 index 000000000..f456102f2 --- /dev/null +++ b/internal/api/arm/error_test.go @@ -0,0 +1,60 @@ +package arm + +import "testing" + +func TestCloudErrorBody_String(t *testing.T) { + tests := []struct { + name string + body *CloudErrorBody + expected string + }{ + { + name: "One detail", + body: &CloudErrorBody{ + Code: "code", + Message: "message", + Target: "target", + Details: []CloudErrorBody{ + { + Code: "innercode", + Message: "innermessage", + Target: "innertarget", + Details: []CloudErrorBody{}, + }, + }, + }, + expected: "code: target: message Details: innercode: innertarget: innermessage", + }, + { + name: "Two details", + body: &CloudErrorBody{ + Code: "code", + Message: "message", + Target: "target", + Details: []CloudErrorBody{ + { + Code: "innercode", + Message: "innermessage", + Target: "innertarget", + Details: []CloudErrorBody{}, + }, + { + Code: "innercode2", + Message: "innermessage2", + Target: "innertarget2", + Details: []CloudErrorBody{}, + }, + }, + }, + expected: "code: target: message Details: innercode: innertarget: innermessage, innercode2: innertarget2: innermessage2", + }, + } + for _, test := range tests { + t.Run(test.name, func(t *testing.T) { + actual := test.body.String() + if test.expected != actual { + t.Errorf("expected: %v\ngot: %v", test.expected, actual) + } + }) + } +} diff --git a/internal/api/hcpopenshiftcluster.go b/internal/api/hcpopenshiftcluster.go index 66726afff..ec268c598 100644 --- a/internal/api/hcpopenshiftcluster.go +++ b/internal/api/hcpopenshiftcluster.go @@ -81,8 +81,8 @@ type NetworkProfile struct { // NodePoolAutoscaling represents a node pool autoscaling configuration. // Visibility for the entire struct is "read". type NodePoolAutoscaling struct { - MinReplicas int32 `json:minReplicas,omitempty"` - MaxReplicas int32 `json:maxReplicas,omitempty"` + MinReplicas int32 `json:"minReplicas,omitempty"` + MaxReplicas int32 `json:"maxReplicas,omitempty"` } // NodePoolProfile represents a worker node pool configuration. diff --git a/internal/api/hcpopenshiftclusternodepool.go b/internal/api/hcpopenshiftclusternodepool.go index ea2a0afc5..b502b34ed 100644 --- a/internal/api/hcpopenshiftclusternodepool.go +++ b/internal/api/hcpopenshiftclusternodepool.go @@ -18,5 +18,5 @@ type HCPOpenShiftClusterNodePool struct { // HCPOpenShiftClusterNodePool resource. type HCPOpenShiftClusterNodePoolProperties struct { ProvisioningState arm.ProvisioningState `json:"provisioningState,omitempty" visibility:"read"` - Profile NodePoolProfile `json:profile,omitempty" visibility:"read,create,update"` + Profile NodePoolProfile `json:"profile,omitempty" visibility:"read,create,update"` } diff --git a/internal/api/v20240610preview/hcpopenshiftclusternodepool.go b/internal/api/v20240610preview/hcpopenshiftclusternodepool.go index 5bdd8f8d4..bdb4c3ab8 100644 --- a/internal/api/v20240610preview/hcpopenshiftclusternodepool.go +++ b/internal/api/v20240610preview/hcpopenshiftclusternodepool.go @@ -19,5 +19,5 @@ type HCPOpenShiftClusterNodePool struct { // HCPOpenShiftClusterNodePool resource. type HCPOpenShiftClusterNodePoolProperties struct { ProvisioningState arm.ProvisioningState `json:"provisioningState,omitempty" visibility:"read"` - Profile api.VersionedNodePoolProfile `json:profile,omitempty" visibility:"read,create,update"` + Profile api.VersionedNodePoolProfile `json:"profile,omitempty" visibility:"read,create,update"` } diff --git a/internal/api/v20240610preview/nodepoolprofile.go b/internal/api/v20240610preview/nodepoolprofile.go index 0e6ca24bf..aa52a0031 100644 --- a/internal/api/v20240610preview/nodepoolprofile.go +++ b/internal/api/v20240610preview/nodepoolprofile.go @@ -6,8 +6,8 @@ package v20240610preview // NodePoolAutoscaling represents a node pool autoscaling configuration. // Visibility for the entire struct is "read". type NodePoolAutoscaling struct { - MinReplicas int32 `json:minReplicas,omitempty"` - MaxReplicas int32 `json:maxReplicas,omitempty"` + MinReplicas int32 `json:"minReplicas,omitempty"` + MaxReplicas int32 `json:"maxReplicas,omitempty"` } // NodePoolProfile represents a worker node pool configuration.