Chrome ships across multiple channels which are built from different release branches. In general, changes should first land on trunk, be shipped and verified in a canary release, and then promoted to our Dev, Beta, and Stable channels overtime. However, due to many reasons and scenarios, it’s possible that changes may miss branch date and require a merge post branch.
Merge: any change that is cherry picked from trunk to a release branch.
Please read overview of Chrome Release Cycle to understand in detail how the Chrome release cycle works and understand key release concepts and terminology. Please read Defining Release Blockers to understand how issues/bugs are categorized as release blocking. List of schedule and release owners can be found at Chrome Calendar (Googlers only, opening to all in the near future).
This section will discuss when and what type of bugs can be merged based on criticality of the issue. Please note that the scrutiny of merges gets higher as we get closer to the stable launch date. Merges post stable-rollout have a higher bar than merges prior to Stable.
Phase 1: First Two Weeks After Branch (two weeks before beta promotion)
There are bugs and polish fixes that may not necessarily be considered critical but help with the overall quality of the product. There are also scenarios where dependent CL’s are missed by hours or days. To accommodate these scenarios, merges will be considered for all polish bugs, regressions, and release blocking bugs for the first two weeks after branch point. Please note that merges will not be accepted for implementing or enabling brand new features or functionality. Features should already be complete. Merges will be reviewed manually and automatically, depending on the type of change.
GRD file changes are allowed only during this phase. If you have a critical string change needed after this phase, please reach out to release owner or Chrome TPMs.
Phase 2: First Four Weeks of Beta Rollout
During the first four weeks of Beta, merges should only be requested if:
Security bugs should be consulted with firstname.lastname@example.org to determine criticality. If your issue does not meet the above criteria but you would still like to consider this merge, please reach out to release owner or TPMs with a detailed justification.
Phase 3: Last Two Weeks of Beta and Post Stable
During the last 2 weeks of Beta and after stable promotion, merges should only be requested for critical, release blocking issues where the fix is low complexity.
Security bugs should be consulted with chrome-security@ to determine criticality.
This table below provides key dates and phases as an example, for M61 release.
|Feature Freeze||June 23rd, 2017|
|Branch Date||July 20th, 2017|
|Branch Stabilization Period||July 20th to August 3rd, 2017|
|Merge Reviews Phase 1||July 20th to August 3rd, 2017|
|Beta Rollout||August 3rd to September 12th 2017|
|Merge Reviews Phase 2||August 3rd to August 31st 2017|
|Merge Reviews Phase 3||August 31st 2017 and post Stable release|
|Stable Release||September 6th, 2017 + rollout schedule|
Before requesting a merge, please ensure following conditions are met:
If the merge review requirements are met (listed in section above) and your change fits one of the timelines above, please go ahead and apply the Merge-Request-[Milestone Number] label on the bug and please provide clear justification in the bug.
Please provide clear explanation for why a merge is required, what is the criticality and impact of the issue, and ensure that bug is correctly labeled for all impacted OS's.
Approved merge requests in Phase 2 and Phase 3 will require a post mortem.
Once Merge is approved, the bug will be marked with Merge-Approved-[Milestone-Number] label. Please merge immediately after. Please note that if change is not merged in time after approval, it can be rejected.
If merge is rejected, “Merge-Rejected” label will be applied. If you think it’s important to consider the change for merge and does not meet the criteria above, please reach out to the release owners, TPMs or TLs for guidance.
The release team has an automated process that helps with the merge evaluation process. It will enforce many of the rules listed in sections above. If the rules above don’t pass, it will either auto-reject or flag for manual review. Please allow up to 24 hours for the automated process to take effect.
Manual merge reviews will be performed by release owners and TPMs.