renovate/lib/modules/manager/tekton
2022-12-20 06:38:36 +01:00
..
__fixtures__ feat(manager/tekton): finally tasks and pipelinespec (#19409) 2022-12-20 06:38:36 +01:00
__snapshots__ feat(manager/tekton): finally tasks and pipelinespec (#19409) 2022-12-20 06:38:36 +01:00
extract.spec.ts feat(manager/tekton): finally tasks and pipelinespec (#19409) 2022-12-20 06:38:36 +01:00
extract.ts feat(manager/tekton): finally tasks and pipelinespec (#19409) 2022-12-20 06:38:36 +01:00
index.ts feat: Add tekton-bundle support (#17289) 2022-09-07 05:21:53 +00:00
readme.md feat(tekton): support official bundle resolver (#19040) 2022-11-30 10:00:40 +00:00
types.ts feat(manager/tekton): finally tasks and pipelinespec (#19409) 2022-12-20 06:38:36 +01:00

Tekton is an open-source cloud-native Continuous Integration and Continuous Delivery/Deployment solution.

Tekton uses Tasks to capture specific commands to be executed, and Pipelines to combine different Tasks, to achieve a goal, like building a container image. Tasks and Pipelines are defined as Kubernetes custom resources.

The Tekton documentation is a great resource to learn more about the overall concepts and how to start using it.

Distributing Tasks and Pipeline definitions

There are different ways to distribute Task and Pipeline definitions. They can be created directly as a Kubernetes resource with standard tools like kubectl. Tasks and Pipeline definitions can also live outside the Kubernetes cluster and get fetched by Tekton when needed, this approach relies on Tekton resource references rather than the resource definition. The tekton manager focuses on providing updates to Tekton resource references.

Right now, Renovate's Tekton manager only supports references that are Bundles. Read the Tekton Pipeline remote resolution docs for the different kinds of Tekton references and their corresponding resolvers.

Using a Tekton Bundle reference

There are three ways to use a Tekton Bundle reference:

  1. Via the Tekton Bundles Resolver
  2. Via the tektoncd/resolution project
  3. Via the taskRun.spec.taskRef.bundle and the pipelineRun.spec.pipelineRef.bundle attributes

Renovate's Tekton manager supports all the methods listed above.

Set your own fileMatch pattern

The tekton manager does not have a default fileMatch pattern. This means it won't match any files until you set a fileMatch pattern. This is to avoid problems with unrelated YAML files since there is no well-established file name pattern for Tekton resources. As an example, the following config matches all the YAML files in a repository:

{
  "tekton": {
    "fileMatch": ["\\.yaml$", "\\.yml$"]
  }
}

See our versioning documentation for details on the existing versioning rules and possible alterations.