COMMITTERS.rst
.. Licensed to the Apache Software Foundation (ASF) under one or more contributor license agreements. See the NOTICE file distributed with this work for additional information regarding copyright ownership. The ASF licenses this file to you under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
.. http://www.apache.org/licenses/LICENSE-2.0
.. Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
Before reading this document, you should be familiar with the Contributors' guide <contributing-docs/README.rst>__.
This document assumes that you are a bit familiar with how Airflow's community works, but you would like to learn more
about the rules by which we add new committers and PMC members.
.. contents:: Table of Contents :depth: 2 :local:
Often you can hear two different terms about people who have write access to the Airflow repository - "committers" and "maintainers". This is because those two terms are used in different contexts.
Contributor License Agreement (CLA) <https://www.apache.org/licenses/#clas>_ on file. They have an
apache.org mail address. This is an official role <https://www.apache.org/foundation/how-it-works/#roles>_
defined and governed by the Apache Software Foundation.For all practical purposes, both terms are interchangeable because the Apache Software Foundation rule is that only Committers can have write access to the repositories managed by the PMC (Project Management Committee) and that all Committers get write access to the repository.
You will see both terms used in different documentation, therefore our goal is not to use one of the terms only - it is unavoidable to see both terms anyway. As a rule, we are using "committer" term in the context of the official rules concerning Apache Software Foundation and "maintainer" term in the context where technical GitHub access and permissions to the project are important.
Committers are community members who have write access to the project's repositories, i.e., they can modify the code, documentation, and website by themselves and also accept other contributions. There is no strict protocol for becoming a committer. Candidates for new committers are typically people that are active contributors and community members.
Some people might be active in several of those areas and while they might not have enough 'achievements' in any single one of those, their combined contributions in several areas all count.
As a community, we appreciate contributions to the Airflow codebase, but we also place equal value on those who help Airflow by improving the community in some way. It is entirely possible to become a committer (and eventually a PMC member) without ever having to change a single line of code, but that requires visibility and presence in the regular community channels - slack, devlist, social media - this is important for the PMC to be aware of such activities. If PMC is not aware of those, they have no chance to spot and promote such candidates.
Guidelines from ASF are listed at ASF:
New Candidates for Committership <http://community.apache.org/newcommitter.html#guidelines-for-assessing-new-candidates-for-committership>_
Prerequisites ^^^^^^^^^^^^^
General prerequisites that we look for in all candidates:
Contributors' Guide <contributing-docs/README.rst>__Code contribution ^^^^^^^^^^^^^^^^^
A potential candidate for committership typically demonstrates several of the following:
Makes high-quality commits (including meaningful commit messages), and assess the impact of the changes, including upgrade paths or deprecation policies
Tests Release Candidates to help the release cycle
Proposes and/or leads Airflow Improvement Proposal(s) to completion
Demonstrates an understanding of several of the following areas or has displayed a holistic understanding of a particular part and made contributions towards a more strategic goal
Has made a significant improvement or added an integration with services/technologies important to the Airflow Ecosystem
Actively participates in the security process, as a member of the security team, discussing, assessing and fixing security issues.
Demonstrates skills to maintain the complex codebase to ensure keeping maturity of product and complexity
Has been actively helping other contributors and users - in Slack, GitHub issues, GitHub discussions - by guiding their coding practices, reviewing their code and answering code-related questions
Note: As mentioned earlier, there may be exceptions for code contributions requirements for contributors who provide sustained, high-impact non-code contributions (for example, community leadership, outlining AIPs, etc.). Such exceptions are rare and chosen selectively, so contributors with coding skills who aim to become committers and PMC members are generally encouraged to follow the regular path.
Community contributions ^^^^^^^^^^^^^^^^^^^^^^^
triaging issues <ISSUE_TRIAGE_PROCESS.rst>_ showing their understanding
of various areas of Airflow and willingness to help other community members.Committer Responsibilities ^^^^^^^^^^^^^^^^^^^^^^^^^^
Committers are more than contributors. While it's important for committers to maintain standing by committing code, their key role is to build and foster a healthy and active community. This means that committers should:
To become a PMC member the committers should meet all general prerequisites. Apart from that the person should demonstrate distinct and sustained community involvement or code contributions.
Prerequisites ^^^^^^^^^^^^^
Community involvement ^^^^^^^^^^^^^^^^^^^^^
Visibility on discussions on the dev mailing list
Spreading the word for "Airflow" either:
Growing the community:
Is aware and pays attention to public image of Airflow
Code contribution ^^^^^^^^^^^^^^^^^
Consistent voting on release candidates for at least past 3 releases lifecycles
Engagement in Airflow Improvements Proposals either:
Actively involved in code contributions:
Only a current PMC member can nominate a current committer to be part of PMC.
If the vote fails or PMC members need more evidence, then one of the PMC Members (who is not the Proposer) can become the Mentor and guide the proposed candidates on how they can become a PMC member.
Candidate Proposer
This is the person who launches the DISCUSS thread & makes the case for a PMC member promotion
Candidate Mentor
If the committee does not have enough information, requires more time, or requires more evidence of candidate's eligibility, a mentor, who is not the proposer, is selected to help mentor the candidate The mentor should try to remain impartial -- their goal is to provide the missing evidence and to try to coach/mentor the candidate to success.
If you know you are not going to be able to contribute for a long time (for instance, due to a change of job or circumstances), you should inform the PMC and we will mark you as "inactive". Inactive committers will be removed from the "roster" on ASF and will no longer have the power of being a Committer (especially write access to the repos). As merit earned never expires, once you become active again you can simply email the PMC and ask to be reinstated.
The PMC also can mark committers as inactive after they have not been involved in the community for more than 12 months.
To be able to merge PRs, committers have to integrate their GitHub ID with Apache systems. To do that follow steps:
enabled with 2FA <https://help.github.com/articles/securing-your-account-with-two-factor-authentication-2fa/>__.GitBox (Apache Account Linking utility) <https://gitbox.apache.org/setup/>__. This also asks you to link your
GitHub ID to your Apache account. You should see 5 green checks in GitBox.Airflow committers team on GitHub <https://github.com/orgs/apache/teams/airflow-committers>__.Additionally, as a committer you can view the team membership at:
Ask in #internal-airflow-ci-cd channel to be
configured in self-hosted runners <https://github.com/apache/airflow-ci-infra/blob/main/scripts/list_committers>_
by the CI team. Wait for confirmation that this is done and some helpful tips from the CI team (Temporarily disabled)
After confirming that step 5 is done, open a PR to include your GitHub ID in:
dev/breeze/src/airflow_breeze/global_constants.py (COMMITTERS variable)project.rst <https://github.com/apache/airflow/blob/main/airflow-core/docs/project.rst>__..asf.yaml.Raise a PR to airflow-site <https://github.com/apache/airflow-site>_ repository with the following additions:
(A kind request: If there are other committers who joined around the same time, please create a unified PR for
all of you together.)
committers list <https://github.com/apache/airflow-site/blob/main/landing-pages/site/data/committers.json>__.Announcements <https://github.com/apache/airflow-site/blob/main/landing-pages/site/content/en/announcements/_index.md>__.Ask a release manager to make Slack announcement
<PMC Responsibilities>https://community.apache.org/pmc/responsibilities.html_[email protected]. Do this by sending an empty email to
[email protected] and following the instructions in the automated response you'll receive.#pmc-private channel on slacklanding-pages/site/data/committers.json
to the landing-pages/site/data/pmc.json. if more than one PMC member was added, coordinate with the others
to make a single PR for everyone.