Merge "Resolution to define distributed leadership for projects"

This commit is contained in:
Zuul 2020-09-15 17:48:40 +00:00 committed by Gerrit Code Review
commit 09e37871b3

View File

@ -0,0 +1,199 @@
=========================================
2020-08-03 Distributed Project Leadership
=========================================
The governing structure for OpenStack project teams has long been for a Project
Team Lead (PTL) to be elected to serve as a singular focus for its team.
While the PTL role varies significantly from team to team, the PTL has
many responsibilities for managing the development and release process for the
project deliverables as well as representing the project team both internally and
externally.
This resolution outlines a process for OpenStack project teams to opt in to a
"distributed leadership" model where there is no PTL. The responsibilities
normally held by the PTL are distributed to various liaisons, which may be held
by one or multiple contributors.
The responsibilities mentioned are related to day-to-day operations of the PTL.
In this model, the rest of the PTL duties, like driving the team goals or
resolve technical disputes, is trusted to the whole team. If necessary, project
teams can still contact the TC to resolve deadlocks in disputes.
How the PTL with liaisons works
-------------------------------
This resolution will not change how the PTL with liaisons work:
the PTL is still encouraged to delegate responsibilities to
individuals. The PTL remains the single point of contact and responsibility for
all the duties.
Please also have a look at the `PTL page on the project team guide`_.
How Distributed Leadership Works
--------------------------------
The day to day responsibilities of the PTL have been broken down into the
following roles. Not all roles are required for the minimal viable health of a
project team. All these roles can be distributed amongst one or more individuals.
Required roles
~~~~~~~~~~~~~~
The project teams are expected to have at least the following required liaison
roles:
* Release liaison: The `release liaison`_ is responsible for requesting releases
for deliverables produced by the project team. In addition, release liaisons
generally review requests for Feature Freeze Exception (FFE).
* tact-sig liaison: Historically named the "infra Liaison". It is responsible for
the health of the CI jobs run in the OpenStack Zuul CI. In the event that there
is an issue with those jobs, this liaison will be a point of contact for the
`TaCT SIG`_. Also, a +1 from at least one tact-sig liaison will be required
for changes in the `project_config repository`_.
* Security liaison: the security liaison is the contact person to help assessing
the impact of any security reported issues in the project team deliverables,
coordinate the development of patches, review proposed patches, and propose
any eventual backport(s).
Additional recommended roles
~~~~~~~~~~~~~~~~~~~~~~~~~~~~
Any other responsibilities of the PTL that are not addressed above are optional,
and are left to the project teams to determine. The TC recommends project teams
opting in for distributed project leadership to assign people into the following
optional roles, to each project team's discretion:
* Events liaison: An Events liaison ensures that a project team has space
reserved at a PTG or Summit that will be sufficient for the project team's
meeting needs. The events liaison puts out an agenda for any of the team
meetings, makes sure those meetings are organized and facilitated, and that
the results are documented. This is a temporary role, lasting only during the
preparation time for the event and it's duration. Due to the temporary aspect
of this role, the liaison will not be recorded in governance, else it might
quickly get outdated.
At the beginning of the organisation of an event, the OpenStack Events teams
will query on our openstack-discuss ML for participants ready to liaise for
the event, for all the teams with distributed leadership.
The project teams interested in being represented at the event can then opt-in to
the event by assigning a liaison. The project teams are free to decide how and
who will be assigned as the event liaison. The project teams not answering on
the ML or not assigning a liaison on time will not have representation in the
event.
* Project Update/Onboarding liaisons: The Project Update Liaison is responsible
for giving the project update showcasing team's achievements for the cycle to
the community. The "Project Onboarding" liaison is responsible for
giving/facilitating onboarding sessions during events for its projects'
community. Similarly to the events liaison, those two roles are opt ins.
* Meeting Facilitator: The Meeting Facilitator chairs the project team's regular
periodic meetings and maintains their agenda.
* Bug Deputy: Ensures all incoming bugs are triaged.
* RFE Coordinator: This role would involve making sure that blueprint status and
milestone targets are up to date, that RFEs are triaged and discussed before
acceptance, and that the tracking LaunchPad or Storyboard items for RFEs are
properly managed.
Liaison selection
~~~~~~~~~~~~~~~~~
The process by which each project team chooses these liaisons is left to the
discretion of the project teams, as long as it is public, open, and respectful
of the current TC guidelines. The TC advocates the use of consensus decisions,
with polls or elections when consensus can not be reached.
Liaison assignment duration
~~~~~~~~~~~~~~~~~~~~~~~~~~~
While the PTL is assigned to a single cycle, the duration of the assignment
for a team's liaison is unlimited in time. To avoid outdated information,
a TC member dedicated to follow a project team with distributed leadership
will query, at regular intervals (once per cycle), if the liaisons for the
team are still valid. It is expected to have the liaisons answer on the
mailing list thread to extend/validate their liaison status.
Points of Concern
-----------------
There are a few places where the project teams that choose the distributed
leadership model will need to innovate and solve problems:
* Discoverability: It will make harder to know whom to contact for a project team.
* Distributed Consensus: With an increased number of people accountable for
aspects of the project team, the potential for miscommunications increases.
* Unclear responsibilities: As a project team moves to the distributed leadership
model, it will lose the single point of contact (SPoC). This SPoC was useful
for coordination on community topics, like the follow up/implementation of
community goals or an official answer on project teams's questions on the
mailing lists, to name a few.
As mentioned in the distributed consensus above, an increased number of people
accountable for the project team leads to consensus challenges, and also
to unclear responsibilities for the liaisons.
This could lead to a blurry situation where no one is actually doing the work
for the community, as they might have expected "someone else" to do it.
The TC expects and trusts the project teams to continue working on their
community duties, and encourage projects teams to actively communicate on the
mailing lists on community efforts, to remove any eventual misunderstandings
and misconceptions.
* Inclusion: Since some of the liaisons will not be explicitly written in code -
like the events liaisons - the project team members will need to actively
contact the OpenStack events team. This is different than our usual opt out,
and is less inclusive than before.
* Minimum Viable: This document is intended to assert the minimum set of roles
the TC would require to consider the project team to be active and
functioning. It is not an exhaustive list of possible roles. For example, a
project team might assign someone at the end of each cycle to write the cycle
highlights. These responsibilities could also be collectively handled by the
project team, as needed or rotated at intervals. Teams have the freedom to
choose what works best for them.
Process for Opting In to Distributed Leadership
-----------------------------------------------
Project teams that would like to opt in to a distributed leadership role should
make sure this change has a relative degree of consensus within the project
team. To make the request, a change should be pushed to `projects.yaml` in the
`openstack/governance` repository to add the line "leadership_type: distributed"
to the team's definition. The minimum required liaisons will also need to be
filled-in, in the appropriate fields in the "liaisons" section of the team.
This change to move to a distributed leadership model can only be accepted by
the TC when it will receive at least a +1 from the current PTL, and the future
liaisons.
Technical notes:
* A follow-up patch on this resolution will change the "liaisons" field to adapt
its current structure, to add the new mandatory roles, next to the already
present list of TC members liaising for the team.
* The releases liaison will continue to be listed in the `releases` repository,
to not impact the current delivery of the releases.
Once a project team has moved to the distributed leadership model, they can
revert to the PTL model by creating a change to `projects.yaml` to remove the
"leadership_type: distributed" line in the team's configuration. This change
should have at least a +1 from all the people currently serving as liaisons,
including the `release liaison`_ for the project team, which might not be in the
`governance` repo. It must also get a +1 from the future PTL, listed in the
same change.
A project team may change their opt-in status only once a release cycle, to
ensure that the elections officials have clarity on which project teams need PTL
elections. All requests should be received by week R-5 of the release calendar.
The distributed leadership model is only requested explicitly. If a project
team has no candidate for PTL, the TC will still evaluate the future of the
team and its deliverables, with now an extra option
(on top of stopping the project or appointing a PTL):
convert the project to a distributed leadership with the help of the project
team members.
.. _release liaison: https://opendev.org/openstack/releases/src/branch/master/data/release_liaisons.yaml
.. _TaCT SIG: https://governance.openstack.org/sigs/tact-sig.html
.. _project_config repository: https://opendev.org/openstack/project-config
.. _PTL page on the project team guide: https://docs.openstack.org/project-team-guide/ptl.html