From 5ee33f31e01148f4b4c418d9f5fee75c46be578d Mon Sep 17 00:00:00 2001 From: Shalier Xia <69616256+shalier@users.noreply.github.com> Date: Tue, 14 Jun 2022 13:07:57 -0700 Subject: [PATCH] ref(contributors): update contributor roles and requirements (#4776) - Clarifies role requirements - Defines process for adding codeowner permissions per directory Signed-off-by: jaellio Signed-off-by: Shalier Xia --- CONTRIBUTOR_LADDER.md | 74 +++++++++++++++++++++++++++++-------------- 1 file changed, 51 insertions(+), 23 deletions(-) diff --git a/CONTRIBUTOR_LADDER.md b/CONTRIBUTOR_LADDER.md index 2a3897177e..fda97fdffe 100644 --- a/CONTRIBUTOR_LADDER.md +++ b/CONTRIBUTOR_LADDER.md @@ -1,34 +1,39 @@ # OSM Contributor Ladder -Hello! We are excited to have you contribute to Open Service Mesh (OSM)! This contributor ladder outlines the different contributor roles within the project, along with the responsibilites and privileges that come with them. Community members generally start at the first levels of the "ladder" and advance up it as their involvement in the project grows. Our project members are happy to help you advance along the contributor ladder. +Hello! We are excited to have you contribute to Open Service Mesh (OSM)! This contributor ladder outlines the different contributor roles within the project, along with the responsibilities and privileges that come with them. Community members generally start at the first levels of the "ladder" and advance up as their involvement in the project grows. Our project members are happy to help you advance along the contributor ladder. -Each of the contributor roles below is organized into lists of three types of things. -* "Responsibilities" are things that a contributor is expected to do -* "Requirements" are qualifications a contributor needs to meet to be in that role -* "Privileges" are things a contributor on that level is entitled to +Each of the roles is organized into the following categories: +* "Responsibilities" list what the role is expected to do +* "Requirements" are qualifications the role needs to meet +* "Privileges" list what the role is entitled to +| Role | Responsibilities | Requirements | Privileges | +| -----| ---------------- | ------------ | -------| +| [Community Participant](#community-participant) | Following the [CNCF Code of Conduct] | --- | --- | +| [Contributor](#contributor) | Following the [CNCF Code of Conduct] and the project [contributing guide] | One or more contributions to the project | Invitations to contributor events | +| [Maintainer](#maintainer) | Active member of the community | | | ## Community Participant + Description: A Community Participant participates in the community and contributes their time, thoughts, etc. * Responsibilities: - * Must follow the [CNCF CoC](https://github.com/cncf/foundation/blob/master/code-of-conduct.md) + * Must follow the [CNCF Code of Conduct] * How users can get involved with the community: - * Participating in community discussions in Github, Slack, and meetings + * Participating in community discussions in GitHub, Slack, and meetings * Helping other users * Submitting bug reports * Trying out new releases * Attending community events * Talking about the project on social media, blogs, and talks - ## Contributor Description: A Contributor contributes directly to the project and adds value to it. Contributions need not be code. People at the Contributor level may be new contributors, or they may only contribute occasionally. * Responsibilities include: - * Following the [CNCF CoC](https://github.com/cncf/foundation/blob/master/code-of-conduct.md) - * Following the project [contributing guide](https://github.com/openservicemesh/osm/blob/main/CONTRIBUTING.md) + * Following the [CNCF Code of Conduct] + * Following the project [contributing guide] * Requirements (one or several of the below): * Reports and sometimes resolves issues * Occasionally submits PRs @@ -41,17 +46,20 @@ Description: A Contributor contributes directly to the project and adds value to * Promotes the project in public * Privileges: * Invitations to contributor events - * Eligible to become a maintainer + * Eligible to become a Maintainer +Process of becoming a Contributor: +1. There is no nomination process for this role. Being a contributor entails being a community member who does one or more of the listed requirements. ## Maintainer -Description: Maintainers are very established contributors who are responsible for the entire project. As such, they have the ability to approve PRs against any area of the project, and are expected to participate in making decisions about the strategy and priorities of the project. +Description: Maintainers are established contributors who are responsible for one or more project areas. They have the ability to approve PRs against the project areas they own and are expected to participate in making decisions about the strategy and priorities of the project. -A Maintainer must meet the rights, responsiblities, and requirements of a Contributor, plus: +**Defined by**: *owners* entry in the [OWNERS file]. + +A Maintainer must meet the rights, responsibilities, and requirements of a Contributor, plus: * Responsibilities include: - * Following the reviewing guide * Reviewing and approving PRs that involve multiple parts of the project * Is supportive of new and infrequent contributors, and helps get useful PRs in shape to commit * Mentoring new Maintainers @@ -60,26 +68,34 @@ A Maintainer must meet the rights, responsiblities, and requirements of a Contri * Determining strategy and policy for the project * Participating in, and leading, community meetings * Helps run the project infrastructure -* Requirements +* Requirements: * Experience as a Contributor for at least 3 months - * Demonstrates a broad knowledge of the project across multiple areas + * Deep understanding of the technical goals and direction of the project + * Deep understanding of the technical domain of the project across their areas of ownership + * Sustained contributions to design and direction by doing all of: + * Authoring and reviewing proposals (GitHub Issues for refactoring, enhancements, or new functionality) + * Initiating, contributing, and resolving discussions (emails, GitHub issues, meetings) + * Identifying subtle or complex issues in designs and implementation PRs * Is able to exercise judgement for the good of the project, independent of their employer, social circles, or teams * Mentors other Contributors * Additional privileges: + * Approve PRs to areas of ownership * Represent the project in public as a Maintainer * Communicate with the CNCF on behalf of the project * Have a vote in Maintainer decisions -Process of becoming a maintainer: +Process of becoming a Maintainer: -1. Any current Maintainer may nominate a current Contributor to become a new Maintainer, by opening a PR against the root of the [OSM repository](https://github.com/openservicemesh/osm) and adding the nominee to the [OWNERS file](https://github.com/openservicemesh/osm/blob/main/OWNERS). Additionally, if the nomination is for a code owner whose PR approvals are meant to satisfy the PR merge requirements, the nominee must be added to the [CODEOWNERS file](https://github.com/openservicemesh/osm/blob/main/CODEOWNERS) in the same PR. +1. A current contributor may be self-nominated or be nominated by a current Maintainer by opening a PR against the root of the [OSM repository] and adding the nominee to the [OWNERS file] under the *owners* entry. + - If the nomination is for a code owner whose PR approvals are meant to satisfy the PR merge requirements against specific areas of the codebase, the nominee must be added to the [CODEOWNERS file] for their specific areas of ownership in the same PR. + - A codeowner is defined per the [GitHub definition](https://docs.github.com/en/repositories/managing-your-repositorys-settings-and-features/customizing-your-repository/about-code-owners#about-code-owners). See this [example](https://docs.github.com/en/repositories/managing-your-repositorys-settings-and-features/customizing-your-repository/about-code-owners#example-of-a-codeowners-file) on how to specify an area in the [CODEOWNERS file] . 2. The nominee will add a comment to the PR testifying that they agree to all requirements of becoming a Maintainer. 3. A majority of the current Maintainers must then approve the PR. ## Inactivity -It is important for contributors to be and stay active to set an example and show commitment to the project. Inactivity is harmful to the project as it may lead to unexpected delays, contributor attrition, and a lost of trust in the project. +It is important for contributors to be and stay active to set an example and show commitment to the project. Inactivity is harmful to the project as it may lead to unexpected delays, contributor attrition, and a loss of trust in the project. * Inactivity is measured by: * Periods of no contributions for longer than 3 months @@ -92,19 +108,31 @@ It is important for contributors to be and stay active to set an example and sho ## Involuntary Removal or Demotion -Involuntary removal/demotion of a contributor happens when responsibilites and requirements aren't being met. This may include repeated pattern of inactivity, extended period of inactivity, a period of failing to meet the requirements of your role, and/or a violation of the [CNCF CoC](https://github.com/cncf/foundation/blob/master/code-of-conduct.md). This process is important because it protects the community and its deliverables while also opens up opportunities for new contributors to step in. - +Involuntary removal/demotion of a Maintainer happens when responsibilities and requirements aren't being met. This may include repeated patterns of inactivity, extended periods of inactivity, a period of failing to meet the requirements of your role, and/or a violation of the [CNCF Code of Conduct]. This process is important because it protects the community and its deliverables while also opens up opportunities for new contributors to step in. Involuntary removal or demotion is handled through a vote by a majority of the current Maintainers. ## Stepping Down/Emeritus Process -If and when contributors' commitment levels change, contributors can consider stepping down (moving down the contributor ladder) vs moving to emeritus status (completely stepping away from the project). +If and when a contributor's commitment level changes, they can consider one of the following options: +1. Stepping down (moving down the contributor ladder) +2. Moving to emeritus status (completely stepping away from the project). -Contact the Maintainers about changing to Emeritus status, or reducing your contributor level. +Contact the Maintainers about changing to Emeritus status or reducing your contributor level. +## Review Process + +- In addition to self-nominated and Maintainer proposed nominations, Maintainers will meet quarterly to discuss Role promotions and demotions. +- Prior to nomination or meeting the requirements of the role, Contributors that express their interest in being a Maintainer can be assigned a Maintainer to help guide them through the requirements. + ## Contact For inquiries, please reach out to: openservicemesh-maintainers@lists.cncf.io + +[OWNERS file]: https://github.com/openservicemesh/osm/blob/main/OWNERS +[CODEOWNERS file]: https://github.com/openservicemesh/osm/blob/main/CODEOWNERS +[OSM repository]: https://github.com/openservicemesh/osm +[contributing guide]: https://github.com/openservicemesh/osm/blob/main/CONTRIBUTING.md +[CNCF Code of Conduct]: https://github.com/cncf/foundation/blob/master/code-of-conduct.md \ No newline at end of file