From 09e89bf43633fe6274c5884b2f8366669861a88c Mon Sep 17 00:00:00 2001 From: Tiexin Guo Date: Wed, 15 Jun 2022 14:37:03 +0800 Subject: [PATCH 1/2] docs: contributor ladder updated --- CONTRIBUTOR_LADDER.md | 169 ++++++++++++++++++++++++++++++++++++++++++ mkdocs.yml | 3 +- 2 files changed, 171 insertions(+), 1 deletion(-) create mode 100644 CONTRIBUTOR_LADDER.md diff --git a/CONTRIBUTOR_LADDER.md b/CONTRIBUTOR_LADDER.md new file mode 100644 index 000000000..84d134b3b --- /dev/null +++ b/CONTRIBUTOR_LADDER.md @@ -0,0 +1,169 @@ +# Contributor Ladder + +- [Contributor Ladder](#contributor-ladder-template) + - [Community Participant](#community-participant) + - [Contributor](#contributor) + - [Organization Member](#organization-member) + - [Reviewer](#reviewer) + - [Maintainer](#maintainer) +- [Inactivity](#inactivity) +- [Involuntary Removal](#involuntary-removal-or-demotion) +- [Stepping Down/Emeritus Process](#stepping-downemeritus-process) +- [Contact](#contact) + +## Contributor Ladder + +Hello! We are excited that you want to learn more about our project contributor ladder! 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 it 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 contributor is expected to do. "Requirements" are qualifications a person needs to meet to be in that role, and "Privileges" are things contributors on that level are entitled to. + +### Contributor + +_Description: A Contributor contributes directly to the project and adds value to it. Contributions need not be code. Non-code contributions are equally, if not more, valued. People at the Contributor level may be new contributors, or they may only contribute occasionally._ + +- Responsibilities: + - Follow the CNCF CoC + - Follow the project contributing guide + +- Requirements (one or several of the below items): + - Report and sometimes resolve issues + - Occasionally submit PRs + - Contribute to the documentation + - Show up at meetings, takes notes + - Answer questions from other community members + - Submit feedback on issues and PRs + - Test releases and patches and submit reviews + - Run or helps run events + - Promote the project in public + - Help run the project infrastructure + +- Privileges: + - Invitations to contributor events + - Eligible to become an Organization Member + +### Organization Member + +_Description: An Organization Member is an established contributor who regularly participates in the project. Organization Members have privileges in both project repositories and elections, and as such are expected to act in the interests of the whole project._ + +An Organization Member _must meet the responsibilities and has the requirements of a Contributor_, plus: + +- Responsibilities: + - Continues to contribute regularly, as demonstrated by having at least 50 GitHub contributions per year, as demonstrated by [GitHub Insights](https://github.com/devstream-io/devstream/pulse). + +- Requirements: + - Must have successful contributions to the project, including at least one of the following: + - 5 accepted PRs, + - Reviewed 5 PRs, + - Resolved and closed 5 Issues, + - Become responsible for a key project management area, + - Or some equivalent combination or contribution + - Must have been contributing for at least 1 months + - Must be actively contributing to at least one project area + - Must have two sponsors who are also Organization Members, at least one of whom does not work for the same employer + +- Privileges: + - May be assigned Issues and Reviews + - May give commands to CI/CD automation + - Entitled to vote in elections [TODO] + - Can be added to @devstream teams + - Can recommend other contributors to become Org Members + +The process for a Contributor to become an Organization Member is as follows: + +1. The member contributor is nominated by a sponsor, by opening an issue in the appropriate repository. +2. The second sponsor from a different employer seconds the nomination in the issue. +3. The nomination is reviewed publicly in a community meeting. All members vote for the nomination. A majority is required in order to approve the nomination. +4. Publicly announce the result in the issue, and in the contributor slack channel; and invite the member into the member channel. + +### Reviewer + +_Description: A Reviewer has responsibility for specific code, documentation, test, or other project areas. They are collectively responsible, with other Reviewers, for reviewing all changes to those areas and indicating whether those changes are ready to merge. They have a track record of contribution and review in the project._ + +Reviewers are responsible for a "specific area." This can be a specific code directory, driver, chapter of the docs, test job, event, or other clearly-defined project component that is smaller than an entire repository or subproject. Most often it is one or a set of directories in one or more Git repositories. The "specific area" below refers to this area of responsibility. + +Reviewers have all the rights and responsibilities of an Organization Member, plus: + +- Responsibilities: + - Following the reviewing guide + - Reviewing most Pull Requests against their specific areas of responsibility + - Reviewing at least 20 PRs per year + - Helping other contributors become reviewers + +- Requirements: + - Experience as a Contributor for at least 1 months + - Is an Organization Member + - Has reviewed, or helped review, at least 5 Pull Requests + - Has analyzed and resolved test failures in their specific area + - Has demonstrated an in-depth knowledge of the specific area + - Commits to being responsible for that specific area + - Is supportive of new and occasional contributors and helps get useful PRs in shape to commit + +- Additional privileges: + - Has GitHub or CI/CD rights to approve pull requests in specific directories + - Can recommend and review other contributors to become Reviewers + - Is listed as Approver in the OWNERS file for certain directories + +The process of becoming a Reviewer is: + +1. The contributor is nominated by opening a PR against the appropriate repository, which adds their GitHub username to the OWNERS file for one or more directories. +2. At least two members of the team that owns that repository or main directory, who are already Approvers, approve the PR. + +### 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._ + +A Maintainer must meet the responsibilities and requirements of a Reviewer, plus: + +- Responsibilities: + - Reviewing at least 40 PRs per year, especially PRs that involve multiple parts of the project + - Mentoring new Reviewers + - Writing refactoring PRs + - Participating in CNCF maintainer activities + - Determining strategy and policy for the project + - Participating in, and leading, community meetings + +- Requirements + - Experience as a Reviewer for at least 3 months + - Demonstrates a broad knowledge of the project across multiple areas + - Is able to exercise judgement for the good of the project, independent of their employer, friends, or team + - Mentors other contributors + - Can commit to spending at least 40 hours per month working on the project + +- Additional privileges: + - Approve PRs to any area of the project + - Represent the project in public as a Maintainer + - Communicate with the CNCF on behalf of the project + - Have a vote in Maintainer decision-making meetings + +Process of becoming a maintainer: + +1. Any current Maintainer may nominate a current Reviewer to become a new Maintainer, by opening a PR against the root of the DevStream repo, adding the nominee as an Approver in the OWNERS 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. + +- Inactivity is measured by: + - Periods of no contributions for longer than 2 months + - Periods of no communication for longer than 1 month +- Consequences of being inactive include: + - Involuntary removal or demotion + - Being asked to move to Emeritus status + +## Involuntary Removal or Demotion + +Involuntary removal/demotion of a contributor happens when responsibilities and requirements aren't being met. This may include repeated patterns of inactivity, extended period of inactivity, a period of failing to meet the requirements of your role, and/or a violation of the 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). + +Contact the Maintainers about changing to Emeritus status, or reducing your contributor level. + +## Contact + +For inquiries, please reach out to the @pmc chair @IronCore864. diff --git a/mkdocs.yml b/mkdocs.yml index f0b15e011..18d225d60 100644 --- a/mkdocs.yml +++ b/mkdocs.yml @@ -67,6 +67,7 @@ nav: - Best Practices: - 'best-practices/gitops.md' - 'contribute.md' + - Contributor Ladder ⧉: 'https://github.com/devstream-io/devstream/blob/main/CONTRIBUTOR_LADDER.md' - Developer Guide: - Core Concepts in Detail: - 'core-concepts/config.md' @@ -76,7 +77,6 @@ nav: - 'core-concepts/dependencies.md' - 'core-concepts/output.md' - 'development/development-workflow.md' - - 'development/contributor_ladder_growth_programs.md' - 'development/project-layout.md' - 'development/architecture.md' - Commands: @@ -87,4 +87,5 @@ nav: - 'development/lint.md' - 'development/creating-a-plugin.md' - 'development/branch-and-release.md' + - Road Map ⧉: 'https://github.com/devstream-io/devstream/blob/main/ROADMAP.md' - 'troubleshooting.md' From 03a952dc80e35f652bfd6b7cd153b69892e01f38 Mon Sep 17 00:00:00 2001 From: Tiexin Guo Date: Wed, 15 Jun 2022 14:40:42 +0800 Subject: [PATCH 2/2] docs: sunset the old ladder doc --- .../contributor_ladder_growth_programs.md | 30 ------------------- 1 file changed, 30 deletions(-) delete mode 100644 docs/development/contributor_ladder_growth_programs.md diff --git a/docs/development/contributor_ladder_growth_programs.md b/docs/development/contributor_ladder_growth_programs.md deleted file mode 100644 index ca1a58b1d..000000000 --- a/docs/development/contributor_ladder_growth_programs.md +++ /dev/null @@ -1,30 +0,0 @@ -# Contributor Ladder Growth Programs - -**Note:** This document is wip and welcomes everyone to help improve. - -## DevStream Community Membership - -| Role | Responsibilities | Requirements | Defined by | -| ----------- | --------------------------------------- | ------------------------------------------------------------ | ------------------------------------------------------------ | -| Contributor | N/A | At least 1 contribution to the project | N/A | -| Member | Active contributor in the community | Sponsored by 2 reviewers and multiple contributions to the project | DevStream GitHub Org member & Team member | -| Reviewer | Review contributions from other members | Highly experienced active member who is knowledgeable about the codebase; Member for at least 1 month | DevStream GitHub Org member & Team member & OWNERS file reviewer entry | -| Approver | Contributions acceptance approval | Highly experienced active reviewer and contributor; Reviewer for at least 3 months | DevStream GitHub Org member & Team member & OWNERS file approver entry | - -New contributors should be welcomed to the DevStream community by existing members, helped with PR workflow, and directed to relevant documentation and communication channels. - -## OWNERS file - -`OWNERS` files are used to designate responsibility for different parts of the DevStream codebase. We use them to assign the `Reviewer` and `Approver` roles. - -We will gradually define `OWNERS` for each DevStream plugin and each module of DevStream core. - -A typical OWNERS file looks like below: - -```yaml -approvers: -- daniel # GitHub username -reviewers: -- daniel -- danny -```