Skip to content

kustomize/v5.0.0

Compare
Choose a tag to compare
@KnVerey KnVerey released this 02 Feb 17:19
· 592 commits to master since this release
738ca56

πŸŽ‰The Kustomize team is so excited to release version 5.0! πŸŽ‰

This release is packed with exciting features and improvements. The full list is below, but here are some of our favorites:

  • kustomize localize: a brand new alpha command that localizes remote content. You’ll be able to build the localized kustomization without network access and performance delays! Please give it a try and let us know what you think in #4996. See more details in its entry under Features below.
  • support for four new Helm fields, by popular request: additionalValuesFiles, skipTests, apiVersions and nameTemplate
  • A new sortOptions kustomization field gives you fine-grained control over resource ordering in build output
  • Significant performance improvements!

A HUGE thank you to everyone who contributed to this release! πŸ™‡β€β™€οΈ

Breaking changes

  • #4930: Remove deprecated alpha cfg and fn commands: kustomize fn sink, kustomize fn source, kustomize fn wrap, kustomize fn xargs, kustomize cfg annotate, kustomize cfg create-setter, kustomize cfg delete-setter, kustomize cfg delete-substitution, kustomize cfg create-substitution, kustomize cfg fmt, kustomize cfg init, kustomize cfg list-setters, kustomize cfg merge, kustomize cfg merge3, kustomize cfg set.
  • #4983, #4954, #4922, #4900, #4885: Warning: We made major improvements to the maintainability of the URL-parsing code for remote URLs, fixing several bugs in the process. We have test coverage for backwards-compatibility with all documented supported URLs, but if you experience a regression with a remote URL, please file an issue.
    • #4985: If you previously included .git in an AWS or Azure URL, we will no longer automatically remove that suffix. You may need to add an extra / to replace the .git for the URL to properly resolve.
    • #4954: Drop support for using gh: as a host (e.g. gh:kubernetes-sigs/kustomize). We were unable to find any usage of or basis for this and believe it may have been targeting a custom gitconfig shorthand syntax.
  • #4911: Drop support for a very old, legacy style of patches. patches used to be allowed to be used as an alias for patchesStrategicMerge in kustomize v3. You now have to use patchesStrategicMerge explicitly, or update to the new syntax supported by patches. See examples in the PR description of #4911.
  • #4731: Remove a potential build-time side-effect in ConfigMapGenerator and SecretGenerator, which loaded values from the local environment under some circumstances, breaking kustomize build's side-effect-free promise. While this behavior was never intended, we deprecated it and are announcing it as a breaking change since it existed for a long time. See also the Eschewed Features documentation.
  • #4929: Duplicate fields in Kustomization files will now result in an error instead of them silently being ignored in an undefined order. NOTE: This was reverted in release v5.0.1.

Deprecations

  • #4723, #4923: We are deprecating the following kustomization fields. These fields will never be removed from the kustomize.config.k8s.io/v1beta1 Kustomization API, but they will not be included in the kustomize.config.k8s.io/v1 Kustomization API. When Kustomization v1 is available, we will announce the deprecation of the v1beta1 version. There will be at least two releases between deprecation and removal of Kustomization v1beta1 support from the kustomize CLI, and removal itself will happen in a future major version bump.
    • patchesStrategicMerge. Please use patches instead
    • patchesJson6902. Please use patches instead
    • vars. Please use replacements instead.
    • imageTags. This is an alias for images, please switch to images.
  • #5000: The --short flag for kustomize version is deprecated.
  • #4954: Deprecate RepoSpec git:: prefix, which is invalid. Kustomize currently strips it, but will stop doing so in a future release.

Features

  • #4652: New kustomize localize command to download any remote content from your kustomization directory and create a new, localized copy with file paths to the local content replacing the URLs. Please leave your feedback here: #4996
  • #4019: New kustomization field sortOptions, that lets you configure the sort order of resources.
  • #4733: kustomize edit fix converts patchesStrategicMerge to patches
  • #4947: Allow fieldspecs (used in advanced transformer configuration) to start with a slash.
  • #5000: Output of kustomize version is improved. YAML and JSON formats are now available via the new --output flag.
  • #4986: Repospec: support ssh urls with ssh certificates
  • #4926, #4808: Support for more helm template args in the helmCharts field: additionalValuesFiles, skipTests, apiVersions and nameTemplate.
    #4886: Wildcard support for creation in ReplacementTransformer

Bug Fixes/performance improvements

  • #4863: Fix RepoSpec query extraction
  • #4985: Remove forced .git suffix in RepoSpec
    • Arbitrary git servers that do not follow the .git directory naming convention can now be used with Kustomize.
    • The .git suffix no longer incorrectly appears in origin annotations in some cases.
  • #4791, #4944, #4809: Significant performance improvements from refactoring metadata handling in the api and kyaml modules
  • #4789: Replacements now throw errors on invalid targets
  • #4890: Fix null value handling when applying strategic merge patches. A null in the patch is a deletion directive, but a null in the target should be preserved.
  • #4654: The working directory of exec KRM-style functions is now the kustomization root that called it. This fixes a bug where KRM exec function executables were looked up incorrectly in base/overlay contexts.
  • #4751, #4805: When using labels.includeTemplates, create template/metadata if not present.
  • #4834: Respect options.disableNameSuffixHash in configmap and secret generator in overlays
  • #4919: Allow overriding of name suffix transformer default configuration
  • #4895: Name references to local-only objects are now correctly resolved before the objects are removed from the set to be printed.

Dependencies

  • #4877: Update minimum Go version to Go 1.19
  • #4830: Update kyaml's dependency swag to v0.22.3
  • #4960: Update sigs.k8s.io/yaml to v1.3.0
  • #4965: Bump k8s.io/kube-openapi to remove archived dependency
  • #4889: All module net and text dependent package CVE-2022-41717 and CVE-2022-32149 vulnerabilities
  • #4970: Replace github/pkg/errors with sigs.k8s.io/kustomize/kyaml/errors