Role expectations

The SRU team is a narrowly scoped team that has privileged access: primarily to “accept” packages from the stable series’ unapproved queues into the -proposed pocket, and “release” packages from the -proposed pocket into the -updates pocket. Reviews and decision making, and the policy, processes and documentation around these reviews and decision making are the responsibility of the SRU team.

Other work that does not require elevated privilege, such as bug triage and management, preparing updates, performing QA, handling any follow-on regression reports and so forth, can be performed by any Ubuntu developer or prospective Ubuntu developer.

Therefore, the SRU team, when on shift and “wearing an SRU hat”, takes a narrow view of our role, focusing our limited resources on only progressing processes limited by this privilege. It is our expectation that Ubuntu developers at large drive the non-privileged tasks because they scale better.

We expect all Ubuntu developers to be familiar with the SRU process as documented here, should they need to interact with SRUs.

It is normal and expected for prospective developers to not yet be familiar with SRU process. If prospective developers are preparing uploads for SRU, then they will need a sponsor, for example through the patch pilot programme. We expect Ubuntu developers to ensure that any uploads that they sponsor meet our expectations. As above, since SRU team members focus on operations limited by privilege during their shifts, prospective developers who need help should seek that help from their sponsors, and not from the SRU team directly. To find a sponsor, try the patch pilot programme.

If review iterations are required, then prospective developers are welcome to help. However, we expect this to be supervised by sponsors and for them to intervene if required.

We therefore arrive at a set of distinct roles. Note that the person who takes on each role can change over time, even for an individual SRU.

Role

Responsibility

Who can do it

SRU Driver

Manage and triage bugs, follow the SRU process and perform the necessary development and QA tasks to see fixes land.

Anyone who understands the packaging changes necessary to land a particular fix into a stable release of Ubuntu and is willing to do that work. If this person does not have upload access to Ubuntu, then they can still take this role, under the supervision of a sponsor (sponsors can be found via the patch pilot programme).

Sponsor

Help the SRU Driver with the required process.

Someone familiar with SRU process who has upload access to the Ubuntu package archive.

SRU Reviewer

Review and negotiate proposed uploads for compliance with SRU criteria, agree the QA plan, accept uploads into -proposed, confirm the agreed plan was followed, and release -proposed packages into -updates.

SRU team members only.

SRU Process Developer

Drive process changes, documentation, etc.

Anyone, under the leadership of the SRU team.

SRU Representative

Ensure the SRU team capacity is spent effectively by guiding the team they represent to propose uploads that meet the process needs and expectations right away. Thereby avoiding iterations consuming SRU team member capacity and delaying uploads.

Has a more direct access to the SRU team in a private channel for when they are in doubt.

Valid sponsors into the SRU process. Proposed to be their representative by a team/group and approved by the SRU team.

SRU Assistant

Essentially an SRU team member in training. Shadowing and helping an active SRU team member to fully learn the skill, the mindset, and the diligence needed.

Initial status of anyone selected by the SRU team to become a SRU team member.

Beneficial, but not required to have been a representative before.

Overriding authority

Agree exceptions to the SRU criteria.

Technical Board members only.

SRU Interest Team

If a team is defined for an SRU with an exception they will get bug updates about upcoming changes to ease testing.

Anyone, by joining the respective SRU Interest team on Launchpad

It may be the case that even though an SRU meets all documented requirements, the SRU team concludes that the risk of an update breaking users’ expectations outweigh the benefit of making the change, and in this case your SRU will be refused. To minimise the chance of this conclusion, the SRU Driver is required to:

  1. Be (or become) an expert in the area of the codebase being modified to the extent required to complete the following steps.

  2. Ensure that a high quality analysis of the risks is presented in the SRU documentation.

  3. Provide effective and convincing mitigation of the risks found in the risk analysis.

The depth and breadth of analysis and mitigation required depends on the apparent risk of the proposed change. If, ultimately, the SRU Driver is unable to provide a risk analysis and appropriate mitigation to the level required, as judged by the SRU team on a case-by-case basis, then the SRU will be refused.