We use analytics and cookies to understand site traffic. Information about your use of our site is shared with Google for that purpose. Learn more.
Knative Migration-To-Core Process
This document provides a maturity model for projects in the Knative community. This includes projects in knative-sandbox (broader community) or as well as projects in other GitHub organizations which wish to participate in the community process. It also defines a process for migrating community projects into the Knative core, if appropriate. Note that projects may not map 1:1 with repos, and projects may even be hierarchical (for example, the “eventing” project includes “eventing API”, “eventing delivery” and “eventing sources”, each of which has artifacts in multiple repositories).
Note that this document intentionally refers to the process of selecting implemented interfaces from sandbox which should be part of core as “migration-to-core” rather than “incubation” or “promotion” – while it may be personally satisfying to have a component be part of the core, components which are not in the core may be equally valuable and production-worthy.
Maturity phases
Initiating
In the initiating phase, a project is starting up, and may have minimal additional artifacts around the code itself. The minimum bar for an initiating project in the knative-sandbox org is:
- Adopted the CLA bot and OWNERS file / Tide merge process, to ensure IP ownership
- Adopt the Knative Code of Conduct
- Sponsored by a WG lead
- Have a README.md that describes the repo(s)
Projects which do not declare otherwise are assumed to be in the “Initiating” phase, regardless of release process, users, etc.
This phase is suitable for:
- Experiments
- Proofs-of-Concept
- Examples
- Templates
- etc
Note that Initiating projects do not need to be hosted in knative-sandbox, and can be hosted under either individual accounts or in other orgs. For projects in knative-sandbox, review requirements and cadence are at the discretion of the sponsoring WG lead.
Usable
A usable project has reached the point where it is releasing executable artifacts which are in use by at least two end users (preferably different companies, rather than installations within the same company). Additionally, a usable project meets certain other criteria (defined below) which allows the Knative community to have confidence in the project and willingness to invest further.
Additional requirements beyond “initiating”:
- A published release schedule, with at least two successful minor releases.
- At least two end users (preferably different companies) who are consuming the release artifacts. Commercial products with production usage count towards this target. This can be documented in something like an ADOPTERS.md file.
- Unit test automation meeting the Knative standards with respect to coverage and flakiness / test failures.
- Provide at least monthly progress reports at the appropriate WG(s). WGs should roll these reports up into their TOC reports.
- User-facing documentation for the following areas: install, usage
- Contributor facing documentation for: development setup
- Ongoing contributions from multiple contributors and management of user issues, etc.
Usable projects which meet the criteria for core (i.e. developer-facing abstractions with wide utility, beta+ APIs) may apply to the TOC and SC for migration to core, but approval is more likely for projects in the “Stable” category.
Stable
A stable project has graduated beyond the bar in “usable” and is widely-adopted with a stable API and well-understood operational characteristics. This would be similar to a “GA” level of support for a commercial product in terms of maturity.
Additional requirements beyond “usable”:
- A stable v1 API following documented release and deprecation principles (ref core Knative principles). Depending on the project, the API may include library methods, Kubernetes CRDs, network data-plane protocols, container contracts, or some combination. The API contract should be explicitly documented in the repo.
- Identified and named set of project leads managing both development roadmap and overall project success.
- Release schedule aligned with the core Knative release schedule.
- At least 5 end-users consuming the release artifacts in installations of
sufficient quality and scope.
- Commercial products with production usage count towards this target, though there must be multiple commercial products or direct upstream users to quality (i.e. 5 users of a single-vendor product and no other users may be “usable”, but would not be accepted for “stable”).
- Upgrade and e2e test automation.
- (Reports as for usable projects)
- User-facing documentation for debugging.
- Contributor facing documentation for issue triage and project engagement.
- Members of the development team is varied. Ideally from multiple organizations.
- There must be a “stable” set of installation-time dependencies for the project. (i.e. for Eventing, the “Kafka” channel implementation could be counted as a “stable” dependency)
Projects are generally encouraged to reach stable maturity before considering migration to core.
Sunsetting
At any time, a project may move into the “sunsetting” phase. This is a declaration that the project will no longer managed or maintained. For a project which is currently in the “stable” phase, there should be a clear commitment to support the project with bug and security fixes as applicable based on the Knative release principles (4 versions of Knative).
Migration to Core
A stable project may apply to the SC and TOC to be admitted to the Knative core. Not all stable projects are suitable for “core”; this is a judgement as to the degree to which the project should be considered a part of a “expected developer experience” across Knative installations. Projects may be graded on the following criteria (to be updated based on experience):
- Presence of developer-facing or operator-facing capability abstractions
- Independent usability / abstraction interfaces – how much does this require / complement existing Knative components (modular at the top)
- Ability to abstract over multiple underlying implementations (pluggable on the bottom)
- Number / diversity of installations and adoption as a fraction of total Knative usage
- Quality of technical implementation – ability to scale and reach