Request for changes
Guide to proposing a new or a change to an existing pattern in the codebase or development workflows.
Last updated
Guide to proposing a new or a change to an existing pattern in the codebase or development workflows.
Last updated
Engineering teams, especially at scale, require guidelines and patterns to be effective, transparent and enable adoption.
This guide aims to achieve the following:
Provide a Single Source of Truth (SSOT) to track all process changes, so that it's easy for stakeholders to understand decisions
Create a straightforward format for the team to make, discuss and implement decisions regarding process changes
Ensure that there is a DRI (Directly Responsible Individual) so that proposals don't go stale
Create an issue using the provided templates and include a reference implementation
Requests not using a template can be automatically rejected
Share the RFC issue across shared mediums
Relevant engineering meeting
Engineering channel (slack, teams, ect)
Connect with relevant stakeholders (i.e. team leads)
Give the stakeholders time to review the proposal and provide comments about the proposal
If there is a strong consensus towards a decision
Connect with Engineering Manager to groom and include the issue in a relevant timeline
Implement the process change using
Announce process change across appropriate mediums
If the decision is not to proceed, the issue should updated with the reasons for disagreement and closed
When an RFC introduces a new pattern the RFC describes high-level design decisions about how developers should implement the pattern in the codebase.
In practice, implementing these patterns can uncover technical constraints and low-level design decisions that can profoundly change the high-level guidelines in the RFC.
Slightly different understandings of the proposed changes can be more easily understood when the stakeholders look concrete examples.
A reference implementation should satisfy the following conditions:
Provide an example in a real-world situation by using the pattern suggested in the RFC to implement a reference solution for an existing feature.
Provide metrics that demonstrate performance or productivity improvements.
As the RFC progresses, it is recommended that the reference implementation also progresses with it. Ideally, upon acceptance of an RFC, the reference implementation should be capable of being merged as the initial step towards implementing the RFC in its entirety.
There are situations where creating a reference implementation may not be appropriate because the proposal does not involve altering code practices or patterns. In such cases, it is advisable to substitute the reference implementation with an alternative exploration of the specifics, such as a cost-benefit analysis, sample documentation, ect.