Release Management/Uplift rules

From MozillaWiki
Jump to navigation Jump to search


This page describes the rules applied by the Release Team to uplift a patch in one of the release.

All regular guidelines for changes apply.

General

  • Uplifts are requested in the Details page of the attachment, Flags section which should be updated.
  • If a patch is considered as risky and impact both aurora and beta, please make sure that the other responsible is aware of the uplift.
  • For a risky patch, don't hesitate to set the keyword "verifyme" to make sure someone will check if the bug is actually fixed.
  • The name/nickname of the release manager who approved the uplift will be added in the commit message with a= (example: a=foobar)


Guidelines on approval comments

  • [Feature/regressing bug #]: If this is a fallout from a feature/bug, or a backout please state the reason along with the bug number
  • [User impact if declined]: In addition to the STR (steps to reproduce) reported in the bug if you can explain on a deeper level aspect of how an end user would be impacted with/without your change
  • [Describe test coverage new/current, TBPL]: What kind of testing was completed here. Manual and/or automated ? Any details about what scenarios the tests cover? If the patch landed on a master/central branch or any other branch did we get verification from reporter or QA?
  • [Risks and why]: No risk/Zero risk are unacceptable here. Even a single line of code change could be damaging!, yes we've seen that
    • When saying something is "low", "medium", or "risky" please justify
    • Eg : Low risk because its a one line CSS change impacting only settings page
    • Eg : Medium, given the code complexity and integration with other areas of code that might be impacted. Expect regressions in areas like..
    • Eg : Risky, given the complex nature the bake time we have have on master/central or other branches. High rate of fallouts/regression. Could be mitigated by more manual testing in areas or running some targeted test cases..
  • [String/UUID change made/needed]: Please answer this as "none" if no string changes were made

Firefox (Desktop and Mobile)

Aurora Uplift (approval-mozilla-aurora)

  • Can accept IDL (with UUID bump) changes as we do not lock down binary for addons until Beta
  • No string changes unless late-l10n awareness and OK given
  • Must be landed on mozilla-central, or reason given for direct-to-branch uplift
  • No new feature landing
  • No disruptive important refactoring
  • No massive code changes

Beta Uplift (approval-mozilla-beta)

  • Must be landed on mozilla-central as well as mozilla-aurora, or reason given for direct-to-branch uplift
  • Ideally reproducible by QA so easily verified
  • Has 'baked' on m-c/aurora and demonstrated decrease in crash or reproducibility
  • No string changes
  • No changes to UUID in .idl files (will break addon compatibility)

Changes can be:

  • Performance improvement (proven, need real numbers)
  • Top-crashers
  • Recent regressions

The closer to the release the more careful uplift should be done.

Release Uplift

  • Must be a part of a known-issue respin or NPOTB (not part of the build) config changes needed to support build infra

Firefox OS gaia/gecko uplifts

approval-gaia-v2.x/approval-gecko-b2gxx

  • For any gaia/gecko change's landing on the 2.x release, please request approval to land
  • Please note, the closer we try to wrap up stabilization mode the more stricter we'd be on taking any changes

Criteria to request approval (Guidelines)

  • Patch must be landed and Resolved on master/central
  • any bug that has a high user impact
  • String changes may not be approved after the string freeze dealine
  • a low risk polish change : Visual polish - colors, sizes, icons, alignment, etc
  • functional-polish: Example, Notification tray displaying that your microphone is active, but onclick does not do anything. Ideally it should take to microphone settings if I wanted to play with it... It's not really a bug, but it could be better. And it requires code changes, not just visual work.
  • papercuts: It's for issues found during dogfooding/testing that are visually or functionally annoying or otherwise sub-par, but not enough to block the release
  • Performance/crash-fixes : Depending on the risk evaluation and the reward we get. Uplifting these fixes will be highly considered depending on where we are in the release cycle
  • If you are requesting approval on a gaia/gecko patch that needs to land on 2.x that
    • Set approval-gaia-v2.x/approval-gecko-b2g37: ? and making sure to fill the populated set of questions [Approval Request Comment] that come up on the attachment
Gaia-approval.png

Special cases

  • In the context of add-on SDK modifications, when an uplift is requested, it is normal not to find the land in m-c (because the m-c changeset is not posted in the bug report)
  • If patches only make changes to tests, test harnesses or anything else that does not affect the shipped builds, they may land with self approval (use a=testonly, a=npotb etc).

Security fixes

As described in Security/Bug_Approval_Process If the bug whiteboard contains a deadline, the uplift should be granted only after this date.