Skip to content

Releases: kubernetes-sigs/cluster-api

v1.4.7

26 Sep 16:14
45ebb2c
Compare
Choose a tag to compare

👌 Kubernetes version support

  • Management Cluster: v1.23.x -> v1.27.x
  • Workload Cluster: v1.21.x -> v1.27.x

More information about version support can be found here

Changes since v1.4.6


📈 Overview

  • 10 new commits merged
  • 2 bugs fixed 🐛

🐛 Bug Fixes

  • KCP: Fix KCP Controller reconcile always return error when workload cluster is unreachable (#9450)
  • MachineHealthCheck: Fix excessive trace logging in the machine health check controller (#9427)

🌱 Others

  • Dependency: Bump cert-manager to v1.13.0 (#9414)
  • Dependency: Bump to Go 1.20.8 (#9432)
  • KCP: Remove redundant GetRESTConfig in KCP Management.GetWorkloadCluster (#9453)

📖 Additionally, there have been 3 contributions to our documentation and book. (#9366, #9431, #9492)

Thanks to all our contributors! 😊

v1.5.1

29 Aug 16:36
db17cb2
Compare
Choose a tag to compare

👌 Kubernetes version support

  • Management Cluster: v1.24.x -> v1.28.x
  • Workload Cluster: v1.22.x -> v1.28.x

More information about version support can be found here

Changes since v1.5.0


📈 Overview

  • 35 new commits merged
  • 2 feature additions ✨
  • 10 bugs fixed 🐛

✨ New Features

  • MachineSet: Adjust preflight check to allow kubelet version skew of 3 for clusters running v1.28 and above (#9233)
  • Testing/documentation: v1.28: Prepare quickstart, capd and tests for the new release including kind bump (#9225)

🐛 Bug Fixes

  • CAPBK: Certificate paths in cloud-init scripts should not use a platform-dependent path separator (#9230)
  • CAPD: Delete container after failed start to work around port allocation issues (#9130)
  • ClusterClass: Add topology-owned label to MachineHealthChecks. (#9204)
  • ClusterClass: Fix ClusterClass enqueue for ExtensionConfig (#9137)
  • Devtools: Fix tilt-prepare leader-elect setting (#9316)
  • e2e: Pin conformance image to a version which includes a fix for the dualstack tests (#9256)
  • KCP: Allow unsetting useExperimentalRetryJoin field from KubeadmControlPlane (#9202)
  • MachineDeployment: MD controller: use regular random suffix for MachineSets, ensure max length 63 (#9329)
  • util: Fix AddAnnotations for unstructured.Unstructured (#9176)

🌱 Others

  • CAPD: Fix multi error handling in RunContainer (#9243)
  • CI: Add verify-govulncheck and verify-vulnerabilities targets and integrate to scan action (#9179)
  • CI: Update base branch for link checker (#9207)
  • clusterctl: Set controller-runtime logger for clusterctl (#9129)
  • clusterctl: Update cert-manager to v1.12.3 (#9198)
  • Dependency: Bump controller-runtime to v0.15.1 (#9127)
  • Dependency: Bump corefile-migration library to v1.0.21 (#9309)
  • Dependency: Bump envtest binaries to 1.28 (#9304)
  • Dependency: Bump golang.org/x/net to v0.13.0 (#9122)
  • Dependency: Bump to Go 1.20.7 (#9105)
  • e2e: Add back flavor to Waiter interface (#9177)
  • e2e: Add CRS re-reconcile to ownerReference test (#9301)
  • e2e: Add test for ownerReference apiVersion update (#9297)
  • e2e: Refactor e2e ownerRef test utils (#9314)
  • e2e: Test and document controller ownerReferences (#9303)
  • logging: Fix patch errors not being logged (#9234)

📖 Additionally, there have been 8 contributions to our documentation and book. (#9332, #9226, #9205, #9238, #9154, #9117, #9090, #9082)

Thanks to all our contributors! 😊

v1.4.6

29 Aug 16:16
38a968f
Compare
Choose a tag to compare

👌 Kubernetes version support

  • Management Cluster: v1.23.x -> v1.27.x
  • Workload Cluster: v1.21.x -> v1.27.x

More information about version support can be found here

Changes since v1.4.5


📈 Overview

  • 20 new commits merged
  • 9 bugs fixed 🐛

🐛 Bug Fixes

  • CAPBK: Certificate paths in cloud-init scripts should not use a platform-dependent path separator (#9231)
  • CAPD: Delete container after failed start to work around port allocation issues (#9131)
  • ClusterClass: Add topology-owned label to MachineHealthChecks. (#9203)
  • ClusterClass: Fix ClusterClass enqueue for ExtensionConfig (#9138)
  • Devtools: Fix tilt-prepare leader-elect setting (#9317)
  • KCP: Allow unsetting useExperimentalRetryJoin field from KubeadmControlPlane (#9201)
  • MachineDeployment: MD controller: use regular random suffix for MachineSets, ensure max length 63 (#9330)
  • util: Fix AddAnnotations for unstructured.Unstructured (#9178)

🌱 Others

  • CAPD: Fix multi error handling in RunContainer (#9242)
  • CI: Add verify-govulncheck and verify-vulnerabilities targets and integrate to scan action (#9180)
  • CI: Update base branch for link checker (#9206)
  • Dependency: Bump corefile-migration library to v1.0.21 (#9310)
  • Dependency: Bump golang.org/x/net to v0.13.0 (#9123)
  • Dependency: Bump to Go 1.19.12 (#9106)
  • Dependency: Update cert-manager to v1.12.3 (#9199)
  • logging: Fix patch errors not being logged (#9235)

📖 Additionally, there have been 4 contributions to our documentation and book. (#9333, #9245, #9155, #9118)

Thanks to all our contributors! 😊

v1.5.0

25 Jul 17:29
v1.5.0
4abf44c
Compare
Choose a tag to compare

👌 Kubernetes version support

  • Management Cluster: v1.24.x -> v1.27.x
  • Workload Cluster: v1.22.x -> v1.27.x

More information about version support can be found here

Highlights

  • MS preflight checks to improve cluster stability (behind feature gate).
  • Support for concurrent MachineDeployment upgrades in classy clusters.
  • Support for add-on providers in clusterctl.
  • Performance improvements when using CAPI at scale, new dev-tools and a new in-memory infrastructure provider for scale testing.
  • MachinePool Machines improve MachinePool observability.
  • clusterctl plugins allow custom code to be called from clusterctl.
  • More metrics have been enabled through a custom Kube State Metrics config, and example Grafana, Prometheus and other observability tool configurations have been added to the repo.
  • Cluster controller now avoids double rollouts during Kubernetes upgrades of classy clusters.

Deprecation warning

The API version v1alpha3 is no longer served in this release. API version v1alpha4 is deprecated and will be removed in v1.6.

Cluster API v1.4 compared to v1.5

See the Cluster-API book for an overview over relevant changes between Cluster API v1.4 and v1.5 for maintainers of providers and consumers of our Go API.

Full list of changes since v1.4.0


📈 Overview

  • 335 new commits merged
  • 4 breaking changes ⚠️
  • 19 feature additions ✨
  • 67 bugs fixed 🐛

⚠️ Breaking Changes

✨ New Features

  • CAPBK: Use caching read for bootstrap config owner (#8867)
  • CAPD: Use k8s v1.27.0 in quickstart docs and CAPD (#8518)
  • CAPIM: Enable Kubernetes upgrades in CAPIM (#8938)
  • CAPIM: Add in memory provider (#8799)
  • ClusterClass: add support or concurrent MD upgrades in classy clusters (#8432)
  • ClusterClass: Add webhook warning for missing ClusterClass (#8746)
  • clusterctl: Add MachinePool Machine support in clusterctl discovery (#8836)
  • clusterctl: Add support for add-on providers in clusterctl (#8472)
  • clusterctl: Accept resource mutators in Move operation (#7966)
  • clusterctl: Introduce possibility to create clusterctl plugins (#8957)
  • Devtools: hack/observability bump kube-state-metrics chart to get version v2.9.2 (#8979)
  • Devtools: hack/observability: Add Parca, Bump observability tools, Add Grafana scale dashboard (#8754)
  • Devtools: hack/observability: improve dashboards (#8964)
  • e2e: collect debug information about leftover processes (#8734)
  • IPAM: Implements Getter interface for IPAddressClaim object (#8374)
  • Machine: Enable configuring the kubernetes rest client timeout for draining nodes (#8917)
  • MachinePool: Add MachinePool Machine implementation in core CAPI components (#8828)
  • MachineSet: MS preflight checks to improve cluster stability (#8595)
  • KCP/Core/CAPD: Add flags for configuring rate limits (#8579)
  • util: Move mergeMap to util (#8377)

🐛 Bug Fixes

  • API: only set finalizers if deletionTimestamp is not set (#8949)
  • API: Ensure ownerReference apiVersions are always up to date (#8256)
  • CAPBK: ignition: start kubeadm after network.target (#8772)
  • CAPBK: set uninitialized taint only on worker nodes (#8358)
  • CAPD: Add kind mapper (#8880)
  • CAPD: change the haproxy entrypoint to prevent getting stopped immediately after start (#8685)
  • CAPD: Implement watch filter (#8789)
  • CAPD: Delegate CAPD port selection to the container runtime (#8642)
  • CAPD: fix kind mapper entry for v1.25.11 (#8914)
  • CAPD: test/e2e fix fail-swap-on=false flag not being part of kind images anymore (#8767)
  • CAPIM: fix cluster deletion in the in-memory API server (#8818)
  • CAPIM: fix inmemory provider docker build (#8822)
  • CAPIM: test/e2e/in-memory: set providerID after VM is provisioned (#8879)
  • CI: Always build Kind images for upgrade tests (#8859)
  • CI: Ensure ALWAYS_BUILD_KIND_IMAGES is defaulted correctly in ci script (#8873)
  • CI: use pull_request instead of pull_request_target (#8635)
  • ClusterCacheTracker: Stop pod caching when checking workload cluster (#8850)
  • ClusterClass: avoid errors when MHC and upgrade occur together in classy clusters (#8464)
  • ClusterClass: Drop uid from error messages (#8333)
  • ClusterClass: topology controller should avoid unnecessary rollouts during upgrades (#8628)
  • ClusterClass: update TopologyReconciled condition on cluster deletion (#8422)
  • ClusterClass: Validate variables in defaulting webhook (#8332)
  • clusterctl: Add soft ownership from clusters to ClusterResourceSetBinding (#8318)
  • clusterctl: return early if release for latest tag does not exist yet (#8253)
  • clusterctl: Ensure all GitHub releases are fetched when searching provider versions (#8240)
  • clusterctl: handle nil pointer in clusterctl describe (#8724)
  • clusterctl: Return error on infra cluster and control plane discovery (#8604)
  • clusterctl: Use local kustomize version in create-local-repository.py (#8414)
  • ClusterResourceSet: Make sure the Kubernetes API Server service already created on remote cluster before applying ClusterResourceSets (#8048)
  • ClusterResourceSet: continue applying when apply for a single cluster failed (#8611)
  • Dependency: Bump to docker v24.0.5-0.20230714235725-36e9e796c6fc (#9042)
  • Dependency: Update kindnetd and kindest/haproxy (#8469)
  • Devtools: Change tilt debug base image to golang (#9072)
  • Devtools: fix build_engine setting when using podman (#8972)
  • Devtools: set CR logger in tilt-prepare, fix allowed contexts (#8919)
  • Devtools: Update clean-charts make target for new paths (#8904)
  • e2e: Adjust machinepool helper e2e timeout (#8739)
  • e2e: Fix length check in MD helper (#8352)
  • e2e: Ignore cert annotation in rollout test (#8761)
  • e2e: Increase timeout for clusterclass rollout test (#8897)
  • e2e: Increased assertClusterObjects timeout (#8758)
  • e2e: Pin kindest/node images to known good versions in clusterctl upgrade tests (#8860)
  • e2e: Remove non-functioning ginkgo.no-color flag (#8703)
  • e2e: Revert "Add calico as e2e test CNI" (#8575)
  • e2e: check for machines being ready after provisioning on Runtime SDK test (#8625)
  • e2e: use topology cluster-template for clusterctl upgrade mgmt cluster (#8311)
  • e2e: test/framework fix docker pod log collector (#8634)
  • IPAM: fix gateway being required for IPAddress (#8506)
  • KCP: Allow machine rollout if cert reconcile fails (#8711)
  • KCP: enable updates from CloudInit (mostly ubuntu) based KCPs to Ignition (flatcar) based KCPs (#8339)
  • KCP: Ensure nil-pointer check in KCP syncMachines (#8481)
  • KCP: Prevent KCP to create many private keys for each reconcile (#8617)
  • KCP: requeue KCP object if ControlPlaneComponentsHealthyCondition is not yet true (#9035)
  • Machine: bug fix to set node interruptible label (#8297)
  • Machine: fix node label propagation (#8427)
  • MachinePool: Add node watcher to MachinePool controller (#8443)
  • MachinePool: Fix MachinePool node taint patching (#8462)
  • MachinePool: always patch owned conditions, fix GetTypedPhase, doc fixes (#8627)
  • MachinePool: Update MachinePool bootstrap dataSecretName when bootstrap config changes (#8667)
  • Release: Alphabetically sorting release tool output (#9060)
  • Release: ensure relase notes tool can be used for external projects again (#9021)
  • Testing: Catch failure when fetching component URLs (#8455)
  • Testing: Fix flake in machine phases test (#8370)
  • Testing: Fix flaky wait in CRS test (#8334)
  • Testing: internal/machine-controller fix flakes in phases test (#8576)
  • Testing: machine-controller: fix phase tests race condition in tests on lastUpdated field (#8484)
  • Testing: Use CreateAndWait in MP ScaleFromZero test (#8927)

🌱 Others

  • API: Deprecate v1alpha3 and v1alpha4 in CRDs (#8687)
  • CAPBK: replace reflect deepequal in bootstrap kubeadm (#8266)
  • CAPD: Automatically set kubelet args for capd (#8881)
  • CAPD: only ignore necessary kubeadm preflight errors (#7911)
  • CAPIM: add ClusterClass support for in-memory provider (#8807)
  • CAPIM: Add startup timeout to the in memory provider (#8831)
  • CAPIM: Add watch to in-memory server multiplexer (#8851)
  • CAPIM: Enable update for coreDNS and kube-proxy (#8899)
  • CAPIM: fix readme for in-memory provider (#8905)
  • CAPIM: Fixups for watch in in-memory apiServer (#8898)
  • CAPIM: Improve etcd management in CAPIM (#8906)
  • CAPIM: Add apiserver & etcd metrics (#8962)
  • CAPIM: Enable unit tests (#8886)
  • CAPIM: Improve locking, return errors instead of panic (#8945)
  • CAPIM: Improve performance by fixing locking issues (#8895)
  • CAPIM: Sync in-memory provider ClusterClass with test (#8892)
  • CAPIM: Rename controller files (#8830)
  • CAPIM: Use consistent spelling for release artifacts (#8853)
  • CI: Add area/dependency label for dependabot when bumping gomod (#8410)
  • CI: Add dependency label to github actions update (#8845)
  • CI: Switch cloudbuild.yaml to e2 machine type (#8428)
  • CI: verifier: change back to pull_request_target to make it work again (#8637)
  • ClusterCacheTracker: ensure Get/List calls are not getting stuck when apiserver is unreachable (#9030)
  • Cluster...
Read more

v1.4.5

25 Jul 17:10
v1.4.5
d5e6afa
Compare
Choose a tag to compare

👌 Kubernetes version support

  • Management Cluster: v1.23.x -> v1.27.x
  • Workload Cluster: v1.21.x -> v1.27.x

More information about version support can be found here

Changes since v1.4.4


📈 Overview

  • 13 new commits merged
  • 6 bugs fixed 🐛

🐛 Bug Fixes

  • clusterctl: Return early if release for latest tag does not exist yet (#8965)
  • Dependency: Bump to docker v24.0.5-0.20230714235725-36e9e796c6fc (#9043)
  • e2e: Bump kindest/node image used in e2e tests (#8974)
  • e2e: Increase timeout for clusterclass rollout test (#8937)
  • KCP: Prevent nil pointer exception in kcp controller when in… (#8991)
  • KCP: Requeue KCP object if ControlPlaneComponentsHealthyCondition is not yet true (#9036)

🌱 Others

  • CAPD: Set Kubelet args internally in CAPD (#8929)
  • ClusterCacheTracker: ClusterCacheTracker: ensure Get/List calls are not getting stuck when apiserver is unreachable (#9027)
  • Dependency: Bump google.golang.org/grpc to v1.55.0 (#8970)
  • Devtools: Build golangci-lint locally (#8935)
  • e2e: Add SHA to default KIND image used in e2e tests (#8976)
  • Dependency: Bump docker to v24.0.5 (#9066)
  • Devtools: Change tilt debug base image to golang (#9074)

Thanks to all our contributors! 😊

v1.3.10

25 Jul 17:08
v1.3.10
3f7ccb8
Compare
Choose a tag to compare

👌 Kubernetes version support

  • Management Cluster: v1.20.x -> v1.26.x [1]
  • Workload Cluster: v1.18.x -> v1.26.x

[1] When using Cluster API with the experimental CLUSTER_TOPOLOGY feature, the Kubernetes version of the management cluster must be >= 1.22.0.

More information about version support can be found here

Changes since v1.3.9


📈 Overview

  • 6 new commits merged
  • 2 bugs fixed 🐛

🐛 Bug Fixes

  • Dependency: Bump to docker v24.0.5-0.20230714235725-36e9e796c6fc (#9046)
  • KCP: Requeue KCP object if ControlPlaneComponentsHealthyCondition is not yet true (#9034)

🌱 Others

  • ClusterCacheTracker: ClusterCacheTracker: ensure Get/List calls are not getting stuck when apiserver is unreachable (#9033)
  • Dependency: Bump google.golang.org/grpc to v1.55.0 (#8971)
  • Dependency: Bump docker to v24.0.5 (#9067)
  • Dependency: Change tilt debug base image to golang (#9075)

Thanks to all our contributors! 😊

v1.5.0-rc.1

18 Jul 16:27
v1.5.0-rc.1
038b533
Compare
Choose a tag to compare
v1.5.0-rc.1 Pre-release
Pre-release

🚨 This is a RELEASE CANDIDATE. Use it only for testing purposes. If you find any bugs, file an issue.

⚠️ Deprecation warning

The API version v1alpha3 is no longer served in this release. API version v1alpha4 is deprecated and will be removed in v1.6.

Changes since v1.5.0-rc.0


📈 Overview

  • 1 new commits merged

🌱 Others

  • util: Move internal.labels to format package for use by providers (#9006)

Reference to v1.5.0-rc.0 release notes

Changes since release v1.4.0

👌 Kubernetes version support

  • Management Cluster: v1.24.x -> v1.27.x
  • Workload Cluster: v1.22.x -> v1.27.x

More information about version support can be found here

Changes since v1.4.0


📈 Overview

  • 324 new commits merged
  • 4 breaking changes ⚠️
  • 19 feature additions ✨
  • 62 bugs fixed 🐛

⚠️ Breaking Changes

  • CAPD: Use k8s v1.27.0 in quickstart docs and CAPD (#8518)
  • clusterctl: Bump to CR v0.15.0 (#8007)
  • clusterctl: Follow XDG Directory standard for config/data/... files (#6913)
  • clusterctl: Stop serving v1alpha3 API types (#8549)

✨ New Features

  • CAPBK: Use caching read for bootstrap config owner (#8867)
  • CAPIM: Enable Kubernetes upgrades in CAPIM (#8938)
  • ClusterClass: Add webhook warning for missing ClusterClass (#8746)
  • ClusterClass: add support or concurrent MD upgrades in classy clusters (#8432)
  • clusterctl: Add MachinePool Machine support in clusterctl discovery (#8836)
  • clusterctl: Add in memory provider (#8799)
  • clusterctl: Add support for add-on providers in clusterctl (#8472)
  • clusterctl: Introduce possibility to create clusterctl plugins (#8957)
  • clusterctl: feat: accept resource mutators in Move operation (#7966)
  • Devtools: hack/observability bump kube-state-metrics chart to get version v2.9.2 (#8979)
  • Devtools: hack/observability: Add Parca, Bump observability tools, Add Grafana scale dashboard (#8754)
  • Devtools: hack/observability: improve dashboards (#8964)
  • e2e: ci: collect debug information about leftover processes (#8734)
  • IPAM: Implements Getter interface for IPAddressClaim object (#8374)
  • KCP/Core/CAPD: Add flags for configuring rate limits (#8579)
  • Machine: Enable configuring the kubernetes rest client timeout for draining nodes (#8917)
  • MachinePool: Add MachinePool Machine implementation in core CAPI components (#8828)
  • MachineSet: MS preflight checks to improve cluster stability (#8595)
  • util: Move mergeMap to util (#8377)

🐛 Bug Fixes

  • API: Ensure ownerReference apiVersions are always up to date (#8256)
  • API: all: only set finalizers if deletionTimestamp is not set (#8949)
  • CAPBK: ignition: start kubeadm after network.target (#8772)
  • CAPBK: set uninitialized taint only on worker nodes (#8358)
  • CAPD: Add kind mapper (#8880)
  • CAPD: CAPD: Implement watch filter (#8789)
  • CAPD: CAPD: change the haproxy entrypoint to prevent getting stopped immediately after start (#8685)
  • CAPD: Delegate CAPD port selection to the container runtime (#8642)
  • CAPD: test/capd: fix kind mapper entry for v1.25.11 (#8914)
  • CAPD: test/e2e fix fail-swap-on=false flag not being part of kind images anymore (#8767)
  • CAPIM: fix cluster deletion in the in-memory API server (#8818)
  • CAPIM: fix inmemory provider docker build (#8822)
  • CAPIM: test/e2e/in-memory: set providerID after VM is provisioned (#8879)
  • CI: Always build Kind images for upgrade tests (#8859)
  • CI: Ensure ALWAYS_BUILD_KIND_IMAGES is defaulted correctly in ci script (#8873)
  • CI: verifier: use pull_request instead of pull_request_target (#8635)
  • ClusterCacheTracker: ClusterCacheTracker: Stop pod caching when checking workload cluster (#8850)
  • ClusterClass: Drop uid from error messages (#8333)
  • ClusterClass: Validate variables in defaulting webhook (#8332)
  • ClusterClass: avoid errors when MHC and upgrade occur together in classy clusters (#8464)
  • ClusterClass: topology controller should avoid unnecessary rollouts during upgrades (#8628)
  • ClusterClass: update TopologyReconciled condition on cluster deletion (#8422)
  • clusterctl: Add soft ownership from clusters to ClusterResourceSetBinding (#8318)
  • clusterctl: Ensure all GitHub releases are fetched when searching provider versions (#8240)
  • clusterctl: Return error on infra cluster and control plane discovery (#8604)
  • clusterctl: Use local kustomize version in create-local-repository.py (#8414)
  • clusterctl: clusterctl: return early if release for latest tag does not exist yet (#8253)
  • clusterctl: handle nil pointer in clusterctl describe (#8724)
  • ClusterResourceSet: Make sure the Kubernetes API Server service already created on remote cluster before applying ClusterResourceSets (#8048)
  • ClusterResourceSet: ClusterResourceSet: continue applying when apply for a single cluster failed (#8611)
  • Dependency: Update kindnetd and kindest/haproxy (#8469)
  • Devtools: Update clean-charts make target for new paths (#8904)
  • Devtools: tilt: fix build_engine setting when using podman (#8972)
  • Devtools: tilt: set CR logger in tilt-prepare, fix allowed contexts (#8919)
  • e2e: Adjust machinepool helper e2e timeout (#8739)
  • e2e: Fix length check in MD helper (#8352)
  • e2e: Ignore cert annotation in rollout test (#8761)
  • e2e: Increase timeout for clusterclass rollout test (#8897)
  • e2e: Increased assertClusterObjects timeout (#8758)
  • e2e: Pin kindest/node images to known good versions in clusterctl upgrade tests (#8860)
  • e2e: Remove non-functioning ginkgo.no-color flag (#8703)
  • e2e: Revert "Add calico as e2e test CNI" (#8575)
  • e2e: test/e2e check for machines being ready after provisioning on Runtime SDK test (#8625)
  • e2e: test/e2e: use topology cluster-template for clusterctl upgrade mgmt cluster (#8311)
  • e2e: test/framework fix docker pod log collector (#8634)
  • IPAM: ipam: fix gateway being required for IPAddress (#8506)
  • KCP: Allow machine rollout if cert reconcile fails (#8711)
  • KCP: Ensure nil-pointer check in KCP syncMachines (#8481)
  • KCP: Prevent KCP to create many private keys for each reconcile (#8617)
  • KCP: enable updates from CloudInit (mostly ubuntu) based KCPs to Ignition (flatcar) based KCPs (#8339)
  • Machine: bug fix to set node interruptible label (#8297)
  • Machine: fix node label propagation (#8427)
  • MachinePool: Add node watcher to MachinePool controller (#8443)
  • MachinePool: Fix MachinePool node taint patching (#8462)
  • MachinePool: MachinePool: always patch owned conditions, fix GetTypedPhase, doc fixes (#8627)
  • MachinePool: Update MachinePool bootstrap dataSecretName when bootstrap config changes (#8667)
  • Testing: Catch failure when fetching component URLs (#8455)
  • Testing: Fix flake in machine phases test (#8370)
  • Testing: Fix flaky wait in CRS test (#8334)
  • Testing: Use CreateAndWait in MP ScaleFromZero test (#8927)
  • Testing: internal/machine-controller fix flakes in phases test (#8576)
  • Testing: machine-controller: fix phase tests race condition in tests on lastUpdated field (#8484)

🌱 Others

  • API: Deprecate v1alpha3 and v1alpha4 in CRDs (#8687)
  • CAPBK: replace reflect deepequal in bootstrap kubeadm (#8266)
  • CAPD: Automatically set kubelet args for capd (#8881)
  • CAPD: CAPD: only ignore necessary kubeadm preflight errors (#7911)
  • CAPIM: Add startup timeout to the in memory provider (#8831)
  • CAPIM: Add watch to in-memory server multiplexer (#8851)
  • CAPIM: CAPIM: Enable update for coreDNS and kube-proxy (#8899)
  • CAPIM: Fixups for watch in in-memory apiServer (#8898)
  • CAPIM: Improve etcd management in CAPIM (#8906)
  • CAPIM: add ClusterClass support for in-memory provider (#8807)
  • CAPIM: fix readme for in-memory provider (#8905)
  • CAPIM: in-memory provider: add apiserver & etcd metrics (#8962)
  • CAPIM: test/e2e/in-memory: enable unit tests (#8886)
  • CAPIM: test/e2e/in-memory: improve locking, return errors instead of panic (#8945)
  • CAPIM: test/e2e/in-memory: improve performance by fixing locking issues (#8895)
  • CAPIM: test/e2e/in-memory: sync in-memory provider ClusterClass with test (#8892)
  • CAPIM: test/infra/inmemory: rename controller files (#8830)
  • CI: Add area/dependency label for dependabot when bumping gomod (#8410)
  • CI: Add dependency label to github actions update (#8845)
  • CI: Switch cloudbuild.yaml to e2 machine type (#8428)
  • CI: verifier: change back to pull_request_target to make it work again (#8637)
  • ClusterCacheTracker: ClusterCacheTracker: improve error when workload cluster is not reachable (#8801)
  • ClusterCacheTracker: Deprecate DefaultIndex usage and remove where not needed (#8855)
  • ClusterCacheTracker: Use ClusterCacheTracker consistently (instead of NewClusterClient) (#8744)
  • ClusterCacheTracker: Use rest config from ClusterCacheTracker consistently (#8894)
  • ClusterClass: cluster/topology: use cached Cluster get in Reconcile (#8936)
  • ClusterClass: cluster/topology: use cached MD list in get current state (#8922)
  • ClusterClass: deprecate rolloutAfter in cluster topology (#8324)
  • ClusterClass: upgrading control plane should only be blocked if MD are upgrading (not just rolling out) (#8658)
  • clusterctl: Add move annotation on objects for cluster move operation (#8322)
  • clusterctl: Bump controller-tools to v0.12 (#8581)
  • clusterctl: CAPIM: use consistent spelling for release arti...
Read more

v1.5.0-rc.0

11 Jul 17:18
v1.5.0-rc.0
5dedc1b
Compare
Choose a tag to compare
v1.5.0-rc.0 Pre-release
Pre-release

🚨 This is a RELEASE CANDIDATE. Use it only for testing purposes. If you find any bugs, file an issue.

⚠️ Deprecation warning

The API version v1alpha3 is no longer served in this release. API version v1alpha4 is deprecated and will be removed in v1.6.

Changes since v1.5.0-beta.1


📈 Overview

  • 19 new commits merged
  • 7 feature additions ✨
  • 1 bugs fixed 🐛

✨ New Features

  • CAPIM: Enable Kubernetes upgrades in CAPIM (#8938)
  • ClusterClass: Add webhook warning for missing ClusterClass (#8746)
  • clusterctl: Add MachinePool Machine support in clusterctl discovery (#8836)
  • clusterctl: Introduce possibility to create clusterctl plugins (#8957)
  • Devtools: hack/observability bump kube-state-metrics chart to get version v2.9.2 (#8979)
  • Devtools: hack/observability: improve dashboards (#8964)
  • MachinePool: Add MachinePool Machine implementation in core CAPI components (#8828)

🐛 Bug Fixes

  • Devtools: tilt: fix build_engine setting when using podman (#8972)

🌱 Others

  • CAPIM: in-memory provider: add apiserver & etcd metrics (#8962)
  • Dependency: Bump golang.org/x/oauth2 from 0.9.0 to 0.10.0 (#8985)
  • Devtools: Protect well know registry from accidental push during tilt up (#8930)
  • Devtools: hack/observability: add apiserver request dashboards (#8978)
  • e2e: Add SHA to default KIND image used in e2e tests (#8975)
  • e2e: test/e2e: add field to scale test to deploy Clusters in separate namespace (#8963)
  • e2e: test/e2e: improve logging for a detected rollout (#8953)
  • KCP: KCP: Log the reason of a Machine rollout (#8959)
  • Dependency: Update golangci-lint to v1.53.3 (#8796)
  • Release: Improve release notes output (#8928)

📖 Additionally, there have been 1 contributions to our documentation and book. (#8958)

Reference to v1.5.0-beta.1 release notes

Changes since release v1.4.0

⚠️ RELEASE CANDIDATE NOTES ⚠️

👌 Kubernetes version support

  • Management Cluster: v1.24.x -> v1.27.x
  • Workload Cluster: v1.22.x -> v1.27.x

More information about version support can be found here

Changes since v1.4.0


📈 Overview

  • 323 new commits merged
  • 4 breaking changes ⚠️
  • 19 feature additions ✨
  • 62 bugs fixed 🐛

⚠️ Breaking Changes

  • CAPD: Use k8s v1.27.0 in quickstart docs and CAPD (#8518)
  • clusterctl: Bump to CR v0.15.0 (#8007)
  • clusterctl: Follow XDG Directory standard for config/data/... files (#6913)
  • clusterctl: Stop serving v1alpha3 API types (#8549)

✨ New Features

  • CAPBK: Use caching read for bootstrap config owner (#8867)
  • CAPIM: Enable Kubernetes upgrades in CAPIM (#8938)
  • ClusterClass: Add webhook warning for missing ClusterClass (#8746)
  • ClusterClass: add support or concurrent MD upgrades in classy clusters (#8432)
  • clusterctl: Add MachinePool Machine support in clusterctl discovery (#8836)
  • clusterctl: Add in memory provider (#8799)
  • clusterctl: Add support for add-on providers in clusterctl (#8472)
  • clusterctl: Introduce possibility to create clusterctl plugins (#8957)
  • clusterctl: feat: accept resource mutators in Move operation (#7966)
  • Devtools: hack/observability bump kube-state-metrics chart to get version v2.9.2 (#8979)
  • Devtools: hack/observability: Add Parca, Bump observability tools, Add Grafana scale dashboard (#8754)
  • Devtools: hack/observability: improve dashboards (#8964)
  • e2e: ci: collect debug information about leftover processes (#8734)
  • IPAM: Implements Getter interface for IPAddressClaim object (#8374)
  • KCP/Core/CAPD: Add flags for configuring rate limits (#8579)
  • Machine: Enable configuring the kubernetes rest client timeout for draining nodes (#8917)
  • MachinePool: Add MachinePool Machine implementation in core CAPI components (#8828)
  • MachineSet: MS preflight checks to improve cluster stability (#8595)
  • util: Move mergeMap to util (#8377)

🐛 Bug Fixes

  • API: Ensure ownerReference apiVersions are always up to date (#8256)
  • API: all: only set finalizers if deletionTimestamp is not set (#8949)
  • CAPBK: ignition: start kubeadm after network.target (#8772)
  • CAPBK: set uninitialized taint only on worker nodes (#8358)
  • CAPD: Add kind mapper (#8880)
  • CAPD: CAPD: Implement watch filter (#8789)
  • CAPD: CAPD: change the haproxy entrypoint to prevent getting stopped immediately after start (#8685)
  • CAPD: Delegate CAPD port selection to the container runtime (#8642)
  • CAPD: test/capd: fix kind mapper entry for v1.25.11 (#8914)
  • CAPD: test/e2e fix fail-swap-on=false flag not being part of kind images anymore (#8767)
  • CAPIM: fix cluster deletion in the in-memory API server (#8818)
  • CAPIM: fix inmemory provider docker build (#8822)
  • CAPIM: test/e2e/in-memory: set providerID after VM is provisioned (#8879)
  • CI: Always build Kind images for upgrade tests (#8859)
  • CI: Ensure ALWAYS_BUILD_KIND_IMAGES is defaulted correctly in ci script (#8873)
  • CI: verifier: use pull_request instead of pull_request_target (#8635)
  • ClusterCacheTracker: ClusterCacheTracker: Stop pod caching when checking workload cluster (#8850)
  • ClusterClass: Drop uid from error messages (#8333)
  • ClusterClass: Validate variables in defaulting webhook (#8332)
  • ClusterClass: avoid errors when MHC and upgrade occur together in classy clusters (#8464)
  • ClusterClass: topology controller should avoid unnecessary rollouts during upgrades (#8628)
  • ClusterClass: update TopologyReconciled condition on cluster deletion (#8422)
  • clusterctl: Add soft ownership from clusters to ClusterResourceSetBinding (#8318)
  • clusterctl: Ensure all GitHub releases are fetched when searching provider versions (#8240)
  • clusterctl: Return error on infra cluster and control plane discovery (#8604)
  • clusterctl: Use local kustomize version in create-local-repository.py (#8414)
  • clusterctl: clusterctl: return early if release for latest tag does not exist yet (#8253)
  • clusterctl: handle nil pointer in clusterctl describe (#8724)
  • ClusterResourceSet: : Make sure the Kubernetes API Server service already created on remote cluster before applying ClusterResourceSets (#8048)
  • ClusterResourceSet: ClusterResourceSet: continue applying when apply for a single cluster failed (#8611)
  • Dependency: Update kindnetd and kindest/haproxy (#8469)
  • Devtools: Update clean-charts make target for new paths (#8904)
  • Devtools: tilt: fix build_engine setting when using podman (#8972)
  • Devtools: tilt: set CR logger in tilt-prepare, fix allowed contexts (#8919)
  • e2e: Adjust machinepool helper e2e timeout (#8739)
  • e2e: Fix length check in MD helper (#8352)
  • e2e: Ignore cert annotation in rollout test (#8761)
  • e2e: Increase timeout for clusterclass rollout test (#8897)
  • e2e: Increased assertClusterObjects timeout (#8758)
  • e2e: Pin kindest/node images to known good versions in clusterctl upgrade tests (#8860)
  • e2e: Remove non-functioning ginkgo.no-color flag (#8703)
  • e2e: Revert "Add calico as e2e test CNI" (#8575)
  • e2e: test/e2e check for machines being ready after provisioning on Runtime SDK test (#8625)
  • e2e: test/e2e: use topology cluster-template for clusterctl upgrade mgmt cluster (#8311)
  • e2e: test/framework fix docker pod log collector (#8634)
  • IPAM: ipam: fix gateway being required for IPAddress (#8506)
  • KCP: Allow machine rollout if cert reconcile fails (#8711)
  • KCP: Ensure nil-pointer check in KCP syncMachines (#8481)
  • KCP: Prevent KCP to create many private keys for each reconcile (#8617)
  • KCP: enable updates from CloudInit (mostly ubuntu) based KCPs to Ignition (flatcar) based KCPs (#8339)
  • Machine: bug fix to set node interruptible label (#8297)
  • Machine: fix node label propagation (#8427)
  • MachinePool: Add node watcher to MachinePool controller (#8443)
  • MachinePool: Fix MachinePool node taint patching (#8462)
  • MachinePool: MachinePool: always patch owned conditions, fix GetTypedPhase, doc fixes (#8627)
  • MachinePool: Update MachinePool bootstrap dataSecretName when bootstrap config changes (#8667)
  • Testing: Catch failure when fetching component URLs (#8455)
  • Testing: Fix flake in machine phases test (#8370)
  • Testing: Fix flaky wait in CRS test (#8334)
  • Testing: Use CreateAndWait in MP ScaleFromZero test (#8927)
  • Testing: internal/machine-controller fix flakes in phases test (#8576)
  • Testing: machine-controller: fix phase tests race condition in tests on lastUpdated field (#8484)

🌱 Others

  • API: Deprecate v1alpha3 and v1alpha4 in CRDs (#8687)
  • CAPBK: replace reflect deepequal in bootstrap kubeadm (#8266)
  • CAPD: Automatically set kubelet args for capd (#8881)
  • CAPD: CAPD: only ignore necessary kubeadm preflight errors (#7911)
  • CAPIM: Add startup timeout to the in memory provider (#8831)
  • CAPIM: Add watch to in-memory server multiplexer (#8851)
  • CAPIM: CAPIM: Enable update for coreDNS and kube-proxy (#8899)
  • CAPIM: Fixups for watch in in-memory apiServer (#8898)
  • CAPIM: Improve etcd management in CAPIM (#8906)
  • CAPIM: add ClusterClass support for in-memory provider (#8807)
  • CAPIM: fix readme for in-memory provider (#8905)
  • CAPIM: in-memory provider: add apiserver & etcd metrics (#8962)
  • CAPIM: test/e2e/in-memory: enable unit tests (#8886)
  • CAPIM: test/e2e/in-memory: improve locking, return errors instead of panic (#8945)
  • CAPIM: tes...
Read more

v1.5.0-beta.1

05 Jul 17:17
2091c44
Compare
Choose a tag to compare
v1.5.0-beta.1 Pre-release
Pre-release

🚨 This is a BETA RELEASE. Use it only for testing purposes. If you find any bugs, file an issue.

Changes since v1.5.0-beta.0


📈 Overview

  • 19 new commits merged
  • 1 feature additions ✨
  • 1 bugs fixed 🐛

✨ New Features

  • Machine: Enable configuring the kubernetes rest client timeout for draining nodes (#8917)

🐛 Bug Fixes

  • API: all: only set finalizers if deletionTimestamp is not set (#8949)

🌱 Others

  • CAPIM: test/e2e/in-memory: improve locking, return errors instead of panic (#8945)
  • ClusterClass: cluster/topology: use cached Cluster get in Reconcile (#8936)
  • Devtools: Build golangci-lint locally (#8933)
  • Devtools: all: Add flags to enable block profiling (#8934)
  • Devtools: hack/observability: add metrics-server chart (#8950)
  • Devtools: hack/observability: skip preload images on non-kind clusters (#8931)
  • Devtools: hack/observability: use 20 Gi of storage for Prometheus (#8961)
  • KCP: KCP: cache secrets between LookupOrGenerate and ensureCertificatesOwnerRef (#8926)
  • ClusterCacheTracker/KCP/CAPBK: cache secrets in KCP, CABPK and ClusterCacheTracker (#8940)
  • MachineSet: add MachineFinalizer during machine computation (#8463)
  • CAPD: Drop cgroup-driver patch for CAPD (#8921)
  • e2e: add improvements to scale e2e (#8910)
  • e2e: test/e2e: increase apply timeout to 1m (#8941)

📖 Additionally, there have been 4 contributions to our documentation and book. (#8960, #8956, #8955, #8932)

Reference to v1.5.0-beta.0 release notes

More details about the release

⚠️ BETA RELEASE NOTES ⚠️

👌 Kubernetes version support

  • Management Cluster: v1.24.x -> v1.27.x
  • Workload Cluster: v1.22.x -> v1.27.x

More information about version support can be found here

Changes since v1.4.0


📈 Overview

  • 304 new commits merged
  • 4 breaking changes ⚠️
  • 12 feature additions ✨
  • 61 bugs fixed 🐛

⚠️ Breaking Changes

  • CAPD: Use k8s v1.27.0 in quickstart docs and CAPD (#8518)
  • clusterctl: Bump to CR v0.15.0 (#8007)
  • clusterctl: Follow XDG Directory standard for config/data/... files (#6913)
  • clusterctl: Stop serving v1alpha3 API types (#8549)

✨ New Features

  • CAPBK: Use caching read for bootstrap config owner (#8867)
  • ClusterClass: add support or concurrent MD upgrades in classy clusters (#8432)
  • Devtools: hack/observability: Add Parca, Bump observability tools, Add Grafana scale dashboard (#8754)
  • IPAM: Implements Getter interface for IPAddressClaim object (#8374)
  • KCP/Core/CAPD: Add flags for configuring rate limits (#8579)
  • Machine: Enable configuring the kubernetes rest client timeout for draining nodes (#8917)
  • MachineSet: MS preflight checks to improve cluster stability (#8595)
  • clusterctl: Add in memory provider (#8799)
  • clusterctl: Add support for add-on providers in clusterctl (#8472)
  • clusterctl: feat: accept resource mutators in Move operation (#7966)
  • e2e: ci: collect debug information about leftover processes (#8734)
  • util: Move mergeMap to util (#8377)

🐛 Bug Fixes

  • API: Ensure ownerReference apiVersions are always up to date (#8256)
  • API: all: only set finalizers if deletionTimestamp is not set (#8949)
  • CAPBK: ignition: start kubeadm after network.target (#8772)
  • CAPBK: set uninitialized taint only on worker nodes (#8358)
  • CAPD: Add kind mapper (#8880)
  • CAPD: CAPD: Implement watch filter (#8789)
  • CAPD: CAPD: change the haproxy entrypoint to prevent getting stopped immediately after start (#8685)
  • CAPD: Delegate CAPD port selection to the container runtime (#8642)
  • CAPD: test/capd: fix kind mapper entry for v1.25.11 (#8914)
  • CAPD: test/e2e fix fail-swap-on=false flag not being part of kind images anymore (#8767)
  • CAPIM: fix cluster deletion in the in-memory API server (#8818)
  • CAPIM: fix inmemory provider docker build (#8822)
  • CAPIM: test/e2e/in-memory: set providerID after VM is provisioned (#8879)
  • CI: Always build Kind images for upgrade tests (#8859)
  • CI: Ensure ALWAYS_BUILD_KIND_IMAGES is defaulted correctly in ci script (#8873)
  • CI: verifier: use pull_request instead of pull_request_target (#8635)
  • ClusterCacheTracker: ClusterCacheTracker: Stop pod caching when checking workload cluster (#8850)
  • ClusterClass: Drop uid from error messages (#8333)
  • ClusterClass: Validate variables in defaulting webhook (#8332)
  • ClusterClass: avoid errors when MHC and upgrade occur together in classy clusters (#8464)
  • ClusterClass: topology controller should avoid unnecessary rollouts during upgrades (#8628)
  • ClusterClass: update TopologyReconciled condition on cluster deletion (#8422)
  • ClusterResourceSet: : Make sure the Kubernetes API Server service already created on remote cluster before applying ClusterResourceSets (#8048)
  • ClusterResourceSet: ClusterResourceSet: continue applying when apply for a single cluster failed (#8611)
  • Dependency: Update kindnetd and kindest/haproxy (#8469)
  • Devtools: Update clean-charts make target for new paths (#8904)
  • Devtools: tilt: set CR logger in tilt-prepare, fix allowed contexts (#8919)
  • IPAM: ipam: fix gateway being required for IPAddress (#8506)
  • KCP: Allow machine rollout if cert reconcile fails (#8711)
  • KCP: Ensure nil-pointer check in KCP syncMachines (#8481)
  • KCP: Prevent KCP to create many private keys for each reconcile (#8617)
  • KCP: enable updates from CloudInit (mostly ubuntu) based KCPs to Ignition (flatcar) based KCPs (#8339)
  • Machine: bug fix to set node interruptible label (#8297)
  • Machine: fix node label propagation (#8427)
  • MachinePool: Add node watcher to MachinePool controller (#8443)
  • MachinePool: Fix MachinePool node taint patching (#8462)
  • MachinePool: MachinePool: always patch owned conditions, fix GetTypedPhase, doc fixes (#8627)
  • MachinePool: Update MachinePool bootstrap dataSecretName when bootstrap config changes (#8667)
  • Testing: Catch failure when fetching component URLs (#8455)
  • Testing: Fix flake in machine phases test (#8370)
  • Testing: Fix flaky wait in CRS test (#8334)
  • Testing: Use CreateAndWait in MP ScaleFromZero test (#8927)
  • Testing: internal/machine-controller fix flakes in phases test (#8576)
  • Testing: machine-controller: fix phase tests race condition in tests on lastUpdated field (#8484)
  • clusterctl: Add soft ownership from clusters to ClusterResourceSetBinding (#8318)
  • clusterctl: Ensure all GitHub releases are fetched when searching provider versions (#8240)
  • clusterctl: Return error on infra cluster and control plane discovery (#8604)
  • clusterctl: Use local kustomize version in create-local-repository.py (#8414)
  • clusterctl: clusterctl: return early if release for latest tag does not exist yet (#8253)
  • clusterctl: handle nil pointer in clusterctl describe (#8724)
  • e2e: Adjust machinepool helper e2e timeout (#8739)
  • e2e: Fix length check in MD helper (#8352)
  • e2e: Ignore cert annotation in rollout test (#8761)
  • e2e: Increase timeout for clusterclass rollout test (#8897)
  • e2e: Increased assertClusterObjects timeout (#8758)
  • e2e: Pin kindest/node images to known good versions in clusterctl upgrade tests (#8860)
  • e2e: Remove non-functioning ginkgo.no-color flag (#8703)
  • e2e: Revert "Add calico as e2e test CNI" (#8575)
  • e2e: test/e2e check for machines being ready after provisioning on Runtime SDK test (#8625)
  • e2e: test/e2e: use topology cluster-template for clusterctl upgrade mgmt cluster (#8311)
  • e2e: test/framework fix docker pod log collector (#8634)

🌱 Others

  • API: Deprecate v1alpha3 and v1alpha4 in CRDs (#8687)
  • CAPBK: replace reflect deepequal in bootstrap kubeadm (#8266)
  • CAPD: Automatically set kubelet args for capd (#8881)
  • CAPD: CAPD: only ignore necessary kubeadm preflight errors (#7911)
  • CAPIM: Add startup timeout to the in memory provider (#8831)
  • CAPIM: Add watch to in-memory server multiplexer (#8851)
  • CAPIM: CAPIM: Enable update for coreDNS and kube-proxy (#8899)
  • CAPIM: Fixups for watch in in-memory apiServer (#8898)
  • CAPIM: Improve etcd management in CAPIM (#8906)
  • CAPIM: add ClusterClass support for in-memory provider (#8807)
  • CAPIM: fix readme for in-memory provider (#8905)
  • CAPIM: test/e2e/in-memory: enable unit tests (#8886)
  • CAPIM: test/e2e/in-memory: improve locking, return errors instead of panic (#8945)
  • CAPIM: test/e2e/in-memory: improve performance by fixing locking issues (#8895)
  • CAPIM: test/e2e/in-memory: sync in-memory provider ClusterClass with test (#8892)
  • CAPIM: test/infra/inmemory: rename controller files (#8830)
  • CI: Add area/dependency label for dependabot when bumping gomod (#8410)
  • CI: Add dependency label to github actions update (#8845)
  • CI: Switch cloudbuild.yaml to e2 machine type (#8428)
  • CI: verifier: change back to pull_request_target to make it work again (#8637)
  • ClusterCacheTracker: ClusterCacheTracker: improve error when workload cluster is not reachable (#8801)
  • ClusterCacheTracker: Deprecate DefaultIndex usage and remove where not needed (#8855)
  • ClusterCacheTracker: Use ClusterCacheTracker consistently (instead of NewClusterClient) (#8744)
  • ClusterCacheTracker: Use rest config from ClusterCacheTracker consistently (#8894)
  • ClusterClass: cluster/topology: use cached Cluster get in Reconcile (#8936)
  • ClusterClass: cluster/topology: use cached MD list in get current state (#8922)
  • ClusterClass: deprecate rolloutAfter in cluster topology (#8324)
  • ClusterClass: upgrading control plane should only be blocked if MD are upgrading (not just rolling out) (#8658)
  • Core: Cache unstructured in Cluster, MD and MS controller (#8916)
  • Core: Remo...
Read more

v1.5.0-beta.0

27 Jun 18:19
v1.5.0-beta.0
2b0dd2e
Compare
Choose a tag to compare
v1.5.0-beta.0 Pre-release
Pre-release

🚨 This is a beta release. Use it only for testing purposes. If you find any bugs, file an issue.

Highlights

Some of the hightlights in this release are:

  • MS preflight checks to improve cluster stability (behind feature gate).
  • Support for concurrent MachineDeployment upgrades in classy clusters.
  • Support for add-on providers in clusterctl.
  • Performance improvements when using CAPI at scale, new dev-tools and a new in-memory infrastructure provider for scale testing.

⚠️ Deprecation warning

The API version v1alpha3 is no longer served in this release. API version v1alpha4 is deprecated and will be removed in v1.6.

Cluster API v1.4 compared to v1.5

See the Cluster-API book for an overview over relevant changes between Cluster API v1.4 and v1.5 for maintainers of providers and consumers of our Go API.

More details about the release

⚠️ BETA RELEASE NOTES ⚠️

👌 Kubernetes version support

  • Management Cluster: v1.24.x -> v1.27.x
  • Workload Cluster: v1.22.x -> v1.27.x

Changes since v1.4.0

📈 Overview

  • 285 new commits merged
  • 4 breaking changes ⚠️
  • 11 feature additions ✨
  • 60 bugs fixed 🐛

⚠️ Breaking Changes

  • CAPD: Use k8s v1.27.0 in quickstart docs and CAPD (#8518)
  • clusterctl: Bump to CR v0.15.0 (#8007)
  • clusterctl: Follow XDG Directory standard for config/data/... files (#6913)
  • clusterctl: Stop serving v1alpha3 API types (#8549)

✨ New Features

  • CAPBK: Use caching read for bootstrap config owner (#8867)
  • ClusterClass: add support or concurrent MD upgrades in classy clusters (#8432)
  • Devtools: hack/observability: Add Parca, Bump observability tools, Add Grafana scale dashboard (#8754)
  • IPAM: Implements Getter interface for IPAddressClaim object (#8374)
  • KCP/Core/CAPD: Add flags for configuring rate limits (#8579)
  • MachineSet: MS preflight checks to improve cluster stability (#8595)
  • clusterctl: Add in memory provider (#8799)
  • clusterctl: Add support for add-on providers in clusterctl (#8472)
  • clusterctl: feat: accept resource mutators in Move operation (#7966)
  • e2e: ci: collect debug information about leftover processes (#8734)
  • util: Move mergeMap to util (#8377)

🐛 Bug Fixes

  • API: Ensure ownerReference apiVersions are always up to date (#8256)
  • CAPBK: ignition: start kubeadm after network.target (#8772)
  • CAPBK: set uninitialized taint only on worker nodes (#8358)
  • CAPD: Add kind mapper (#8880)
  • CAPD: CAPD: Implement watch filter (#8789)
  • CAPD: CAPD: change the haproxy entrypoint to prevent getting stopped immediately after start (#8685)
  • CAPD: Delegate CAPD port selection to the container runtime (#8642)
  • CAPD: test/capd: fix kind mapper entry for v1.25.11 (#8914)
  • CAPD: test/e2e fix fail-swap-on=false flag not being part of kind images anymore (#8767)
  • CAPIM: fix cluster deletion in the in-memory API server (#8818)
  • CAPIM: fix inmemory provider docker build (#8822)
  • CAPIM: test/e2e/in-memory: set providerID after VM is provisioned (#8879)
  • CI: Always build Kind images for upgrade tests (#8859)
  • CI: Ensure ALWAYS_BUILD_KIND_IMAGES is defaulted correctly in ci script (#8873)
  • CI: verifier: use pull_request instead of pull_request_target (#8635)
  • ClusterCacheTracker: ClusterCacheTracker: Stop pod caching when checking workload cluster (#8850)
  • ClusterClass: Drop uid from error messages (#8333)
  • ClusterClass: Validate variables in defaulting webhook (#8332)
  • ClusterClass: avoid errors when MHC and upgrade occur together in classy clusters (#8464)
  • ClusterClass: topology controller should avoid unnecessary rollouts during upgrades (#8628)
  • ClusterClass: update TopologyReconciled condition on cluster deletion (#8422)
  • ClusterResourceSet: : Make sure the Kubernetes API Server service already created on remote cluster before applying ClusterResourceSets (#8048)
  • ClusterResourceSet: ClusterResourceSet: continue applying when apply for a single cluster failed (#8611)
  • Dependency: Update kindnetd and kindest/haproxy (#8469)
  • Devtools: Update clean-charts make target for new paths (#8904)
  • Devtools: tilt: set CR logger in tilt-prepare, fix allowed contexts (#8919)
  • IPAM: ipam: fix gateway being required for IPAddress (#8506)
  • KCP: Allow machine rollout if cert reconcile fails (#8711)
  • KCP: Ensure nil-pointer check in KCP syncMachines (#8481)
  • KCP: Prevent KCP to create many private keys for each reconcile (#8617)
  • KCP: enable updates from CloudInit (mostly ubuntu) based KCPs to Ignition (flatcar) based KCPs (#8339)
  • Machine: bug fix to set node interruptible label (#8297)
  • Machine: fix node label propagation (#8427)
  • MachinePool: Add node watcher to MachinePool controller (#8443)
  • MachinePool: Fix MachinePool node taint patching (#8462)
  • MachinePool: MachinePool: always patch owned conditions, fix GetTypedPhase, doc fixes (#8627)
  • MachinePool: Update MachinePool bootstrap dataSecretName when bootstrap config changes (#8667)
  • Testing: Catch failure when fetching component URLs (#8455)
  • Testing: Fix flake in machine phases test (#8370)
  • Testing: Fix flaky wait in CRS test (#8334)
  • Testing: Use CreateAndWait in MP ScaleFromZero test (#8927)
  • Testing: internal/machine-controller fix flakes in phases test (#8576)
  • Testing: machine-controller: fix phase tests race condition in tests on lastUpdated field (#8484)
  • clusterctl: Add soft ownership from clusters to ClusterResourceSetBinding (#8318)
  • clusterctl: Ensure all GitHub releases are fetched when searching provider versions (#8240)
  • clusterctl: Return error on infra cluster and control plane discovery (#8604)
  • clusterctl: Use local kustomize version in create-local-repository.py (#8414)
  • clusterctl: clusterctl: return early if release for latest tag does not exist yet (#8253)
  • clusterctl: handle nil pointer in clusterctl describe (#8724)
  • e2e: Adjust machinepool helper e2e timeout (#8739)
  • e2e: Fix length check in MD helper (#8352)
  • e2e: Ignore cert annotation in rollout test (#8761)
  • e2e: Increase timeout for clusterclass rollout test (#8897)
  • e2e: Increased assertClusterObjects timeout (#8758)
  • e2e: Pin kindest/node images to known good versions in clusterctl upgrade tests (#8860)
  • e2e: Remove non-functioning ginkgo.no-color flag (#8703)
  • e2e: Revert "Add calico as e2e test CNI" (#8575)
  • e2e: test/e2e check for machines being ready after provisioning on Runtime SDK test (#8625)
  • e2e: test/e2e: use topology cluster-template for clusterctl upgrade mgmt cluster (#8311)
  • e2e: test/framework fix docker pod log collector (#8634)

🌱 Others

  • API: Deprecate v1alpha3 and v1alpha4 in CRDs (#8687)
  • CAPBK: replace reflect deepequal in bootstrap kubeadm (#8266)
  • CAPD: Automatically set kubelet args for capd (#8881)
  • CAPD: CAPD: only ignore necessary kubeadm preflight errors (#7911)
  • CAPIM: Add startup timeout to the in memory provider (#8831)
  • CAPIM: Add watch to in-memory server multiplexer (#8851)
  • CAPIM: CAPIM: Enable update for coreDNS and kube-proxy (#8899)
  • CAPIM: Fixups for watch in in-memory apiServer (#8898)
  • CAPIM: Improve etcd management in CAPIM (#8906)
  • CAPIM: add ClusterClass support for in-memory provider (#8807)
  • CAPIM: fix readme for in-memory provider (#8905)
  • CAPIM: test/e2e/in-memory: enable unit tests (#8886)
  • CAPIM: test/e2e/in-memory: improve performance by fixing locking issues (#8895)
  • CAPIM: test/e2e/in-memory: sync in-memory provider ClusterClass with test (#8892)
  • CAPIM: test/infra/inmemory: rename controller files (#8830)
  • CI: Add area/dependency label for dependabot when bumping gomod (#8410)
  • CI: Add dependency label to github actions update (#8845)
  • CI: Switch cloudbuild.yaml to e2 machine type (#8428)
  • CI: verifier: change back to pull_request_target to make it work again (#8637)
  • ClusterCacheTracker: ClusterCacheTracker: improve error when workload cluster is not reachable (#8801)
  • ClusterCacheTracker: Deprecate DefaultIndex usage and remove where not needed (#8855)
  • ClusterCacheTracker: Use ClusterCacheTracker consistently (instead of NewClusterClient) (#8744)
  • ClusterCacheTracker: Use rest config from ClusterCacheTracker consistently (#8894)
  • ClusterClass: cluster/topology: use cached MD list in get current state (#8922)
  • ClusterClass: deprecate rolloutAfter in cluster topology (#8324)
  • ClusterClass: upgrading control plane should only be blocked if MD are upgrading (not just rolling out) (#8658)
  • Core: Cache unstructured in Cluster, MD and MS controller (#8916)
  • Core: Remove unnecessary requeues (#8743)
  • Dependency: Bump EndBug/add-and-commit from 9.1.1 to 9.1.2 (#8584)
  • Dependency: Bump EndBug/add-and-commit from 9.1.2 to 9.1.3 (#8621)
  • Dependency: Bump actions/checkout from 3.3.0 to 3.4.0 (#8321)
  • Dependency: Bump actions/checkout from 3.4.0 to 3.5.0 (#8389)
  • Dependency: Bump actions/checkout from 3.5.0 to 3.5.2 (#8540)
  • Dependency: Bump actions/checkout from 3.5.2 to 3.5.3 (#8837)
  • Dependency: Bump actions/setup-go from 3.5.0 to 4.0.1 (#8664)
  • Dependency: Bump docker/distribution to v2.8.2 (#8645)
  • Dependency: Bump gcb-docker-gcloud from v20230424-910a2a439d to v20230522-312425ae46 (#8770)
  • Dependency: Bump gcb-docker-gcloud image (#8570)
  • Dependency: Bump github.com/go-logr/logr from 1.2.3 to 1.2.4 (#8461)
  • Dependency: Bump github.com/onsi/ginkgo/v2 from 2.10.0 to 2.11.0 (#8891)
  • Dependency: Bump github.com/onsi...
Read more