diff --git a/teps/0087-custom-tasks-graduation.md b/teps/0087-custom-tasks-graduation.md new file mode 100644 index 000000000..f13fe4245 --- /dev/null +++ b/teps/0087-custom-tasks-graduation.md @@ -0,0 +1,437 @@ +--- +status: proposed +title: Custom Tasks Graduation +creation-date: '2021-09-28' +last-updated: '2021-09-28' +authors: +- '@jerop' +see-also: +- TEP-0002 +--- + +# TEP-0087: Custom Tasks Graduation + + + + + + + + +- [Summary](#summary) +- [Motivation](#motivation) + - [Goals](#goals) + - [Non-Goals](#non-goals) + - [Use Cases](#use-cases) + - [Requirements](#requirements) +- [Proposal](#proposal) + - [Experimental](#experimental) + - [Admission Requirements](#admission-requirements) + - [Admission Process](#admission-process) + - [Stable](#stable) + - [Graduation Requirements](#graduation-requirements) + - [Graduation Process](#graduation-process) + - [Integrated](#integrated) + - [Graduation Requirements](#graduation-requirements-1) + - [Graduation Process](#graduation-process-1) +- [Design Evaluation](#design-evaluation) + - [Simplicity](#simplicity) + - [Reusability](#reusability) + - [Flexibility](#flexibility) +- [Alternatives](#alternatives) + - [Experimental and Stable in One Repository](#experimental-and-stable-in-one-repository) + - [Pros](#pros) + - [Cons](#cons) + - [Experimental to Integrated](#experimental-to-integrated) + - [Pros](#pros-1) + - [Cons](#cons-1) +- [Infrastructure Needed](#infrastructure-needed) +- [References](#references) + + +## Summary + + + +Today, `Custom Tasks` shared by the Tekton community are all *experimental* and we haven't +defined a process to promote them beyond *experimental*. + +As such: +- users can't depend on the `Custom Tasks` because they not *stable* (they can change any time) +- contributors don't have a process to stabilize their `Custom Tasks` or integrate them natively +to the Tekton Pipelines API + +In this TEP, we aim to: +- define the graduation path for `Custom Tasks` from *experimental* to *stable* to *integrated* +- provide infrastructure for *stable* `Custom Tasks` that are officially supported by Tekton + +`Custom Tasks` will have three levels in their graduation path: + +1. *Experimental*: `Custom Tasks` can change any time, [*alpha* API policy][api-policy] applies, as we are iterating on +them. +2. *Stable*: `Custom Tasks` are stable, [*beta* API policy][api-policy] applies, and have been approved in a TEP. +3. *Integrated*: `Custom Tasks`' functionalities are natively supported in Tekton Pipelines API. + +## Motivation + + + +As described in [TEP-0002: Enable Custom Tasks][TEP-0002], we introduced `Custom Tasks` that are defined as CRDs that +are executed using [`Runs`][runs]. These `Custom Tasks` have reconciling controllers that watch for `Runs` referencing +their types and updates their status. `Custom Tasks` enable extensibility in Tekton - users can implement functionality +that's not supported natively in Tekton Pipelines. + +Hitherto, we have implemented several `Custom Tasks` in [Tekton Experimental Repository][experimental-repo]: +- [Common Expression Language Custom Tasks][cel-ct] - provides support for Common Expression Language in Tekton Pipelines +- [Wait Custom Tasks][wait-ct] - enables waiting for some amount of time between `Tasks` +- [Task Looping Custom Tasks][tl-ct] - enables running a `Task` in a loop with varying `Parameter` values +- [Pipelines in Pipelines Custom Tasks][pip-ct] - provide support for composing and executing `Pipelines` in `Pipelines` + +These `Custom Tasks` implementations are all *experimental*. Notwithstanding, they are in use in critical projects, such +as [Kubeflow Pipelines on Tekton][kubeflow]. Providing stability levels and progression for `Custom Tasks` will enable +users to rely on them and empower contributors to safely update them. + +We may decide to promote some `Custom Tasks` to top level such that their functionality is supported natively in the +Tekton Pipelines API. On the other hand, we may decide not to natively support some functionalities provided in some +`Custom Tasks` but we need to provide stability guarantees. Thus, we need to provide an incremental graduation path and +stability levels for `Custom Tasks`. + +### Goals + + + +1. Provide a graduation path for `Custom Tasks` from *experimental* to *stable* and *integrated* +2. Provide infrastructure for *stable* `Custom Tasks` that are officially supported by Tekton + +### Non-Goals + + + +1. Promote `Custom Tasks` feature itself from `alpha` to `beta` - we will address this separately soon +2. Provide CLI support for `Custom Tasks` provided as *stable* integrations - we can explore this later + +### Use Cases + + + +1. As a contributor, I want to promote my `Custom Tasks` from *experimental* to *stable* and, possibly, *integrated* so +I need a process that I can follow with clear requirements for graduation to the next level +2. As a user, I need to use *stable* `Custom Tasks` that I can rely on for critical projects + +### Requirements + + + +- Define graduation requirements and path for `Custom Tasks` from *experimental* to *stable* and *integrated*. +- Provide a catalog of `Custom Tasks` that are *stable* integrations with necessary infrastructure and processes, such +as thorough testing and frequent releases. + + +## Proposal + + + +`Custom Tasks` will have three levels in their graduation path: + +1. *Experimental*: `Custom Tasks` can change any time, [*alpha* API policy][api-policy] applies, as we are iterating on + them. +2. *Stable*: `Custom Tasks` are stable, [*beta* API policy][api-policy] applies, and have been approved in a TEP. +3. *Integrated*: `Custom Tasks`' functionalities are natively supported in Tekton Pipelines API. + +### Experimental + +`Custom Tasks` will start as *experimental* to keep the barrier of sharing integrations low. + +The [*alpha* API policy][api-policy] applies to the *experimental* `Custom Tasks`, meaning their Owners can make any +changes at any time as they iterate on the `Custom Tasks`. + +#### Admission Requirements + +We can consider admitting an *experimental* `Custom Task` *stable* if: + +1. A `Custom Task` is needed to provide a specific functionality to solve common Continuous Delivery use cases +2. At least two contributors are interested in owning a `Custom Task` that provides that functionality + +#### Admission Process + +As described in [Tekton's community process][proposing-projects] for proposing new projects, the `Custom Tasks` Owners +would: + +1. Contributors propose the experimental `Custom Task` in the [Tekton API working group meeting][api-wg] +2. Contributors file an issue in the [Tekton Community repository][community-repo] describing the problem the +`Custom Task` would solve and who will own it +3. When at least two Tekton Pipelines Owners approve the issue, the contributors can add the `Custom Task` to the +[Tekton Experimental repository][experimental-repo] (N/B: other experimental projects need Governing Board approval) + +### Stable + +Tekton will add a new GitHub repository - *custom-tasks* - that would contain high quality `Custom Tasks`. These are +extensions that users can rely on to use functionality that's not provided in the Tekton Pipelines API directly. The +Tekton Pipelines Owners will be the Owners of this repository, and each `Custom Task` will have its own Owners. + +The [*beta* API policy][api-policy] applies to the *stable* `Custom Tasks`, meaning that: +- Any [backwards incompatible][backwards] changes must be introduced in a backwards compatible manner first, with a +deprecation warning in the release notes and migration instructions +- Users will be given at least 9 months to migrate before a backward incompatible change is made +- Backwards incompatible changes have to be approved by more than half of the `Custom Task`'s Owners + +The *custom-tasks* repository will provide the testing infrastructure needed by stable *Custom Tasks*. We will make +monthly releases of `Custom Tasks` that have had changes since their latest release, which we can automate. Moreover, +we will have nightly releases of each `Custom Task` to catch any failures. Each *stable* `Custom Task` will be used in +dogfooding, and will have detailed documentation and multiple examples. + +We can explore a bundling releases of Tekton Pipelines and its latest compatible *stable* `Custom Tasks`, such that +users can install Tekton Pipelines and `Custom Tasks` together. + +#### Graduation Requirements + +We can consider graduating a given *experimental* `Custom Task` to *stable* if it meets the following requirements: + +1. It is thoroughly tested +2. It has nightly releases +3. It is used in dogfooding +4. It provides several examples or samples +5. It has detailed documentation for installation and usage +6. It has received feedback from the community (solicited in working group, mailing list or other channels) + +#### Graduation Process + +The graduation process from *experimental* to *stable* for a given `Custom Task` would be: + +1. Its Owners validate that the *experimental* `Custom Task` meets the above requirements +2. Its Owners open a Tekton Enhancement Proposal (TEP) for the functionality provided by the `Custom Task` with its +motivation (goals, use cases and requirements), proposal (with design details and evaluation), and alternatives +3. Its Owners nominate the `Custom Task` for graduation from *experimental* to *stable* +4. When the Tekton Pipelines Owners have approved the TEP as implementable, the `Custom Task`'s Owners can migrate it to +the *custom-tasks* repository + +### Integrated + +When a given *stable* `Custom Task` is actively used and needed for common Continuous Delivery use cases, we can +consider making it *integrated* - meaning that its functionality is natively supported in the Tekton Pipelines API. +Not all *stable* `Custom Tasks` have to be *integrated*, a *stable* `Custom Task` that improves user experience but +is not really necessary in Tekton Pipelines API can stay as a *stable* `Custom Task` in the long term. + +#### Graduation Requirements + +We can consider graduating a given *stable* `Custom Task` to *integrated* if it meets the following requirements: + +1. Its functionality is critical to common Continuous Delivery use cases +2. It's actively used by the community and in dogfooding + +#### Graduation Process + +The graduation process from *stable* to *integrated* for a given `Custom Task` would be: + +1. Its Owners validate that the *stable* `Custom Task` meets the above requirements +2. Its Owners update the `Custom Task`'s TEP with: + 1. a nomination for graduation from *stable* to *integrated* + 2. a discussion of how its been useful and why it's necessary to natively support the functionality in the + Tekton Pipelines API + 3. proposal and alternatives for its syntax in the Tekton Pipelines API +3. When the Tekton Pipelines Owners have approved the TEP as implementable, the `Custom Task`'s Owners will add its +functionality directly to the Tekton Pipelines API as an *alpha* feature and deprecate the *stable* `Custom Task` +4. When the *alpha* feature is promoted to *beta*, the `Custom Task`'s Owners can remove it from the *custom-tasks* repo + +## Design Evaluation + + + +#### Simplicity + +By providing *stable* `Custom Tasks`, we provide an intermediary stability tier that provides the reliability needed by +users without making unnecessary changes directly in the Tekton Pipelines API. This ensures that the Tekton Pipelines +API has the bare minimum features needed to solve most Continuous Delivery use cases. + +#### Reusability + +By providing *stable* `Custom Tasks`, we enable users to reuse extensions that they can rely on. Moreover, having both +*experimental* and *stable* `Custom Tasks` allows contributors to share reusable `Custom Tasks` across the community. + +#### Flexibility + +The *experimental* and *stable* `Custom Tasks` provide a mechanism to provide functionality that's not directly +available in the Tekton Pipelines API. It empowers users to extend Tekton Pipelines to solve their bespoke Continuous +Delivery use cases. + +The `Custom Tasks` graduation path and process in this TEP gives us flexibility to safely iterate on functionality +provided through the `Custom Tasks` as we make progress through each stage. + +## Alternatives + + + +#### Experimental and Stable in One Repository + +We could have the *experimental* and *stable* `Custom Tasks` in one repository, and indicate their stability levels +by other means (such as documentation). + +###### Pros + +- consolidates `Custom Tasks` in one place, making them more easily discoverable +- simplifies the change needed to migrate from *experimental* to *stable* + +###### Cons + +- reduces the separation between the *experimental* and *stable* `Custom Tasks`, taking more effort to distinguish them +- makes it harder to enforce quality requirements for *stable* `Custom Tasks` (we're considering separating official +resources in Tekton Catalog for this reason) + +#### Experimental to Integrated + +We could remove the *stable* `Custom Tasks` and promote from *experimental* to *integrated* directly. + +###### Pros + +- simplifies the graduation path +- speeds up the graduation process without intermediary stage + +###### Cons + +- removes a way to provide high quality and reliable `Custom Tasks` +- reduces the time to iterate on the functionality provided by `Custom Tasks` before integrating it to Tekton Pipelines + +## Infrastructure Needed + + + +We need a GitHub repository for *stable* `Custom Tasks`. + +## References + + + +- [TEP-0002: Enable Custom Tasks][TEP-0002] +- [TEP-0056: Pipelines in Pipelines][TEP-0056] +- [Pipelines in Pipelines Custom Tasks][pip-ct] +- [Common Expression Language Custom Tasks][cel-ct] +- [Wait Custom Tasks][wait-ct] +- [Task Looping Custom Tasks][tl-ct] +- [Kubeflow Pipelines on Tekton][kubeflow] +- [Tekton Pipelines API Policy][api-policy] + + + +[experimental-repo]: https://github.com/tektoncd/experimental +[community-repo]: https://github.com/tektoncd/community +[api-wg]: https://github.com/tektoncd/community/blob/main/working-groups.md#api +[TEP-0002]: 0002-custom-tasks.md +[TEP-0056]: 0056-pipelines-in-pipelines.md +[pip-ct]: https://github.com/tektoncd/experimental/tree/main/pipelines-in-pipelines +[cel-ct]: https://github.com/tektoncd/experimental/tree/main/cel +[wait-ct]: https://github.com/tektoncd/experimental/tree/main/wait-task +[tl-ct]: https://github.com/tektoncd/experimental/tree/main/task-loops +[kubeflow]: https://developer.ibm.com/blogs/kubeflow-pipelines-and-tekton-advances-data-workloads +[proposing-projects]: https://github.com/tektoncd/community/blob/main/process.md#proposing-projects +[runs]: https://github.com/tektoncd/pipeline/blob/main/docs/runs.md +[api-policy]: https://github.com/tektoncd/pipeline/blob/main/api_compatibility_policy.md#alpha-beta-and-ga +[backwards]: https://github.com/tektoncd/pipeline/blob/main/api_compatibility_policy.md#backwards-incompatible-changes diff --git a/teps/README.md b/teps/README.md index b74cfc6fe..0ff3f4d5d 100644 --- a/teps/README.md +++ b/teps/README.md @@ -223,3 +223,4 @@ This is the complete list of Tekton teps: |[TEP-0073](0073-simplify-metrics.md) | Simplify metrics | proposed | 2021-06-23 | |[TEP-0080](0080-support-domainscoped-parameterresult-names.md) | Support domain-scoped parameter/result names | implemented | 2021-08-19 | |[TEP-0084](0084-endtoend-provenance-collection.md) | end-to-end provenance collection | proposed | 2021-09-16 | +|[TEP-0087](0087-custom-tasks-graduation.md) | Custom Tasks Graduation | proposed | 2021-09-28 |