Skip to content

Releases: kubernetes-sigs/kubebuilder

v4.9.0

22 Sep 10:52
5e331e7

Choose a tag to compare

✨ New features

  • (go/v4): Upgrade controller-gen from v0.18.0 to v0.19.0 #5064
  • (go/v4): Upgrade golang CI from v2.3.0 to v2.4.0 #5063
  • (go/v4): Upgrade controller-runtime from v0.21.0 to v0.22.1 #5062 #5098
  • (go/v4): Upgrade kustomize from v5.6.0 to v5.7.1 #5099
  • (helm/v1-alpha): Migrate from installCRDs=true to crds.enabled=true in GitHub action test-chart.yml to address deprecation #5083

🐛 Bug fixes

  • (go/v4): Fix Docker builds failing when projects don’t include apis/, controllers/, or webhooks by updating .dockerignore to allow only Go source files and module metadata #5048
  • (AutoUpdate/v1-alpha): Adjust comments on Auto Update workflow #5082
  • (alpha generate command): Ensure kubebuilder reuses its own binary instead of relying on $PATH #5081
  • (go/v4): Fix e2e test to validate that metrics are exported without asserting a controller-specific metric #5100
  • (go/v4): Handle empty CRD directories in Makefile install/uninstall targets #5042

🎉 Thanks to all contributors!

What's Changed

  • 🌱 Bump github.com/onsi/gomega from 1.38.1 to 1.38.2 by @dependabot[bot] in #5059
  • 📖 Bump sigs.k8s.io/kubebuilder/v4 from 4.7.1 to 4.8.0 in /docs/book/src/simple-external-plugin-tutorial/testdata/sampleexternalplugin/v1 by @dependabot[bot] in #5061
  • 🌱 Bump github.com/onsi/ginkgo/v2 from 2.25.1 to 2.25.2 by @dependabot[bot] in #5065
  • ✨ feat: Upgrade controller-gen from v0.18.0 to v0.19.0 by @camilamacedo86 in #5064
  • ✨ Upgrade golang CI from v2.3.0 to v2.4.0 by @camilamacedo86 in #5063
  • ✨ feat: upgrade controller-runtime from v0.21.0 to v0.22.0 by @camilamacedo86 in #5062
  • 📖 Remove unit tests badge from README by @camilamacedo86 in #5067
  • 🐛 (go/v4): Fix Docker builds failing when projects don’t include apis/, controllers/, or webhooks by updating .dockerignore to allow only Go source files and module metadata by @camilamacedo86 in #5048
  • 🌱 Bump github.com/onsi/ginkgo/v2 from 2.25.2 to 2.25.3 by @dependabot[bot] in #5077
  • 📖 Bump github.com/spf13/pflag from 1.0.7 to 1.0.10 in /docs/book/src/simple-external-plugin-tutorial/testdata/sampleexternalplugin/v1 by @dependabot[bot] in #5076
  • 🌱 Bump actions/setup-node from 4 to 5 by @dependabot[bot] in #5078
  • 🌱 Bump actions/setup-go from 5 to 6 by @dependabot[bot] in #5079
  • 🌱 Bump github.com/spf13/cobra from 1.9.1 to 1.10.1 by @dependabot[bot] in #5070
  • 📖 add note about Windows support by @vitorfloriano in #5080
  • 🐛 (AutoUpdate/v1-alpha): Adjust comments on Auto Update workflow by @vitorfloriano in #5082
  • 🐛 (alpha generate command): Ensure kubebuilder reuses its own binary instead of relying on $PATH by @ashishkpathak-connect in #5081
  • 🌱 (e2e) upgrade certmanager from v1.16.3 to v1.18.2 by @camilamacedo86 in #5084
  • 🌱 (e2e/docs): upgrade prometheus version used to run the tests by @camilamacedo86 in #5085
  • 🌱 go: upgraded github.com/spf13/pflag v1.0.9 => v1.0.10 by @camilamacedo86 in #5086
  • ⚠️ (helm/v1-alpha): Migrate from installCRDs=true to crds.enabled=true in GitHub action test-chart.yml by @camilamacedo86 in #5083
  • 🌱 Bump github.com/spf13/afero from 1.14.0 to 1.15.0 by @dependabot[bot] in #5091
  • 🌱 Bump golang.org/x/text from 0.28.0 to 0.29.0 by @dependabot[bot] in #5090
  • 🌱 Bump helm.sh/helm/v3 from 3.18.6 to 3.19.0 by @dependabot[bot] in #5095
  • 🌱 Bump golang.org/x/tools from 0.36.0 to 0.37.0 by @dependabot[bot] in #5094
  • ✨ Upgrade controller-runtime from v0.22.0 to v0.22.1 by @camilamacedo86 in #5098
  • ✨ Upgrade kustomize from v5.6.0 to v5.7.1 by @camilamacedo86 in #5099
  • 🐛 (go/v4): Fix e2e test to validate that metrics are exported without asserting a controller-specific metric by @camilamacedo86 in #5100
  • 🐛 (go/v4) Handle empty CRD directories in Makefile install/uninstall targets by @nerdeveloper in #5042
  • 📖 (docs) drop patchStrategy/protobuf tags from Conditions in Getting Started section by @pedjak in #5104
  • 📖 (doc): Add demo for auto-update plugin by @camilamacedo86 in #5105

New Contributors

Full Changelog: v4.8.0...v4.9.0

v4.8.0

27 Aug 11:08
a069bf1

Choose a tag to compare

⚠️ Breaking changes

  • (CLI): Replace logrus with standard library log/slog for logging (no user-facing changes) #4968 #5049 #4993

✨ New features

  • (go/v4): Upgrade cert-manager used in E2E tests from v1.16.3 to v1.18.2 #4947
  • (go/v4): Upgrade Golang-CI from v2.1.6 to v2.3.0 #4945 #4974 #4957
  • (CLI;go/v4): Upgrade Go from 1.24.0 to 1.24.5 #4944
  • (go/v4): Improve KinD integration to ensure custom KinD binary is used in E2E tests #4618
  • (go/v4): Add e2e build tag to prevent accidental execution of end-to-end tests #4946
  • (go/v4): create api now adds status conditions by default #4943
  • (helm/alpha-v1): Allow define default image policy for the manager #4932 #5023
  • (go/v4): Improve go-install-tool implementation in Makefile #4988
  • (CLI): Add IfNotExistsAction to machinery for optional file handling #4967
  • (alpha update): #5013 #5002 #5018 #5019 #5026 #5017 #5027 #5035 #5040 #5039 #4992 #5050
    • (command) Major improvements and new flags—--squash to condense commits; --restore-path to keep selected paths unchanged; --output-branch to write changes to a new branch; --open-gh-issue to create new GitHub issues with update data; --use-gh-models to post AI summary to help project upgrade process; and --git-config to set Git defaults for the run. (More info)
    • (New Plugin) Adds new optional plugin (autoupdate/alpha-v1) with AI-assistence for upgrades. The plugin scaffolds a workflow to open an issue and post an AI summary whenever a new Kubebuilder release is available. (More info)

