2015-08-13 18:14:34 +02:00
|
|
|
# Node.js Project Governance
|
2015-01-02 12:52:50 +01:00
|
|
|
|
2018-01-20 14:09:17 +01:00
|
|
|
<!-- TOC -->
|
|
|
|
|
|
|
|
- [Collaborators](#collaborators)
|
|
|
|
- [Collaborator Activities](#collaborator-activities)
|
|
|
|
- [Technical Steering Committee](#technical-steering-committee)
|
|
|
|
- [TSC Meetings](#tsc-meetings)
|
|
|
|
- [Collaborator Nominations](#collaborator-nominations)
|
|
|
|
- [Onboarding](#onboarding)
|
|
|
|
- [Consensus Seeking Process](#consensus-seeking-process)
|
|
|
|
|
|
|
|
<!-- /TOC -->
|
|
|
|
|
2015-01-02 12:52:50 +01:00
|
|
|
## Collaborators
|
|
|
|
|
2019-04-03 17:43:54 +02:00
|
|
|
Node.js Core Collaborators maintain the [nodejs/node][] GitHub repository.
|
|
|
|
The GitHub team for Node.js Core Collaborators is @nodejs/collaborators. Their
|
|
|
|
privileges include but are not limited to:
|
2017-08-22 19:29:09 +02:00
|
|
|
|
2018-01-20 14:09:17 +01:00
|
|
|
* Commit access to the [nodejs/node][] repository
|
|
|
|
* Access to the Node.js continuous integration (CI) jobs
|
2015-01-02 12:52:50 +01:00
|
|
|
|
2019-04-05 20:26:37 +02:00
|
|
|
Both Collaborators and non-Collaborators may propose changes to the Node.js
|
|
|
|
source code. The mechanism to propose such a change is a GitHub pull request.
|
|
|
|
Collaborators are responsible for reviewing and merging (_landing_)
|
|
|
|
pull requests.
|
2018-08-10 23:49:21 +02:00
|
|
|
|
|
|
|
At least two Collaborators must approve a pull request before the pull request
|
2019-04-05 20:26:37 +02:00
|
|
|
can land. (One Collaborator approval is enough if the pull request has been open
|
2018-08-10 23:49:21 +02:00
|
|
|
for more than 7 days.) Approving a pull request indicates that the Collaborator
|
|
|
|
accepts responsibility for the change. Approval must be from Collaborators who
|
|
|
|
are not authors of the change.
|
2016-10-13 07:12:11 +02:00
|
|
|
|
2019-04-05 20:26:37 +02:00
|
|
|
If a Collaborator opposes a proposed change, then the change cannot land. The
|
|
|
|
exception is if the TSC votes to approve the change despite the opposition.
|
|
|
|
Usually, involving the TSC is unnecessary. Often, discussions or further changes
|
|
|
|
result in Collaborators removing their opposition.
|
2015-01-02 12:52:50 +01:00
|
|
|
|
2018-01-20 14:09:17 +01:00
|
|
|
See:
|
|
|
|
|
2017-06-03 01:27:54 +02:00
|
|
|
* [Current list of Collaborators](./README.md#current-project-team-members)
|
|
|
|
* [A guide for Collaborators](./COLLABORATOR_GUIDE.md)
|
2015-01-02 12:52:50 +01:00
|
|
|
|
2016-07-14 00:41:17 +02:00
|
|
|
### Collaborator Activities
|
|
|
|
|
2016-07-15 05:16:26 +02:00
|
|
|
Typical activities of a Collaborator include:
|
|
|
|
|
2018-01-20 14:09:17 +01:00
|
|
|
* Helping users and novice contributors
|
|
|
|
* Contributing code and documentation changes that improve the project
|
|
|
|
* Reviewing and commenting on issues and pull requests
|
|
|
|
* Participation in working groups
|
|
|
|
* Merging pull requests
|
2016-07-15 05:16:26 +02:00
|
|
|
|
2019-04-08 06:13:51 +02:00
|
|
|
The TSC can remove inactive Collaborators or provide them with _Emeritus_
|
|
|
|
status. Emeriti may request that the TSC restore them to active status.
|
2016-07-15 05:16:26 +02:00
|
|
|
|
2017-08-22 07:44:50 +02:00
|
|
|
## Technical Steering Committee
|
2017-06-03 01:27:54 +02:00
|
|
|
|
2018-02-17 01:18:09 +01:00
|
|
|
A subset of the Collaborators forms the Technical Steering Committee (TSC).
|
2018-01-20 14:09:17 +01:00
|
|
|
The TSC has final authority over this project, including:
|
2017-06-03 01:27:54 +02:00
|
|
|
|
|
|
|
* Technical direction
|
|
|
|
* Project governance and process (including this policy)
|
|
|
|
* Contribution policy
|
|
|
|
* GitHub repository hosting
|
|
|
|
* Conduct guidelines
|
2019-04-10 07:09:09 +02:00
|
|
|
* Maintaining the list of Collaborators
|
2017-06-03 01:27:54 +02:00
|
|
|
|
2019-04-10 07:09:09 +02:00
|
|
|
The current list of TSC members is in
|
2018-01-20 14:09:17 +01:00
|
|
|
[the project README](./README.md#current-project-team-members).
|
2017-06-03 01:27:54 +02:00
|
|
|
|
2019-04-10 07:09:09 +02:00
|
|
|
The [TSC Charter][] governs the operations of the TSC. All changes to the
|
|
|
|
Charter need approval by the Node.js Board of Directors.
|
2015-01-02 12:52:50 +01:00
|
|
|
|
2017-08-22 07:44:50 +02:00
|
|
|
### TSC Meetings
|
2015-01-02 12:52:50 +01:00
|
|
|
|
2019-04-12 20:19:06 +02:00
|
|
|
The TSC meets in a voice conference call. Each year, the TSC elects a chair to
|
|
|
|
run the meetings. The TSC streams its meetings for public viewing on YouTube or
|
|
|
|
a similar service.
|
2015-01-02 12:52:50 +01:00
|
|
|
|
2019-04-12 20:19:06 +02:00
|
|
|
The TSC agenda includes issues that are at an impasse. The intention of the
|
|
|
|
agenda is not to review or approve all patches. Collaborators review and approve
|
|
|
|
patches on GitHub.
|
2015-01-02 12:52:50 +01:00
|
|
|
|
2019-04-12 20:19:06 +02:00
|
|
|
Any community member can create a GitHub issue asking that the TSC review
|
|
|
|
something. If consensus-seeking fails for an issue, a Collaborator may apply the
|
|
|
|
`tsc-agenda` label. That will add it to the TSC meeting agenda.
|
2015-01-02 12:52:50 +01:00
|
|
|
|
2019-04-12 20:19:06 +02:00
|
|
|
Before each TSC meeting, the meeting chair will share the agenda with members of
|
|
|
|
the TSC. TSC members can also add items to the agenda at the beginning of each
|
|
|
|
meeting. The meeting chair and the TSC cannot veto or remove items.
|
2017-08-22 07:44:50 +02:00
|
|
|
|
2019-04-12 20:19:06 +02:00
|
|
|
The TSC may invite people to take part in a non-voting capacity.
|
2015-01-02 12:52:50 +01:00
|
|
|
|
2019-04-12 20:19:06 +02:00
|
|
|
During the meeting, the TSC chair ensures that someone takes minutes. After the
|
|
|
|
meeting, the TSC chair ensures that someone opens a pull request with the
|
|
|
|
minutes.
|
2015-01-02 12:52:50 +01:00
|
|
|
|
2019-04-12 20:19:06 +02:00
|
|
|
The TSC seeks to resolve as many issues as possible outside meetings using
|
2017-08-22 07:44:50 +02:00
|
|
|
[the TSC issue tracker](https://github.com/nodejs/TSC/issues). The process in
|
2016-10-06 05:55:56 +02:00
|
|
|
the issue tracker is:
|
|
|
|
|
2017-08-22 07:44:50 +02:00
|
|
|
* A TSC member opens an issue explaining the proposal/issue and @-mentions
|
|
|
|
@nodejs/tsc.
|
2019-04-12 20:19:06 +02:00
|
|
|
* The proposal passes if, after 72 hours, there are two or more TSC approvals
|
|
|
|
and no TSC opposition.
|
|
|
|
* If there is an extended impasse, a TSC member may make a motion for a vote.
|
2016-10-06 05:55:56 +02:00
|
|
|
|
2018-01-20 14:09:17 +01:00
|
|
|
## Collaborator Nominations
|
|
|
|
|
2019-04-15 08:28:18 +02:00
|
|
|
Existing Collaborators can nominate someone to become a Collaborator. Nominees
|
|
|
|
should have significant and valuable contributions across the Node.js
|
|
|
|
organization.
|
2018-01-20 14:09:17 +01:00
|
|
|
|
2019-04-15 08:28:18 +02:00
|
|
|
To nominate a new Collaborator, open an issue in the [nodejs/node][] repository.
|
|
|
|
Provide a summary of the nominee's contributions. For example:
|
2018-01-20 14:09:17 +01:00
|
|
|
|
|
|
|
* Commits in the [nodejs/node][] repository.
|
2019-04-17 20:32:41 +02:00
|
|
|
* Use the link `https://github.com/nodejs/node/commits?author=GITHUB_ID`
|
2018-01-20 14:09:17 +01:00
|
|
|
* Pull requests and issues opened in the [nodejs/node][] repository.
|
2019-04-17 20:32:41 +02:00
|
|
|
* Use the link `https://github.com/nodejs/node/issues?q=author:GITHUB_ID`
|
|
|
|
* Comments on pull requests and issues in the [nodejs/node][] repository
|
|
|
|
* Use the link `https://github.com/nodejs/node/issues?q=commenter:GITHUB_ID`
|
|
|
|
* Reviews on pull requests in the [nodejs/node][] repository
|
|
|
|
* Use the link `https://github.com/nodejs/node/pulls?q=reviewed-by:GITHUB_ID`
|
|
|
|
* Help provided to end users and novice contributors
|
|
|
|
* Pull requests and issues opened throughout the Node.js organization
|
|
|
|
* Use the link `https://github.com/search?q=author:GITHUB_ID+org:nodejs`
|
|
|
|
* Comments on pull requests and issues throughout the Node.js organization
|
|
|
|
* Use the link `https://github.com/search?q=commenter:GITHUB_ID+org:nodejs`
|
|
|
|
* Participation in other projects, teams, and working groups of the Node.js
|
|
|
|
organization
|
2018-01-20 14:09:17 +01:00
|
|
|
* Other participation in the wider Node.js community
|
|
|
|
|
|
|
|
Mention @nodejs/collaborators in the issue to notify other Collaborators about
|
|
|
|
the nomination.
|
|
|
|
|
|
|
|
If there are no objections raised by any Collaborators one week after
|
|
|
|
the issue is opened, the nomination will be considered as accepted.
|
|
|
|
Should there be any objections against the nomination, the TSC is responsible
|
|
|
|
for working with the individuals involved and finding a resolution.
|
|
|
|
The nomination must be approved by the TSC, which is assumed when there are no
|
|
|
|
objections from any TSC members.
|
|
|
|
|
|
|
|
Prior to the public nomination, the Collaborator initiating it can seek
|
|
|
|
feedback from other Collaborators in private using
|
|
|
|
[the GitHub discussion page][collaborators-discussions] of the
|
|
|
|
Collaborators team, and work with the nominee to improve the nominee's
|
|
|
|
contribution profile, in order to make the nomination as frictionless
|
|
|
|
as possible.
|
|
|
|
|
|
|
|
If individuals making valuable contributions do not believe they have been
|
|
|
|
considered for a nomination, they may log an issue or contact a Collaborator
|
|
|
|
directly.
|
|
|
|
|
|
|
|
### Onboarding
|
|
|
|
|
|
|
|
When the nomination is accepted, the new Collaborator will be onboarded
|
|
|
|
by a TSC member. See [the onboarding guide](./doc/onboarding.md) on
|
|
|
|
details of the onboarding process. In general, the onboarding should be
|
|
|
|
completed within a month after the nomination is accepted.
|
|
|
|
|
2015-01-02 12:52:50 +01:00
|
|
|
## Consensus Seeking Process
|
|
|
|
|
2018-10-30 18:42:09 +01:00
|
|
|
The TSC follows a [Consensus Seeking][] decision-making model as described by
|
2017-08-22 07:44:50 +02:00
|
|
|
the [TSC Charter][].
|
2015-01-02 12:52:50 +01:00
|
|
|
|
2018-01-20 14:09:17 +01:00
|
|
|
[collaborators-discussions]: https://github.com/orgs/nodejs/teams/collaborators/discussions
|
2017-11-23 00:01:19 +01:00
|
|
|
[Consensus Seeking]: https://en.wikipedia.org/wiki/Consensus-seeking_decision-making
|
2018-01-20 14:09:17 +01:00
|
|
|
[TSC Charter]: https://github.com/nodejs/TSC/blob/master/TSC-Charter.md
|
|
|
|
[nodejs/node]: https://github.com/nodejs/node
|