From 5e3c839e330e26d759ce60f2524bc930711a8396 Mon Sep 17 00:00:00 2001 From: Sebastiaan van Stijn Date: Sat, 14 Jan 2023 16:03:29 +0100 Subject: [PATCH 1/2] go.mod: update minimum version to go1.17 committed the result of: go mod tidy -go=1.17 -compat=1.13 Signed-off-by: Sebastiaan van Stijn --- go.mod | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/go.mod b/go.mod index a3778a5..50a4a88 100644 --- a/go.mod +++ b/go.mod @@ -1,6 +1,6 @@ module github.com/moby/ipvs -go 1.13 +go 1.17 require ( github.com/sirupsen/logrus v1.4.2 @@ -8,3 +8,5 @@ require ( github.com/vishvananda/netns v0.0.0-20191106174202-0a2b9b5464df golang.org/x/sys v0.0.0-20200302150141-5c8b2ff67527 ) + +require github.com/konsorten/go-windows-terminal-sequences v1.0.1 // indirect From 9b4cd23a2ae3336230f61e5845ae6194667d7ffb Mon Sep 17 00:00:00 2001 From: Sebastiaan van Stijn Date: Sat, 14 Jan 2023 14:15:43 +0100 Subject: [PATCH 2/2] gha: update to go >= 1.17, fix and update actions - update go versions to go1.17, and latest (1.19.x) - fix incorrect `go-versions` (plural) in the matrix, and rename "platform" to "os" (which looks to be what we use elsewhere) - update github action versions - set permissions and timeout for github actions - switch to use the golangci-lint action (instead of using a container) - update golangci-lint to 1.50.1, which is needed for compatibility with current go versions - replace "golint" with "revive" as golint is deprecated. - update how we use `sudo` for testing (see [this tweet][1]) - add a go mod tidy check [1]: https://twitter.com/kolyshkin/status/1367697997979557897 Signed-off-by: Sebastiaan van Stijn --- .github/workflows/test.yml | 73 ++++++++++++++++++++++++++++++-------- .golangci.yml | 8 +++++ 2 files changed, 67 insertions(+), 14 deletions(-) create mode 100644 .golangci.yml diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index 80ff19f..bf6ed33 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -1,32 +1,77 @@ name: Test -on: [push, pull_request] +on: + push: + tags: + - v* + branches: + - master + - main + pull_request: + branches: + - master + - main + jobs: test: + permissions: + contents: read # for actions/checkout to fetch code + timeout-minutes: 10 + strategy: matrix: - go-versions: [1.12.x, 1.13.x, 1.14.x] - platform: [ubuntu-latest] - runs-on: ${{ matrix.platform }} + # test against the "oldest" supported version and the current version + # of go. Go 1.17 is kept in this matrix as it is the minimum version + # specified in go.mod, and maintaining compatibility with go 1.17 is + # currently not much of a burden. Most projects using this module are + # using newer versions than that, so we can drop the old version if + # it becomes too much of a burden. + go-version: [1.17.x, 1.19.x] + os: [ubuntu-latest] + runs-on: ${{ matrix.os }} steps: - name: Install Go - uses: actions/setup-go@v1 + uses: actions/setup-go@v3 with: go-version: ${{ matrix.go-version }} - name: Checkout code - uses: actions/checkout@v2 + uses: actions/checkout@v3 + - name: go mod tidy + run: | + go mod tidy + git diff --exit-code - name: Ensure IPVS module - run: sudo modprobe ip_vs + run: | + sudo modprobe ip_vs - name: Test - run: sudo go test -v ./... + run: | + go test -exec "sudo -n" -v ./... lint: + permissions: + contents: read # for actions/checkout to fetch code + pull-requests: read # for golangci/golangci-lint-action to fetch pull requests + timeout-minutes: 10 runs-on: ubuntu-latest steps: - name: Install Go - uses: actions/setup-go@v1 + uses: actions/setup-go@v3 + with: + # We only run on the latest version of go, as some linters may be + # version-dependent (for example gofmt can change between releases). + go-version: 1.19.x - name: Checkout code - uses: actions/checkout@v2 + uses: actions/checkout@v3 - name: Lint - run: | - docker run --rm -v `pwd`:/go/src/github.com/moby/ipvs -w /go/src/github.com/moby/ipvs \ - golangci/golangci-lint:v1.23.8 golangci-lint run --disable-all -v \ - -E govet -E misspell -E gofmt -E ineffassign -E golint + uses: golangci/golangci-lint-action@v3 + with: + version: "v1.50.1" + skip-cache: true + args: --print-resources-usage --timeout=5m --verbose + + # Optional: show only new issues if it's a pull request. The default value is `false`. + # only-new-issues: true + + # Optional: if set to true then the action don't cache or restore ~/go/pkg. + # skip-pkg-cache: true + + # Optional: if set to true then the action don't cache or restore ~/.cache/go-build. + # skip-build-cache: true diff --git a/.golangci.yml b/.golangci.yml new file mode 100644 index 0000000..22e0992 --- /dev/null +++ b/.golangci.yml @@ -0,0 +1,8 @@ +linters: + disable-all: true + enable: + - gofmt + - govet + - ineffassign + - misspell + - revive