renovate/lib/manager/kustomize
Andrei Nistor 8184bda9b6
feat(manager/kustomize): support HelmChartInflationGenerator (#12628)
Co-authored-by: Michael Kriese <michael.kriese@visualon.de>
2021-11-17 15:04:26 +00:00
..
__fixtures__ feat(manager/kustomize): support HelmChartInflationGenerator (#12628) 2021-11-17 15:04:26 +00:00
__snapshots__ feat(manager/kustomize): support HelmChartInflationGenerator (#12628) 2021-11-17 15:04:26 +00:00
extract.spec.ts feat(manager/kustomize): support HelmChartInflationGenerator (#12628) 2021-11-17 15:04:26 +00:00
extract.ts feat(manager/kustomize): support HelmChartInflationGenerator (#12628) 2021-11-17 15:04:26 +00:00
index.ts fix(kustomize): don’t pin digests (#8090) 2020-12-19 23:12:11 +01:00
readme.md feat(manager/kustomize): support HelmChartInflationGenerator (#12628) 2021-11-17 15:04:26 +00:00
types.ts feat(manager/kustomize): support HelmChartInflationGenerator (#12628) 2021-11-17 15:04:26 +00:00

This package will manage the following parts of the kustomization.yaml file:

  1. remote resources
  2. image tags
  3. components
  4. helm charts
  5. remote bases (deprecated since kustomize v2.1.0)

How It Works

  1. Renovate will search each repository for any kustomization.yaml files.
  2. Existing dependencies will be extracted from remote bases, image tags & helm charts
  3. Renovate will resolve the dependency's source repository and check for SemVer tags if found.
  4. If an update was found, Renovate will update kustomization.yaml

This manager uses three depTypes to allow a fine-grained control of which dependencies are upgraded:

  • Component
  • Kustomization
  • HelmChart

Limitations

  • Needs to have kind: Kustomization or kind: Component defined
  • Currently this hasn't been tested using HTTPS to fetch the repos
  • The keys for the image tags can be in any order
- name: image/name
  newTag: v0.0.1
# or
- newTag: v0.0.1
  name: image/name
  • Digests can be pinned in newTag or digest:
- name: image/name
  newTag: v0.0.1@sha256:3eeba3e2caa30d2aba0fd78a34c1bbeebaa1b96c7aa3c95ec9bac44163c5ca4f
# without a version, digests are tracked as :latest
- name: image/name
  digest: sha256:3eeba3e2caa30d2aba0fd78a34c1bbeebaa1b96c7aa3c95ec9bac44163c5ca4f
  • The image's repository can be changed with newName:
- name: image/name
  newName: custom-image/name:v0.0.1
- name: image/name
  newName: custom-image/name:v0.0.1@sha256:3eeba3e2caa30d2aba0fd78a34c1bbeebaa1b96c7aa3c95ec9bac44163c5ca4f
- name: image/name
  newName: custom-image/name@sha256:3eeba3e2caa30d2aba0fd78a34c1bbeebaa1b96c7aa3c95ec9bac44163c5ca4f
- name: image/name
  newName: custom-image/name
  newTag: v0.0.1@sha256:3eeba3e2caa30d2aba0fd78a34c1bbeebaa1b96c7aa3c95ec9bac44163c5ca4f
- name: image/name
  newName: custom-image/name
  digest: sha256:3eeba3e2caa30d2aba0fd78a34c1bbeebaa1b96c7aa3c95ec9bac44163c5ca4f
  • Images with values ignored by Kustomize will be skipped to avoid ambiguity:
# bad: skipped because newTag: is ignored when digest: is set
- name: image/name
  newTag: v0.0.1
  digest: sha256:3eeba3e2caa30d2aba0fd78a34c1bbeebaa1b96c7aa3c95ec9bac44163c5ca4f
# good:
- name: image/name
  newTag: v0.0.1@sha256:3eeba3e2caa30d2aba0fd78a34c1bbeebaa1b96c7aa3c95ec9bac44163c5ca4f