🐛 Bug fixes

  • (e2e): Remove Prometheus install/check helpers from E2E utils #4948
  • (go/v4): Replace custom CertWatcher with controller-runtime’s built-in implementation for webhook & metrics server cert reloads; ensures non-leader replicas update certificates #5008
  • (CLI): Fix link shown for plugin versioning when plugins are not found #5021
  • (helm/v1-alpha): When scaffolding a Helm project with webhooks, the generated GitHub Actions workflow now installs and waits for cert-manager. Without webhooks, the cert-manager step remains commented #5043
  • (go/v4) fix simple typos in Dockerfile comments #5056

Thanks to all contributors 🎉

What's Changed

  • 📖 Bump sigs.k8s.io/kubebuilder/v4 from 4.6.0 to 4.7.0 in /docs/book/src/simple-external-plugin-tutorial/testdata/sampleexternalplugin/v1 by @dependabot[bot] in #4926
  • 🌱 helm(e2e): test helm plugin integration by @bavarianbidi in #4914
  • 📖: Revert guide for building a bundle with kubebuilder-based projects for management by OLM and/or publication on OperatorHub.io by @camilamacedo86 in #4929
  • 🌱 (cli; alpha commands): Add unit tests for common utils used by alpha commands by @mayuka-c in #4928
  • 📖 (doc): fixed the broken links by @manzil-infinity180 in #4933
  • 📖 Bump github.com/spf13/pflag from 1.0.6 to 1.0.7 in /docs/book/src/simple-external-plugin-tutorial/testdata/sampleexternalplugin/v1 by @dependabot[bot] in #4934
  • 🌱 Bump github.com/spf13/pflag from 1.0.6 to 1.0.7 by @dependabot[bot] in #4935
  • 🌱: introduce gci as formatter in golangci-lint by @bavarianbidi in #4927
  • ✨ (go/v4) : Improve Kind Integration: Ensure Custom Kind Binary is Used in E2E Tests by @kersten in #4618
  • 🌱 (ci): Fix mock for alpha update e2e tests by @camilamacedo86 in #4938
  • ✨ (go/v4): upgrade cert-manager from v1.16.3 v1.18.2 used in the e2e tests by @camilamacedo86 in #4947
  • ✨ Upgrade Golang-CI from v2.1.6 to v2.2.2 by @camilamacedo86 in #4945
  • 🌱 (ci): only call lint sample and test-devcontainer checks when has changes in the specific directories checked by @camilamacedo86 in #4940
  • 📖 (docs/alpha update): remove suggestion marker by @vitorfloriano in #4953
  • 🌱 (CLI): Add unit tests for plugin utils by @mayuka-c in #4956
  • 🌱 (alpha update): add e2e tests for --force flag by @vitorfloriano in #4955
  • ✨ (go/v4) add e2e build tag to prevent accidental execution of end-to-end tests by @camilamacedo86 in #4946
  • ✨ Upgrade Golang-CI from v2.2.2 to v2.3.0 by @aman4433 in #4957
  • ✨ (go/v4): Create API command now adds status conditions by @camilamacedo86 in #4943
  • 🌱 Improve revive linter configuration by @aman4433 in #4954
  • 🌱 (ci) - Add test for release mock by @camilamacedo86 in #4939
  • 🌱 Bump github.com/onsi/gomega from 1.37.0 to 1.38.0 by @dependabot[bot] in #4958
  • 🌱 (CLI): Add unit tests and improve coverage for plugins/golang pkg by @mayuka-c in #4959
  • 🐛 remove: Prometheus install/check helpers from e2e utils by @camilamacedo86 in #4948
  • 🌱 Bump sigs.k8s.io/yaml from 1.5.0 to 1.6.0 by @dependabot[bot] in #4962
  • 📖 Bump sigs.k8s.io/kubebuilder/v4 from 4.7.0 to 4.7.1 in /docs/book/src/simple-external-plugin-tutorial/testdata/sampleexternalplugin/v1 by @dependabot[bot] in #4963
  • ✨ (CLI;go/v4) Upgrade golang version from 1.24.0 to 1.24.5 by @camilamacedo86 in #4944
  • 🌱 fix file added by mistake; should be removed by @camilamacedo86 in #4964
  • 🌱 (ci) fix samples linter and release linter by @camilamacedo86 in #4965
  • 🌱 Add unit testing for files(external) in pkg/cli/alpha by @cmallikarjunah in #4966
  • 🌱 Add unit tests for alpha/internal/update by @cmallikarjunah in #4931
  • 🌱 (fix) Install-and-build.sh script to work on MacOs by @mayuka-c in #4970
  • ✨ Version bump for golangci-lint to 2.3.0 ( follow up #4957 ) by @Shubhamag12 in #4974
  • 🌱 (alpha update) add validation for equal versions by @vitorfloriano in #4975
  • 📖 (docs/tutorials): ensure all fields follow Kubernetes API conventions by @camilamacedo86 in #4942
  • ⚠️ Migrate from logrus to log/slog by @Shubhamag12 in #4968
  • ✨ (go/v4;helm/alpha-v1;kustomize/v2): Adding default image policy for the manager by @adarshagrawal38 in #4932
  • 🌱 Add versioned tool installation via go-install-tool helper in Kubebuilder Makefile such as we provide for end users by @afritzler in #4986
  • ✨ (go/v4): Improve go-install-tool code imple...
Read more

v4.7.1

24 Jul 18:47
9c991d3

Choose a tag to compare

✨ New Features

  • (alpha update command): Introduce --force flag to allow upgrades and create the commit even if conflicts are encountered. Also enables users to resolve conflicts before committing with the conflict markers. (#4936)

🐛 Bug Fixes

  • (alpha update command): fix pre-require check when --to-version is informed (#4937)
  • (go/v4): Skip webhook test injection if required files or markers are missing, avoiding unnecessary errors during scaffolding or updates by ensuring backwards compatibility with older project versions where e2e tests were not scaffolded due to missing markers. This fix also allows for flexibility in user customisations, as e2e tests are optional. (#4950)
  • (go/v4): For utils scaffolded under e2e tests: delete CertManager leftover leases in kube-system (not cleaned by default) when CertManager is uninstalled (#4949)

Thanks to all our contributors! 🎉

What's Changed

  • 🐛 (CLI) fix alpha update command to version pre-require check by @mayuka-c in #4937
  • ✨ (alpha update command): add --force flag by @vitorfloriano in #4936
  • 🐛 (go/v4): gracefully skip webhook test injection if file or markers are missing by @camilamacedo86 in #4950
    sigs/kubebuilder/pull/4959
  • 🐛 (go/v4)(fix): (e2e) delete CertManager leftover leases in kube-system (not cleaned by default) by @camilamacedo86 in #4949

Full Changelog: v4.7.0...v4.7.1

v4.7.0

14 Jul 08:20
cf5dbb3

Choose a tag to compare

⚠️ Breking Changes

  • (helm/v1-alpha): remove init command from Helm plugin as it's only meaningful with edit (#4903)

✨ New Features

  • (go/v4): Add default logic to conversion webhook implementations to copy ObjectMeta (e.g., name, namespace, labels). Includes example usage to clarify usage patterns (#4825)
  • (kustomize/v2; go/v4): Automatically uncomment webhook blocks during scaffold generation to improve UX and maintainability (#4826)
  • (cli): Improve help output for kubebuilder alpha generate command to clarify usage (#4846)
  • (alpha update): Introduce initial implementation of the alpha update command (#4871). Users can now automate the full upgrade process of their projects, only intervening to resolve conflicts. (More info)
  • (deploy-image/v1-alpha): Refine CRD conditions field documentation for improved clarity and human readability (#4894)
  • Upgrade usage of cert-manager from v1.17.2 to v1.18.2 (#4866) (#4878)(#4905)
  • Upgrade golang-ci from v2.1.0 to v2.1.6 (#4867)

🐛 Bug Fixes

  • (helm/v1-alpha): Use consistent file and directory permissions (0644/0755) during scaffolding (#4814)
  • (cli): Ensure files and directories starting with a dot (except .git and PROJECT) are cleaned up correctly during alpha generate (#4842)
  • (cli): Ensure alpha generate runs all necessary targets (make manifests generate fmt vet lint-fix) post-scaffolding (#4843)(#4848)
  • (cli): Patch PROJECT file in-memory to support unsupported plugins during alpha generate (#4844)
  • (go/v4): Fix grammar in e2e test comments to improve clarity (#4847)
  • (go/v4): Remove unused +kubebuilder:conversion:hub marker from conversion webhooks (#4849)
  • (go/v4): Set readOnlyRootFilesystem in manager and curl pods to meet PSA security guidelines (#4869)
  • (go/v4): Fix incorrect ServiceAccount spec naming in e2e tests (#4868)
  • (go/v4): Skip kind node creation during e2e tests if node already exists (#4883)
  • (deploy-image/v1-alpha): Remove patchStrategy and protobuf tags from Conditions field (#4893)
  • (deploy-image/v1-alpha): Remove default max size validation logic from CRD schema (#4909)
  • (deploy-image/v1-alpha): Eliminate unnecessary error handling for addFinalizer logic (#4789)
  • (go/v4, deploy-image/v1-alpha): Ensure API scaffolds follow Kubernetes API conventions. This effort aligns the code to be checked with kube-api-linter in a future release. (#4907) (#4897) (#4913)
    • Ensure CRD field comments do not start with capitalised letters and omit trailing periods
    • Ensure //+required and //+optional markers are correctly applied
    • Use omitzero for Status fields to avoid unnecessary use and complexities that pointers can bring

Thanks to all our contributors! 🎉

What's Changed

  • 🌱 [external-plugin] fix(ci): use Make targets for CLI install and expose plugin failures by @camilamacedo86 in #4823
  • 🐛 (helm/v1-alpha): standardized file and directory permissions scaffolding with 0644/0755 by @jtyr in #4814
  • 📖 (docs): Upgrade controller-tools from v0.17.4 to v0.18.0 by @camilamacedo86 in #4832
  • 🌱 fix: lint issue: string baseDir = "api" has 3 occurrences, make it a constant (goconst) by @camilamacedo86 in #4834
  • ✨ (go/v4): Improved conversion webhook implementation by adding default logic to copy ObjectMeta (name, namespace, labels, etc.). Included example usage for clarity. by @camilamacedo86 in #4825
  • 📖 doc: [metrics] - provide information about required permissions to access the metrics endpoint by @camilamacedo86 in #4831
  • 🌱 Bump sigs.k8s.io/kubebuilder/v4 from 4.5.2 to 4.6.0 in /docs/book/src/simple-external-plugin-tutorial/testdata/sampleexternalplugin/v1 by @dependabot[bot] in #4835
  • 📖 fix broken link to busybox test by @carlossg in #4840
  • 📖 fix examples how to specify watched CR in Watches() by @jokuniew in #4841
  • 🐛 (cli): Fixed an issue where alpha generate skipped files and directories beginning with a dot (e.g., .github/, .env, .golangci.yaml). These are now properly removed during cleanup, except .git and PROJECT, which are intentionally preserved. by @camilamacedo86 in #4842
  • 🐛 fix(cli): ensure 'alpha generate' runs 'make manifests generate fmt vet lint-fix' after scaffolding by @camilamacedo86 in #4843
  • 🐛 (go/v4) fix: correct grammar in e2e tests comments which clarifies its purpose by @camilamacedo86 in #4847
  • 🐛 (cli)(fix): postscaffold for alpha generate should return warning (follow-up: 4843) by @camilamacedo86 in #4848
  • 🌱 (ci) - Enable tests against k8s 1.33 by @camilamacedo86 in #4852
  • 🌱 (ci): Temporarily comment out tests failing on Kubernetes 1.33 to unblock CI and allow for a calmer investigation and fix by @camilamacedo86 in #4856
  • 🌱 Bump golang.org/x/text from 0.25.0 to 0.26.0 by @dependabot[bot] in #4858
  • 🌱 Bump golang.org/x/tools from 0.33.0 to 0.34.0 by @dependabot[bot] in #4861
  • ✨ Upgrade usage of cert-manager from v1.17.2 to v1.18.0 by @camilamacedo86 in #4866
  • ✨ Upgrade golang-ci from v2.1.0 to v2.1.6 by @camilamacedo86 in #4867
  • 🐛 (go/v4): ensure manager and curl pod use readOnlyRootFilesystem to comply with PSA rules by @camilamacedo86 in #4869
  • 🐛 (go/v4): e2e tests SA spec name is not accurate to inform the SA by @camilamacedo86 in #4868
  • 🌱 (e2e test context): not try remove ns when we uninstall release by @camilamacedo86 in #4870
  • 📖 docs: fix code block rendering by @starbops in #4877
  • ✨ Upgrade cert-manager from v0.18.0 to v0.18.1 by @camilamacedo86 in #4878
  • ✨ (kustomize/v2; go/v4) feat: improve UX and maintainability by auto-uncommenting webhook blocks when possible by @camilamacedo86 in #4826
  • 🐛 (cli) fix: allow 'alpha generate' to work with unsupported plugins by patching PROJECT file in-memory by @camilamacedo86 in #4844
  • ✨ (cli): enhance help information for kubebuilder alpha generate command by @camilamacedo86 in #4846
  • 🌱 (ci) - fix cleanup for go/v4 e2e tests by @camilamacedo86 in #4880
  • 🐛 (go/v4)(fix): remove unused marker +kubebuilder:conversion:hub for conversion webhooks by @camilamacedo86 in #4849
  • 🌱 (ci) fix: e2e tests by adding sleep before metrics access to handle K8s 1.33 cert delay by @camilamacedo86 in #4882
  • 🐛 (deploy-image/v1alpha1): drop patchStrategy/protobuf tags from Conditions by @camilamacedo86 in #4893
  • 🌱 updated sigs.k8s.io/yaml version form 1.4.0 to 1.5.0 and changed formatting in 2 tests by @manalilatkar in #4895
  • 🐛 fix go/v4 e2e tests: skip kind node cr...
Read more

v4.6.0

24 May 23:23
cd90bd8

Choose a tag to compare

Changes since v4.5.2

⚠️ Breaking Changes

✨ New Features

  • (go-v4): Enable import-shadowing linter (#4700)
  • (go-v4): Add new Makefile target to create a cluster name for e2e tests (#4673)
  • (go-v4): Upgrade Go version to v1.24.0 (#4585)
  • (go-v4): Update golangci-lint to v2.0.2and GitHub Action to v8 (#4752,#4801)
  • (go-v4): Upgrade controller-tools from v0.17.2 to v0.18.0 (#4804,#4770)
  • (API, CLI, go/v4): Add cliVersion field to PROJECT file to track CLI binary version used in scaffolds (#4621, #4821)

🐛 Bug Fixes

  • (go-v4): Wrap test command execution errors with %w for better error tracing (#4694)
  • (go-v4): Improve main.go scaffolding to reduce err scope using := (#4585)
  • (helm/v1-alpha): Add control-plane labels to metrics service and ServiceMonitor templates (#4777)
  • (helm/v1-alpha): Append project name to webhook service name to avoid name collisions (#4808)
  • (go-v4): Fix staticcheck linter issues (ST1005, QF1008) in scaffolds and tutorials (#4779)
  • (go-v4): Fix incorrect Webhook import aliasing in cmd/main.go (#4781)
  • (go-v4): Revert unintended addition of explicit docker.io prefix in Dockerfile (#4818)
  • (go-v4): Improve comment in /config/rbac/kustomization.yaml by rendering project name instead of using template var (#4819)
  • (go-v4): Remove redundant/noisy godebug default lines in the go.mod file (#4787)

Thanks to all our contributors! 🎉

What's Changed

  • 📖 bump sigs.k8s.io/kubebuilder/v4 from 4.5.1 to 4.5.2 in /docs/book/src/simple-external-plugin-tutorial/testdata/sampleexternalplugin/v1 by @dependabot in #4683
  • 🌱 (chore): add gofumpt to golangci-lint configuration by @kersten in #4672
  • 🌱 (chore): unify import alias for network-policy by @kersten in #4684
  • 🌱 (chore): normalize error messages and wrap errors using %w by @kersten in #4685
  • 📖 Fix path for samples in the Getting Started tutorial by @fferrann in #4695
  • 🌱 (chore): normalize error messages and wrap errors using %w by @kersten in #4686
  • 🌱 (chore): wrap file and I/O errors with '%w' in 'pkg' by @kersten in #4689
  • 🌱 (chore): remove unnecessary blank lines across plugin configuration and options by @kersten in #4690
  • 📖 Improve error format in the design docs for API Versioning in Kubebuilder by @kersten in #4693
  • 🌱 (chore): avoid shadowing of 'config' and 'resource' in golang/v4 plugins by @kersten in #4649
  • 🌱 (chore): normalize error messages and wrap errors using %w by @kersten in #4687
  • 🌱 (chore): wrap errors with '%w' and normalize formatting in 'kustomize/v2' by @kersten in #4688
  • 🌱 (chore): wrap error with %w in test_context.go for improved diagnostics by @kersten in #4692
  • 🐛 (go/v4): wrap test command execution errors with %w in test utils by @kersten in #4694
  • 🌱 (chore): avoid shadowing of 'config', 'store', and 'resource' in cli/alpha/generate by @kersten in #4697
  • 🌱 (chore) add comment to clarify usage context of ReplaceRegexInFile by @kersten in #4656
  • 🌱 (chore): fix improper usage of errors.As in scaffold tests by @kersten in #4696
  • 🌱 (chore): improve readability of test case for alternative delimiters by @kersten in #4698
  • 🌱 (chore): enable shadow checks via import-shadowing linter by @kersten in #4661
  • 🌱 (chore): refactor unit tests to isolate mutable test data in CLI spec to improve maintainability by @kersten in #4701
  • 🌱 (chore): enable 'asciicheck' and 'bidichk' for improved code safety and clarity by @kersten in #4699
  • ✨ (go/v4): enable 'import-shadowing' linter by @kersten in #4700
  • 🌱 (chore): refactor unit tests to isolate mutable state with BeforeEach for pkg/cli by @kersten in #4702
  • 🌱 (chore): refactor unit tests to isolate mutable state with BeforeEach for pkg/config/store by @kersten in #4703
  • 🌱 (chore): refactor unit tests to isolate mutable state with BeforeEach in pkg/config by @kersten in #4704
  • 🌱 (chore): refactor unit tests to isolate mutable state with BeforeEach in pkg/machinery tests by @kersten in #4705
  • 🌱 (chore): refactor stage unit tests with Ginkgo conventions and simplify logic in stage_test.go by @kersten in #4706
  • 🌱 (chore): refactor unit tests to isolate mutable state with BeforeEach in resource-related tests by @kersten in #4707
  • 🌱 (chore): refactor shared setup logic in plugins into BeforeEach to isolate test state by @kersten in #4708
  • 🌱 (chore): enable 'whitespace' linter in golangci-lint config by @kersten in #4691
  • 🌱 (chore): refactor shared setup logic in plugin into BeforeEach to isolate test state by @kersten in #4709
  • 🌱 fix (ci): fix lint issue: shadow: declaration of pluginCfg shadows declaration by @camilamacedo86 in #4725
  • 📖 Updated 404 page details in TODO.md and updated the book by @Kuzuri247 in #4674
  • 🐛 (go/v4) Update main.go scaffold to follow Go best practices by reducing the scope of err using short variable declarations (:=) by @koba1t in #4627
  • 📖 Updated migration pages by @Kuzuri247 in #4676
  • 🌱 Use dynamic controller-runtime version in doc generator to make easier update the version by @p-shah256 in #4713
  • 🌱 (chore): enable ginkgolinter forbid-spec-pollution to enforce isolated test specs by @kersten in #4710
  • 🌱 (chore): enable ginkgolinter forbid-focus-container by @nunnatsa in #4714
  • 📖 Fixed grammatical errors in designs doc by @Kuzuri247 in #4716
  • 🌱 (chore): replace errors.As() with MatchError() in error assertions by @kersten in #4723
  • 🌱 Fix golangci-lint wrong configurations by @nunnatsa in #4726
  • 🌱 (chore): simplify test variable declarations for CLI tests by @kersten in #4731
  • 🌱 (chore): replace '%v' with '%w' in deploy-image v1alpha1 plugin errors by @kersten in #4732
  • 🌱 (chore): wrap errors using '%w' and improve formatting in golang plugin by @kersten in #4729
  • 🌱 (chore): improve error wrapping for external plugin discovery and config loading by @kersten in #4744
  • 🌱 (chore): wrap plugin and util error returns for better context by @kersten in #4745
  • 🌱 (chore): check and return error from os.WriteFile when writing litout.json by @kersten in https://gith...
Read more

v4.5.2

26 Mar 19:40
7c70705

Choose a tag to compare

changes since v4.5.1

✨ New Features

Note: This release includes minor version upgrades for key dependencies.

  • (go-v4): Upgraded controller-runtime from v0.20.2 to v0.20.4 (#4604, #4678)
  • (go-v4): Upgraded kustomize from v5.5.0 to v5.6.0 (#4620)

🐛 Bug Fixes

  • (CLI): Fixed Kubebuilder installation using go install to ensure proper setup (#4581)
  • (CLI): Allowed kubebuilder alpha generate to proceed even when legacy plugins (go/v2, go/v3) are unavailable (#4572)
  • (helm/v1-alpha): Skipped empty directories during Helm chart generation to avoid invalid output (#4586)
  • (helm/v1-alpha): Avoided scaffolding webhook manifests for projects that do not use webhooks (#4584)
  • (go-v4): Made Kind integration in the Makefile configurable, aligning with the standard used for other variables (#4615)
  • (go-v4): Fixed indentation of import statements in generated test files (#4623)
  • (go-v4): Fixed minor typo in e2e test suite comments (#4662)
  • (go-v4): Prevented shadowing of the standard log package by aliasing it as logf (#4646)
  • (grafana/v1alpha): Prevented shadowing of the err variable in generated Grafana plugin code (#4653)

Thanks to all our contributors! 🎉

What's Changed

  • 📖 : Bump sigs.k8s.io/kubebuilder/v4 from 4.5.0 to 4.5.1 in /docs/book/src/simple-external-plugin-tutorial/testdata/sampleexternalplugin/v1 by @dependabot in #4579
  • 🐛 Fix Kubebuilder Installation with go install by @migueleliasweb in #4581
  • 🌱 (ci): improve PR title validation for a better security by @camilamacedo86 in #4583
  • 🐛 (helm/v1-alpha): Skip empty directories in chart generation by @camilamacedo86 in #4586
  • 🌱 Upgrade Goreleaser + fix deprecation on release.yml by @migueleliasweb in #4587
  • 🌱 Add Makefile target to sync Kubernetes version by @akagami-harsh in #4589
  • 🌱 fix PR title check by @camilamacedo86 in #4596
  • 🌱 Bump golang.org/x/text from 0.22.0 to 0.23.0 by @dependabot in #4594
  • 🌱 Bump golang.org/x/tools from 0.30.0 to 0.31.0 by @dependabot in #4593
  • 🌱Bump github.com/onsi/ginkgo/v2 from 2.22.2 to 2.23.0 by @dependabot in #4595
  • 📖 Add link to Watching Secondary Resources Owned by the Controller by @guettli in #4590
  • 📖 Update Single Group to Multi-Group Documentation to Add Webhooks Details 📖 by @GunaKKIBM in #4601
  • 📖 fix incorrect reference to "deploy-image-plugin" in docs. by @mo3et in #4599
  • 📖 Update README.md with minor changes by @chethanm99 in #4603
  • ✨ Upgrade controller-runtime from v0.20.2 to v0.20.3 by @vitorfloriano in #4604
  • 📖 Update code-generate-image-plugin.md and gvks.md by @chethanm99 in #4607
  • 📖 Update CONTRIBUTING-ROLES.md with minor changes by @chethanm99 in #4605
  • 📖 docs: fix incorrect json tag in API example. by @mo3et in #4609
  • 🌱 Bump github.com/spf13/afero from 1.12.0 to 1.14.0 by @dependabot in #4616
  • 🐛 Make the Kind integration in the Makefile configurable like the other variables. by @kersten in #4615
  • 🐛 Allow 'kubebuilder alpha generate' rescaffolds work with no longer supported/available plugins ( go/v3 and go/v2 ) by @sarthaksarthak9 in #4572
  • 🌱 Fix: ensure tha cmd/verdion.go is properly updated to return this value for go modules by @camilamacedo86 in #4619
  • 🌱 Bump github.com/onsi/ginkgo/v2 from 2.23.0 to 2.23.1 by @dependabot in #4622
  • ✨ (go/v4): Upgrade kustomize version from v5.5.0 to v5.6.0 by @camilamacedo86 in #4620
  • 🌱 Bump github.com/onsi/ginkgo/v2 from 2.23.1 to 2.23.2 by @dependabot in #4626
  • 📖 Remove outdated test examples by @fiunchinho in #4624
  • 🐛 (go/v4): fix indentation of imports in test files by @kersten in #4623
  • 🌱 Bump github.com/onsi/ginkgo/v2 from 2.23.2 to 2.23.3 by @dependabot in #4628
  • 🌱 Bump github.com/onsi/gomega from 1.36.2 to 1.36.3 by @dependabot in #4629
  • 🌱 fix: avoid variable shadowing by renaming loop variable 'plugin' by @kersten in #4640
  • 🌱 fix: resolve shadowed variable issue in literate.go by @kersten in #4641
  • 🌱 (chore): avoid variable shadowing by renaming local 'alpha' variable by @kersten in #4642
  • 🌱 (chore): rename local 'config' variable to avoid collision with imported package by @kersten in #4639
  • 🌱 (chore): rename local 'resource' variable to avoid shadowing import by @kersten in #4645
  • 🌱 fix(docs): correct typo in comments across multiple files by @kersten in #4634
  • 🌱 (chore): avoid variable shadowing by renaming local 'errors' variable by @kersten in #4643
  • 🐛 (go/v4): fix typo in e2e test suite comments by @kersten in #4662
  • 🌱 (chore): improve readability of test case for alternative delimiters by @kersten in #4671
  • 🌱 (chore): group const declarations into blocks for clarity by @kersten in #4669
  • 🌱 (chore): avoid shadowing of 'config', 'err', and patch error in helm and deploy-image scaffolds by @kersten in #4660
  • 🌱 (chore): use octal notation for file and directory modes by @kersten in #4663
  • 🌱 (chore): remove unnecessary trailing newlines and redundant blank lines by @kersten in #4664
  • 🌱 (chore): simplify test variable declarations for CLI tests by @kersten in #4665
  • 🌱 (chore): simplify variable declarations by adding var blocks by @kersten in #4666
  • 🌱 (chore): simplify variable declarations by removing unnecessary var blocks by @kersten in #4667
  • 🌱 (chore): fix formatting for multi-line function signatures by @kersten in #4668
  • 🌱 (chore): avoid shadowing of 'err' in CLI options, YAML store, and external plugin helpers by @kersten in #4658
  • 🌱 (chore): avoid shadowing of 'err' and related variables in E2E and external plugin tests by @kersten in #4659
  • 🌱 (chore): avoid shadowing of 'fmt' in regexError helper by @kersten in #4648
  • 🌱 (chore): avoid shadowing of 'config', 'resource', and 'err' in kustomize/v2 scaffolds by @kersten in #4651
  • 🌱 (chore): avoid shadowing of 'pluginConfig' in config v3 implementation and tests by @kersten in #4652
  • 🌱 (chore): avoid shadowing of 'err' in version parsing for plugin and config packages by @kersten in #4657
  • 🌱 (chore): avoid 'fs' shadowing and rename 'isPluginExectuable' to 'isPluginExecutable' by @kersten in #4647
  • 🌱 (chore): clean up var declarations in grafana scaffolder and cronjob doc generator by @kersten in #4670
  • ✨ Upgrade controller-runtime v0.20.3 to v0.20.4 by @camilamacedo86 in #4678
  • 🐛 (helm/v1-alpha): not scaffold webhooks conditiona...
Read more

v4.5.1

21 Feb 20:15
0ace7a8

Choose a tag to compare

changes since v4.5.0

✨ New Features

Note: This release includes only minor version updates.

  • (go-v4): Upgraded controller-runtime from v0.20.0 to v0.20.2 (#4528, #4570)
  • (go-v4): Upgraded controller-gen from v0.17.1 to v0.17.2 (#4553)

🐛 Bug Fixes

  • (go-v4): Aligned webhook suite tests with controller suite tests (#4449)
  • (go-v4): Fixed project initialization in directories containing other files. Now, initialization is only prevented for directories with explicitly unwanted files (#4510)
  • (go-v4, kustomize/v2, helm/v1-alpha): Fixed Prometheus integration by adding the serverName field to ServiceMonitor, ensuring proper certificate validation with the metrics server (#4536, #4558)
  • (CLI): Fixed kubebuilder alpha generate by using --repo information tracked in the PROJECT file. Fix generation of projects outside of GOPATH (#4559)
  • (go-v4, deploy-image/v1-alpha): Fixed handling of missing boilerplate files by raising a warning instead of failing. Previously, the process would terminate with an error, but it now issues a warning and continues execution (#4518).
  • (go-v4): e2e tests: Removed Prometheus dependency as part of cleanup and fixes, since it is optional and not required (#4529)

Thanks to all our contributors! 🎉

What's Changed

New Contributors

Full Changelog: v4.5.0...v4.5.1

v4.5.0

21 Jan 08:46
7153119

Choose a tag to compare

changes since v4.4.0

⚠️ Breaking Changes

  • (go-v4): Upgrade controller-runtime from v0.19.4 to v0.20.0 and add support for Kubernetes 1.32 (#4492). See the controller-runtime release notes to learn more about the breaking changes introduced.

    (Projects using webhooks):
    Controller-runtime removed the deprecated webhook.Validator and webhook.Defaulter interfaces. Additionally, webhooks should no longer reside under the api directory. Kubebuilder projects have not scaffolded webhooks in this directory or used the deprecated interfaces since v4.3.0.

    If you are using these interfaces or the legacy apis directory for webhooks, please refer to the v4.3.0 release notes, which provide guidance on updating your projects to align with the current standards.

    To assist with migration or reduce the burden on users, Kubebuilder has introduced a flag option to allow scaffolding webhooks using the new interfaces in the legacy path. For now, you can scaffold webhooks in the legacy path (under api) by using the command kubebuilder create webhook [OPTIONS] --legacy=true. For reference, you can look at the CronJob Tutorial sample webhooks implementation.

✨ New Features

  • (go-v4): Upgrade controller-gen from v0.17.0 to v0.17.1 (#4493)
  • (go-v4): Upgrade GolangCI Lint from v1.62.2 to v1.63.4 (#4494)
  • (go-v4): e2e tests: upgrade cert-manager version used from v1.16.0 to v1.16.3 (#4497)
  • (go-v4): e2e tests: follow cert-manager org name changes (#4505)

🐛 Bug Fixes

  • (CLI) Ensure minimal golang version 1.23.0 (#4491)
  • (helm/alpha-v1): Fix YAML lint in the ServiceMonitor file (#4502)
  • (alpha generate command): Fix scenario where the output-dir path is not informed; default to the current directory (#4500)
  • (alpha generate command): Allow re-creating projects with webhooks for external-apis (#4501)
  • (go-v4): Use explicit docker.io prefix for Docker Hub images (#4513)

Thanks to all our contributors! 🎉

What's Changed

  • 📖 Add helm-plugin to the summary of available plugins by @camilamacedo86 in #4485
  • 🐛 Update golang version to 1.23.0 in init validation logic by @dmvolod in #4491
  • 📖 Bump sigs.k8s.io/kubebuilder/v4 from 4.3.1 to 4.4.0 in /docs/book/src/simple-external-plugin-tutorial/testdata/sampleexternalplugin/v1 by @dependabot in #4488
  • ⚠️ Upgrade controller-runtime from v0.19.4 to v0.20.0 and k8s deps from 1.31 to 1.32 by @camilamacedo86 in #4492
  • ✨ Upgrade controller-gen from v0.17.0 to v0.17.1 by @camilamacedo86 in #4493
  • ✨ Upgrade GolangCI Lint from v1.62.2 to v1.63.4 by @camilamacedo86 in #4494
  • ✨ e2e tests: upgrade cert-manager version used from v1.16.0 to v1.16.3 by @camilamacedo86 in #4497
  • 🐛 (helm/alpha-v1): fix yaml lint in the ServiceMonitor file by @camilamacedo86 in #4502
  • 🌱 CLI: Remove unused doc.go by @camilamacedo86 in #4504
  • 🐛 fix: kubebuilder alpha generate command to allow re-create projects with webhooks for external-apis by @camilamacedo86 in #4501
  • ✨ (go/v4): Follow cert-manager org name changes by @zchee in #4505
  • 🌱 (ci): Add GH action to validate generated helm charts for tutorials by @akagami-harsh in #4472
  • 🌱 fix: alpha generate command. If the output-dir path is not informed than it should be the current directory by @camilamacedo86 in #4500
  • 🐛 Use explicit docker.io prefix for Docker Hub images by @pl4nty in #4513

New Contributors

Full Changelog: v4.4.0...v4.5.0

v4.4.0

12 Jan 13:09
55097d0

Choose a tag to compare

changes since v4.3.1

✨ New Features

  • (go/v4): Upgrade golangci-lint from v1.61.0 to v1.62.2 (#4448)
  • (go/v4): Add support for go 1.23 (#4446)
  • (go/v4): Upgraded controller-gen from v0.16.4 to v0.17.0. (#4254, #4457)
  • (go/v4): Upgrade controller-runtime v0.19.1 to v0.19.4 (#4482)
  • (kustomize/v2): Kubebuilder scaffolds rules under config/rbac to help cluster admins manage the permissions for their solutions. The comments and explanations added to these scaffolds have been improved. Furthermore, it now includes admin-specific rules to make it easier for cluster admins to work with features like aggregation (e.g., rbac.authorization.k8s.io/aggregate-to-admin). More info. (#4299)
  • (go/v4): Added configurations for securing Metrics Server and Prometheus integration using TLS and certificates managed by CertManager, enabling users to align their solutions with best practices, enhance security, and achieve production readiness. (#4243, #4312, #4400)
  • (go/v4): Added webhook CertWatcher and flags for custom certificate configuration #4429)
  • (go/v4): Ensures that the manager container adheres to Restricted Pod Security Standards and can operate in namespaces labelled for restricted policies, following best practices. (#4251).
  • (go/v4): Ensure that e2e test scaffolds will validate that the enforcement is prepared to ensure that all can run as restricted. See that the curl pod to use the metrics was updated and changed (#4435)
  • (go/v4): Improved developer experience and maintainability by updating actions and the Makefile to utilize go.mod for Go version management and automating ENVTEST versioning by retrieving the version directly from go.mod, based on the controller-runtime dependency in use. (#4385) (#4401)
  • (helm/v1-alpha): Introduced the new helm.kubebuilder.io/v1-alpha plugin to enable users to distribute solutions using Helm Charts. Example scaffolds are available under testdata/project-v4-with-plugins/dist/chart. (#4227, #4315, #4350, #4351, #4356, #4357, #4371, #4377, #4383, #4380, #4373, #4386, #4375, #4388, #4406, #4399, #4419,#4451). IMPORTANT: The helm.kubebuilder.io/v1-alpha is an experimental initial version. (More info)
  • (go/v4,kustomize/v2): Add app.kubernetes.io/name label to allow more precise configurations (#4437)
  • (go/v4): Standardize the webhook and controller test suites (#4447)
  • (go/v4): Add new makefile target to check and validate the linter config (#4462)
  • (go/v4): Added Hub and Spoke support for conversion webhooks. Developers can now scaffold webhooks for resource conversion more easily. (#4254) Example:
    # Create API to test conversion from v1 to v2
    $ kubebuilder create api --group crew --version v1 --kind FirstMate --controller=true --resource=true --make=false
    $ kubebuilder create api --group crew --version v2 --kind FirstMate --controller=false --resource=true --make=false
    $ kubebuilder create webhook --group crew --version v1 --kind FirstMate --conversion --make=false --spoke v2

🐛 Bug Fixes

  • (go/v4): Fixed an issue where GitHub Actions workflows were overwritten by commands, ensuring users can now customize workflows freely without their changes being overridden. (#4379)
  • (go/v4): Resolved linting issues in generated scaffolds. (#4384)
  • (kustomize/v2, go/v4): Fixed CA injection for conversion webhooks. Previously, the CA injection patch was not accurate; The injection should occur only for CRDs, which are conversion types and not for all CRDs when a webhook with --conversion option is scaffolded. The issue goes back to release 3.5.0 (where to replace vars for replacements was done and the kustomize/v2-alpha plugin was introduced). It was not previously found, likely because conversion webhook features were incomplete, which is addressed in this release. Now, users can use the tool to generate the conversion webhooks properly (#4254). (#4282)
  • (go/v4): Ensure that schemas are added before starting EnvTest-based suite tests for webhooks and controllers (#4466)
  • (go/v4): e2e-tests: cleanup by removing calls to call make generate and manifests (#4471)

Thanks to all our contributors! 🎉

What's Changed

Read more

v4.3.1

09 Nov 12:30
a9ee390

Choose a tag to compare

changes since v4.3.0

✨ New Features

Note: Only minor version updates were applied in this release.

  • (go/v4): Upgraded controller-runtime from v0.19.0 to v0.19.1. (#4234)
  • (go/v4): Updated kustomize from v5.4.3 to v5.5.0 (#4235)
  • (go/v4): Upgraded golangci-lint from v1.59 to v1.61 with minor adjustments for lint rules. (#4236)

🐛 Bug Fixes

  • (kustomize/v2, go/v4): Corrected the generation of manifests under config/crd/patches to ensure the /convert service patch is only created for webhooks configured with --conversion. (#4280)
  • (go/v4): Fixed path configuration for webhook markers generated for core types with non-"core" group values, ensuring accurate path handling in core-type webhooks. (#4301)
  • (go/v4): Resolved misleading comments regarding metrics configuration for certs in cmd/main.go, providing clarity on secure metrics setup. (#4245)
  • (go/v4): Enabled the --make=false option for webhook creation, ensuring consistency with other command options and improved flexibility. (#4275)
  • (kustomize/v2, go/v4): Moved the cert-manager uncomment block to the top of kustomization.yaml to enhance visibility (#4283)
  • (Impact only for library users): ⚠️ Restructured internal layout to move main.go boilerplate into the cmd/ directory. This change is relevant for users consuming the framework as a library and Kubebuilder maintainers only, providing a cleaner separation of code. (#4246)

Thanks to all our contributors! 🎉

What's Changed

  • 🌱 Fix incorrect image reference for DeployImage plugin in test data by @camilamacedo86 in #4230
  • 🌱 e2e tests: increase coverage by validating webhooks with installer-based installation by @camilamacedo86 in #4231
  • 🌱 Fix simplify external plugin tests by @camilamacedo86 in #4233
  • ✨ Upgrade controller-runtime from v0.19.0 to v0.19.1 by @camilamacedo86 in #4234
  • ✨ Upgrade kustomize version from v5.4.3 to v5.5.0 by @camilamacedo86 in #4235
  • ✨ Upgrade golangci-lint from v1.59 to v1.61 and resolve new lint issues by @camilamacedo86 in #4236
  • 🌱 Upgrade GoReleaser version from v2.1.0 to v2.3.2 used in the GitHub action by @camilamacedo86 in #4237
  • 📖 Upgrade controller-gen version used to generate documentation by @camilamacedo86 in #4238
  • 🐛 fix internal layout: move main.go boilerplate to cmd/ directory by @camilamacedo86 in #4246
  • 📖 Resolve navigation bar CSS issue and sidebar toggle functionality. by @thiha-min-thant in #4242
  • 🌱 Update Dependabot configuration by @camilamacedo86 in #4249
  • 🌱 : Update dependabot.yml to just raise PRs against project-v4 sample by @camilamacedo86 in #4273
  • 🌱 Bump github.com/onsi/gomega from 1.34.2 to 1.35.0 by @dependabot in #4256
  • 🌱 Bump github.com/onsi/ginkgo/v2 from 2.20.2 to 2.21.0 by @dependabot in #4257
  • 📖 move Versions Compatibility and Supportability info to a dedicated page by @camilamacedo86 in #4250
  • 📖 Correct misleading information in production note for metrics config by @camilamacedo86 in #4244
  • 🐛 (go/v4): Fix misleading metrics configuration comments in cmd/main.go for metrics certs by @camilamacedo86 in #4245
  • 🐛 clarify usage of alpha generate command as internal-only by @camilamacedo86 in #4247
  • 🌱 Add SBOM generation for Cyber Resilience Act compliance by @camilamacedo86 in #4248
  • 🌱 Add GitHub workflow to scan project with CodeQL by @camilamacedo86 in #4252
  • 🐛 fix: (go/v4): ensure --make=false option is available for webhook creation for consistency by @camilamacedo86 in #4275
  • 🌱 Update codeql.yml to run the workflow once per week only by @camilamacedo86 in #4277
  • 🌱 fix: optimize and improve testdata scaffolding for webhook conversion by @camilamacedo86 in #4276
  • 📖 fix(docs): update Quick Start guide with information on using the master branch by @camilamacedo86 in #4228
  • 🌱 Bump github.com/onsi/gomega from 1.35.0 to 1.35.1 by @dependabot in #4279
  • 🌱 Bump actions/setup-go from 4 to 5 by @dependabot in #4278
  • 🌱 Add bundle installer for sample projects in docs by @camilamacedo86 in #4281
  • 🐛 (kustomize/v2,go/v4): Move cert-manager uncomment block to top of kustomization.yaml for better visibility in new projects by @camilamacedo86 in #4283
  • 🐛 (kustomize/v2, go/v4): Fix incorrect generation of manifests under config/crd/patches. Previously, the /convert service patch was being generated for all webhooks instead of only for those with --conversion enabled. by @camilamacedo86 in #4280
  • 🐛 (go/v4) Fix issue with scaffolding multiple webhooks for the same resource by @camilamacedo86 in #4286
  • 📖 (doc) - Fix broken URL by @monteiro-renato in #4298
  • 🌱 Bump golang.org/x/text from 0.19.0 to 0.20.0 by @dependabot in #4303
  • 📖 (doc) - Fix Add missing Reference-style Link by @monteiro-renato in #4304
  • 🐛 (go/v4): Fix path configuration for webhook markers generated for core types with non-"core" group values by @damsien in #4301
  • 🌱 Bump golang.org/x/tools from 0.26.0 to 0.27.0 by @dependabot in #4307
  • 📖 (doc): getting started: fix information about make command for generating manifests by @vtrenton in #4306
  • 🐛 revert the changes done in the PR #4286 by @camilamacedo86 in #4308

New Contributors

Full Changelog: v4.3.0...v4.3.1