Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Problem Statement] TEP-0096: Pipelines V1 Release #567

Merged
merged 1 commit into from
Dec 9, 2021
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
141 changes: 141 additions & 0 deletions teps/0096-pipelines-v1-api.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,141 @@
---
status: proposed
title: Pipelines V1 API
creation-date: '2021-11-29'
last-updated: '2021-12-07'
authors:
- '@lbernick'
- '@jerop'
- '@bobcatfish'
- '@vdemeester'
see-also:
- TEP-0033
---

# TEP-0096: Pipelines V1 API

<!-- toc -->
- [Summary](#summary)
- [Motivation](#motivation)
- [Goals](#goals)
- [Non-Goals](#non-goals)
- [Background](#background)
- [Proposal](#proposal)
- [V1 Stability and Deprecation Policy](#v1-stability-and-deprecation-policy)
- [API Definition](#api-definition)
- [Use Cases](#use-cases)
- [References](#references)
<!-- /toc -->

## Summary

Today, Tekton provides a Beta API and a deprecated Alpha API.
This TEP proposes a path to releasing Tekton Pipelines V1 to provide a stable API that users can rely on.
This TEP defines the Pipelines V1 API and stability policy,
the use cases we would like to support for Pipelines V1, and the features needed to support these use cases.

## Motivation

To become the industry standard, cloud-native CI/CD platform,
Tekton must provide users with a stable API they can rely on.
New users may be waiting for V1 stability before using Tekton as their CI/CD platform in production,
and existing users will benefit from stability guarantees as well.

### Goals

- Define stability policy for Pipelines V1.
- Define supported and unsupported use cases for Pipelines V1.
- Define criteria for a feature to be "required" or "optional" for Pipelines V1.
- Define what updates, if any, are needed to the [Pipelines API definition](https://github.com/tektoncd/pipeline/blob/main/api_compatibility_policy.md#what-is-the-api),
the feature gates [TEP-0033](./0033-tekton-feature-gates.md), and release tooling before V1 release.

### Non Goals

- Define the stability or V1 plans of other Tekton project.
- Discussion of software versioning. This TEP discusses what is needed to release a v1 (stable) API;
we expect to release a 1.0 software version shortly after.

## Background

Tekton currently uses Kubernetes' [API versioning guidelines](https://kubernetes.io/docs/reference/using-api/api-overview/#api-versioning)
to define API stability levels, as described in the [compatibility policy](https://github.com/tektoncd/pipeline/blob/main/api_compatibility_policy.md#alpha-beta-and-ga).

Tekton API components may contain features at a lower level of stability, gated behind feature flags,
as described in [TEP-0033: Tekton Feature Gates](./0033-tekton-feature-gates.md).

Tekton follows Kubernetes' [deprecation policy](https://kubernetes.io/docs/reference/using-api/deprecation-policy/).
However, while Kubernetes defines stability periods in terms of months or releases, whichever is longer,
Tekton defines stability periods only in terms of months.
This policy states that API versions cannot be considered deprecated until they are
replaced by a version that is at least as stable (for example, v1beta1 can be considered deprecated when v1 is released).
A deprecated API version must continue to be supported for a length of time based on the following chart.

| API Version | Kubernetes Deprecation Policy | Tekton Deprecation Policy |
|:----------- |:----------------------------- |:------------------------- |
| Alpha | 0 releases | 0 months |
| Beta | 9 months or 3 releases | 9 months |

## Proposal

### V1 Stability and Deprecation Policy

Tekton will continue to follow the Kubernetes [API versioning guidelines](https://kubernetes.io/docs/reference/using-api/api-overview/#api-versioning) and [deprecation policy](https://kubernetes.io/docs/reference/using-api/deprecation-policy/).

Users will have at least 12 months to upgrade to backwards incompatible changes
to a stable API version, meaning that a previous stable API version
must be supported for 12 months from when a new stable API version is created. Backwards incompatible API changes
must be accompanied by deprecation warnings and migration instructions from the previous version.

| API Version | Kubernetes Deprecation Policy | Tekton Deprecation Policy |
|:----------- |:----------------------------- |:------------------------- |
| Alpha | 0 releases | 0 months |
| Beta | 9 months or 3 releases | 9 months |
| V1 | 12 months or 3 releases | 12 months |

No changes are proposed to [TEP-0033: Tekton Feature Gates](https://github.com/tektoncd/community/blob/main/teps/0033-tekton-feature-gates.md),
meaning that features gated behind flags will follow their respective stability policies.
For example, a flag-gated alpha feature may be removed at any time without incrementing the CRD version,
even if it is part of a CRD that is considered stable.

#### Examples
##### Removing an API field from a V1 CRD
Unless the field is controlled by a feature gate at an alpha or beta level of stability, this is a backwards-incompatible change.
Removing the field would require incrementing the API group to v2.
We could choose to release this change as part of a v2alpha1 or v2beta1 API before creating a v2 API.
v1 would not be considered deprecated until v2 is released, and would continue
to be supported for 12 months after that point.

##### Adding an optional API field to a V1 CRD
Additive changes are backwards compatible and don't require incrementing the API version.
As described in [TEP-0033: Tekton Feature Gates](https://github.com/tektoncd/community/blob/main/teps/0033-tekton-feature-gates.md),
this field would be added as an alpha field to the CRD and gated behind the "enable-api-fields" flag.
It may then progress to beta and eventually to stable.

##### Removing a flag-gated field or feature from a V1 CRD
An alpha or beta feature that is flag-gated and part of a v1 CRD may be
removed without incrementing the API version.

##### Promoting a behavior flag
Changing the default behavior of Pipelines, including by promoting a behavior feature flag to opt-out, is a backwards incompatible change.

However, as described in the [behavior flags example](https://github.com/tektoncd/community/blob/main/teps/0033-tekton-feature-gates.md#promoting-behavior-flags)
of TEP-0033: Feature Gates, Tekton's policy allows a behavior change to be updated from opt-in to opt-out without updating the API version.
A behavior can't be changed from opt-in to opt-out until 9 months after it is introduced to a beta API or 12 months after it is introduced to a stable API.
This is different from Kubernetes' policy, which would require creating a new API version to change a feature from opt-in to opt-out.

### API Definition

## Use Cases

### V1 Supported Use Cases

### V1 Unsupported Use Cases

## References

- [Doc: Beta plan and policy](https://docs.google.com/document/d/1H8I2Rk4kLdQaR4mV0A71Qbk-1FxXFrmvisEAjLKT6H0)
- [Issue: Towards V1 API](https://github.com/tektoncd/pipeline/issues/3548)
- [Tekton Pipelines API Compatibility Policy](https://github.com/tektoncd/pipeline/blob/main/api_compatibility_policy.md#alpha-beta-and-ga)
- [Kubernetes API Versioning](https://kubernetes.io/docs/reference/using-api/api-overview/#api-versioning)
- [Kubernetes Deprecation Policy](https://kubernetes.io/docs/reference/using-api/deprecation-policy/)
- [TEP-0033: Tekton Feature Gates](https://github.com/tektoncd/community/blob/main/teps/0033-tekton-feature-gates.md)
1 change: 1 addition & 0 deletions teps/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -231,3 +231,4 @@ This is the complete list of Tekton teps:
|[TEP-0088](0088-result-summaries.md) | Tekton Results - Record Summaries | proposed | 2021-10-01 |
|[TEP-0090](0090-matrix.md) | Matrix | proposed | 2021-11-08 |
|[TEP-0094](0094-configuring-resources-at-runtime.md) | Configuring Resources at Runtime | proposed | 2021-11-08 |
|[TEP-0096](0096-pipelines-v1-api.md) | Pipelines V1 API | proposed | 2021-12-07 |