"To think, you have to write. If you're thinking without writing, you only think you're thinking". Leslie Lamport
An RFC - Request For Comments - is a document issued mainly to recommend changes to the language and standard libraries. The RFC process aims to provide a consistent and controlled path for changes to enter the project, ensuring that all stakeholders can review and approve them before they are implemented.
You need to follow this process if you intend to make a significant change to the system or changes to the user experience. What constitutes a "significant" change is evolving based on community feedback, but may include the following:
- Semantics or syntax changes, other than bugfixes (e.g. introducing a new Flytekit language feature)
- Core-Language updates (e.g. FlyteIdl changes that introduce a new wire-format)
- Documentation restructuring
- Service-to-Service changes (e.g. new gRPC APIs)
- Breaking changes
- Governance changes
Changes not requiring RFCs include:
- Documentation rephrasing or reorganizing
- Addition of images, tables, etc. to supplement documentation
- Updates to code samples, links, examples, etc.
- Bug fixes that do not introduce changes listed above (use your judgement).
NOTE: new feature implementation will almost certainly require an RFC; PRs attempting to do so will not be approved without a merged RFC.
Some good practices when starting an RFC include:
- Gathering feedback from team or community members first, to confirm that the changes will indeed be useful
- Starting a Discussion at the RFC Incubator to gauge interest. Once you have received positive feedback, especially from Maintainers or Steering Committee members, please proceed to:
- Discussing the topic on the #contribute Slack channel
- Adding the topic to the Contributor's meeting agenda to make sure it alligns with roadmap
- Taking the time to produce a well-written, well-thought-of document by using the template located here.
The Flyte repo on GitHub has an RFC folder with 3 directories:
-
Core language: proposals to
FlyteIdl
that change the wire-format in any way are considered significant changes that require revision and approval.Reviewers: At least one of Flyte maintainers and one of Technical Steering Committee.
-
General System: Changes to other repos that introduce signficant change of behavior or user-impacting features.
Reviewers: At least one of Flyte maintainers and one of Technical Steering Committee.
-
CI-CD: Significant changes to CI-CD System that have impact across different repositories.
Reviewer: At least one of Flyte maintainers.
- Fork the flyte repository.
- Copy
rfc/RFC-0000-Template.md
torfc/<category>/0000-my-feature.md
(where "my-feature" is descriptive). Don't assign an RFC number yet; this is going to be the PR number and we'll rename the file accordingly if the RFC is accepted. - Fill in the RFC. Put care into the details.
- Submit a pull request. As a pull request the RFC will receive design feedback from the larger community, and the author should be prepared to revise it in response.
- Now that your RFC has an open pull request, use the pull request number (e.g.
123
fromhttps://github.com/flyteorg/flyte/pull/123
) to update your 0000- prefix to that number.
Once a pull request is opened, the RFC is now in development and the following will happen:
- It will be introduced in a future Contributor's meetup, happenning every other week, except othwerwise informed.
- The proposal will be discussed as much as possible in the RFC pull request directly. Any outside discussion will be summarized in the comment thread.
- When deemed "ready", a maintainer or TSC member will propose a "motion for Final Comment Period (FCP)" along with a disposition of the outcome (merge, close, or postpone). This step is taken when enough discussions of the tradeoffs have taken place and the community is in a position to make a decision.
- The proposal enters FCP unless there's any objection (lazy consensus).
- The Final Comment Period will last 7 days. If there's no objection, the FCP can close early.
- If no substantial new arguments or ideas are raised, the FCP will follow the outcome decided.
- The RFC author could also withdraw the proposal if they decide to accept a competing proposal as a better alternative or if they deem the original idea as not applicable anymore.
A proposal is considered Accepted when it has:
- Completed the FCP with no significant objections
- Received an approval vote from a supermajority (2/3) of the Technical Steering Comittee's members
RFCs for vital features may need to be implemented immediately, whereas other RFCs may need to wait for the right developer to be available.
The author of an RFC may not always be the one to implement it, but if they do, they are welcome to submit an implementation for review after the RFC has been accepted.
Rejected RFCs may be labelled as "postponed". This means the PR has been closed without implementation, because either:
- the proposed change will need to wait for prerequisite features,
- the business model may not be presently able to support it,
- or other more urgent changes may need to be implemented first.
Although "postponed" RFCs have already gone through the approval process, it is always recommended that they be reviewed again prior to implementation, to make sure the existing ecosystem will still benefit from the change.
Alternatively, if an RFC is not likely to be implemented, it should be labelled as "rejected" and permanently closed.
Any contribution to FlyteOrg repos will be licensed with Apache-2.0 license without any additional terms or conditions.