diff --git a/.github/workflows/pr_build.yaml b/.github/workflows/pr_build.yaml index 19b26e6a..055f275f 100644 --- a/.github/workflows/pr_build.yaml +++ b/.github/workflows/pr_build.yaml @@ -3,7 +3,7 @@ on: pull_request: {} workflow_dispatch: {} env: - GO_VERSION: 1.19 + GO_VERSION: 1.21 jobs: lint-linux: runs-on: ubuntu-latest diff --git a/Makefile b/Makefile index 86ca5918..40910986 100644 --- a/Makefile +++ b/Makefile @@ -39,6 +39,8 @@ ifeq ($(arch1),x86_64) arch2=amd64 else ifeq ($(arch1),aarch64) arch2=arm64 +else ifeq ($(arch1),arm64) +arch2=arm64 else $(error unsupported ARCH: $(arch1)) endif @@ -70,7 +72,7 @@ protoc_gen_go_grpc_base_dir := $(build_dir)/protoc-gen-go-grpc protoc_gen_go_grpc_dir := $(protoc_gen_go_grpc_base_dir)/$(protoc_gen_go_grpc_version)-go$(go_version) protoc_gen_go_grpc_bin := $(protoc_gen_go_grpc_dir)/protoc-gen-go-grpc -golangci_lint_version = v1.50.1 +golangci_lint_version = v1.57.2 golangci_lint_dir = $(build_dir)/golangci_lint/$(golangci_lint_version) golangci_lint_bin = $(golangci_lint_dir)/golangci-lint @@ -81,7 +83,7 @@ apiprotos := \ # Toolchain ############################################################################# -go_version_full := 1.19.12 +go_version_full := 1.21.8 go_version := $(go_version_full:.0=) go_dir := $(build_dir)/go/$(go_version) diff --git a/v2/.golangci.yml b/v2/.golangci.yml index f8d7695e..90bf4c66 100644 --- a/v2/.golangci.yml +++ b/v2/.golangci.yml @@ -2,20 +2,9 @@ run: # timeout for analysis, e.g. 30s, 5m, default is 1m deadline: 10m - # include examples - skip-dirs-use-default: false - - skip-dirs: - - testdata$ - - test/mock - - skip-files: - - ".*\\.pb\\.go" - linters: enable: - bodyclose - - depguard - goimports - revive - gosec @@ -28,6 +17,16 @@ linters: - gocritic issues: + # include examples + exclude-dirs-use-default: false + + exclude-dirs: + - testdata$ + - test/mock + + exclude-files: + - ".*\\.pb\\.go" + exclude-rules: # exclude some lints from examples test files - path: examples_test.go @@ -40,3 +39,7 @@ linters-settings: golint: # minimal confidence for issues, default is 0.8 min-confidence: 0.0 + revive: + rules: + - name: unused-parameter + disabled: true # It's useful to name parameters in library code for better readability diff --git a/v2/internal/test/fakeworkloadapi/workload_api.go b/v2/internal/test/fakeworkloadapi/workload_api.go index 0668545d..fdfefb39 100644 --- a/v2/internal/test/fakeworkloadapi/workload_api.go +++ b/v2/internal/test/fakeworkloadapi/workload_api.go @@ -50,7 +50,7 @@ func New(tb testing.TB) *WorkloadAPI { x509BundlesChans: make(map[chan *workload.X509BundlesResponse]struct{}), } - listener, err := newListener() + listener, err := newListener(tb) require.NoError(tb, err) server := grpc.NewServer() diff --git a/v2/internal/test/fakeworkloadapi/workload_api_posix.go b/v2/internal/test/fakeworkloadapi/workload_api_posix.go index 8572e33d..473966d8 100644 --- a/v2/internal/test/fakeworkloadapi/workload_api_posix.go +++ b/v2/internal/test/fakeworkloadapi/workload_api_posix.go @@ -6,9 +6,10 @@ package fakeworkloadapi import ( "fmt" "net" + "testing" ) -func newListener() (net.Listener, error) { +func newListener(_ testing.TB) (net.Listener, error) { return net.Listen("tcp", "localhost:0") } diff --git a/v2/internal/test/fakeworkloadapi/workload_api_windows.go b/v2/internal/test/fakeworkloadapi/workload_api_windows.go index 6989e32b..348eeeea 100644 --- a/v2/internal/test/fakeworkloadapi/workload_api_windows.go +++ b/v2/internal/test/fakeworkloadapi/workload_api_windows.go @@ -4,12 +4,13 @@ package fakeworkloadapi import ( + "crypto/rand" "fmt" - "math/rand" + "math" + "math/big" "net" "strings" "testing" - "time" "github.com/Microsoft/go-winio" "github.com/spiffe/go-spiffe/v2/proto/spiffe/workload" @@ -17,13 +18,15 @@ import ( "google.golang.org/grpc" ) +var maxUint64 = maxBigUint64() + func NewWithNamedPipeListener(tb testing.TB) *WorkloadAPI { w := &WorkloadAPI{ x509Chans: make(map[chan *workload.X509SVIDResponse]struct{}), jwtBundlesChans: make(map[chan *workload.JWTBundlesResponse]struct{}), } - listener, err := winio.ListenPipe(fmt.Sprintf(`\\.\pipe\go-spiffe-test-pipe-%x`, rand.Uint64()), nil) //nolint: gosec // not use for crypto + listener, err := winio.ListenPipe(fmt.Sprintf(`\\.\pipe\go-spiffe-test-pipe-%x`, randUint64(tb)), nil) require.NoError(tb, err) server := grpc.NewServer() @@ -45,12 +48,22 @@ func GetPipeName(s string) string { return strings.TrimPrefix(s, `\\.\pipe`) } -func init() { - rand.Seed(time.Now().UnixNano()) +func maxBigUint64() *big.Int { + n := big.NewInt(0) + return n.SetUint64(math.MaxUint64) +} + +func randUint64(t testing.TB) uint64 { + n, err := rand.Int(rand.Reader, maxUint64) + if err != nil { + t.Fail() + } + + return n.Uint64() } -func newListener() (net.Listener, error) { - return winio.ListenPipe(fmt.Sprintf(`\\.\pipe\go-spiffe-test-pipe-%x`, rand.Uint64()), nil) //nolint: gosec // not used for crypto +func newListener(tb testing.TB) (net.Listener, error) { + return winio.ListenPipe(fmt.Sprintf(`\\.\pipe\go-spiffe-test-pipe-%x`, randUint64(tb)), nil) } func getTargetName(addr net.Addr) string {