Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Upgrade to go 1.22 #8125

Merged
merged 4 commits into from
Jan 21, 2025
Merged

Upgrade to go 1.22 #8125

merged 4 commits into from
Jan 21, 2025

Conversation

bryantbiggs
Copy link
Member

@bryantbiggs bryantbiggs commented Jan 10, 2025

Description

1.21 reached end of support in August of 2024.
1.22 was chosen because there were errors thrown on 1.23 - tabled for later date.

This PR is a bit larger than usual given the way the prior Docker images were configured in order to update the go version. Previously, it appears that you would need to perform the following to update the go version:

  1. Create your git branch
  2. Update the go version references throughout the codebase to the desired version
  3. Build and push the eksctl "build" image to ECR. This means that only maintainers with write access to ECR can update go versions, and this is done locally! Not great
  4. Grab the sha digest of the "build" image pushed to ECR, update the main Dockerfile with the new digest
  5. Proceed to open pull request with changes

This is interesting for two reasons:

  1. It requires a human in the loop which opens up various issues in terms of supply chain, access, and does not allow OSS contributions for this update
  2. The "build" image includes a lot of dev type tooling (helm, kubectl, aws-iam-authenticator, etc.) but the eksctl binary is copied out of this dev build image into the resulting final image. If this psuedo development environment image was of value, there are probably better ways to achieve this using multi-stage builds and removing the need to have a person push the intermediate image to ECR from their local machine

To simplify, this PR removes the dev build image entirely which removes the majority of the complexity in this process. The resulting image that is pushed to ECR is based on other K8s/EKS images. I did not get a chance to dig into the code generation and whether any of that is used in the resulting final executable or if that is only for testing, but there could be further simplification - tabled for a later date.

With this changes, we therefore can remove the following:

  • The .requirements file is removed which avoids version skew issues; any binaries needed are instead installed via go install ... in the Makefile before their use
    • This removes the need for the install-build-deps Make target
  • With building the binary in the final image, the eksctl-build image, scripts, and manifests are removed
    • This removes the .github/workflows/ecr-publish-build.yaml workflow
    • This removes the need for Makefile.docker
  • .github/workflows/build-all-distros-nightly.yaml workflow is removed since its redundant of the CI checks, and has been failing for some time
  • .github/workflows/cache-dependencies.yaml workflow is removed since there are already a number of cache points in the workflows and we are over-caching which is rendering this moot
    image

With this change, an outside OSS contributor can now update the version go and build, test, and validate that change before creating a PR without any maintainer involvement.

Checklist

  • Added tests that cover your change (if possible)
  • Added/modified documentation as required (such as the README.md, or the userdocs directory)
  • Manually tested
  • Made sure the title of the PR is a good description that can go into the release notes
  • (Core team) Added labels for change area (e.g. area/nodegroup) and kind (e.g. kind/improvement)

BONUS POINTS checklist: complete for good vibes and maybe prizes?! 🤯

  • Backfilled missing tests for code in same general area 🎉
  • Refactored something and made the world a better place 🌟

@bryantbiggs bryantbiggs added skip-release-notes Causes PR not to show in release notes dependencies Pull requests that update a dependency file area/tech-debt Leftover improvements in code, testing and building labels Jan 10, 2025
@bryantbiggs bryantbiggs force-pushed the feat/go-1-22 branch 2 times, most recently from 08c2a18 to 7e205f8 Compare January 10, 2025 02:35
Copy link
Member

@a-hilaly a-hilaly left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Awesome! Thank you @bryantbiggs for working on this! :) i left a couple comments in line

Makefile Outdated
Comment on lines 141 to 144
generate-always: ## Generate code (required for every build)
go install github.com/maxbrunsfeld/counterfeiter/v6
go install github.com/vektra/mockery/v2
go install github.com/vburenin/ifacemaker
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

super nit: we can move the go installs under a differ make rule and just call it here:

Suggested change
generate-always: ## Generate code (required for every build)
go install github.com/maxbrunsfeld/counterfeiter/v6
go install github.com/vektra/mockery/v2
go install github.com/vburenin/ifacemaker
generate-always: install-gen-tools ## Generate code (required for every build)

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

good call - added a new target for installing tools 3331498

should this target run automatically where tools are required, or should that be an explicit step that CI/users take on their own

Makefile Outdated
Comment on lines 90 to 101
unit-test-no-generate:
go install github.com/cloudflare/cfssl/cmd/...@latest
CGO_ENABLED=0 go test -tags=release ./pkg/... ./cmd/... $(UNIT_TEST_ARGS)

.PHONY: unit-test-race
unit-test-race: ## Run unit test with race detection
go install github.com/cloudflare/cfssl/cmd/...@latest
CGO_ENABLED=1 go test -race ./pkg/... ./cmd/... $(UNIT_TEST_ARGS)
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

is cfssl binary being called inside the unit tests?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

unfortunately, yes

cfssl gencert \

the unit tests are not "pure" unit tests - for example, they reach out to ECR to pull images

Copy link
Member

@a-hilaly a-hilaly left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

👍

@bryantbiggs bryantbiggs merged commit ccdd44c into eksctl-io:main Jan 21, 2025
10 checks passed
@bryantbiggs bryantbiggs deleted the feat/go-1-22 branch January 21, 2025 16:13
TiberiuGC added a commit to TiberiuGC/eksctl that referenced this pull request Jan 22, 2025
TiberiuGC added a commit that referenced this pull request Jan 22, 2025
)

* Revert "Bump github.com/gofrs/flock from 0.8.1 to 0.12.1 (#8024)"

This reverts commit 18394bd.

* Revert "Bump github.com/github-release/github-release from 0.10.0 to 0.10.1 (#8107)"

This reverts commit 34ab1f8.

* Revert "Migrate `goformation` under `pkg/` as a local package and remove location re-write (#8153)"

This reverts commit d0e5360.

* Revert "Upgrade to go 1.22 (#8125)"

This reverts commit ccdd44c.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
area/tech-debt Leftover improvements in code, testing and building dependencies Pull requests that update a dependency file skip-release-notes Causes PR not to show in release notes
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants