diff --git a/teams/README.md b/teams/README.md new file mode 100644 index 00000000..1f10fe08 --- /dev/null +++ b/teams/README.md @@ -0,0 +1,80 @@ +# Teams + +This folder holds all teams in the TiDB projects. This document defines governance policies of the teams. + +Teams are persistent open groups that focus on a part of the TiDB projects. A team has its reviewer, committer and maintainer, and owns one or more repositories. Team level decision making comes from its maintainers. + +The [Technical Oversight Committee (TOC)](/toc/README.md) is in charge of team creation and retirement, and arbitrates divergence between team. But TOC members don't participant team level decision making directly. + +## Roles and Responsibilities + +### Reviewers + +Reviewers are individuals who actively make contribution and are willing to participate in the code review of new contributions. We identify reviewers from active contributors. The committers should explicitly solicit reviews from reviewers. High-quality code reviews prevent technical debt for long-term and are crucial to the success of the project. A pull request to the project has to be reviewed by at least one reviewer in order to be merged. + +Review access is by invitation only and must be approved by consensus of the maintainers. A reviewer is considered emeritus by their own declaration. An emeritus reviewer may request reinstatement of review access from the maintainers, which will be sufficient to restore him or her to active reviewer status. + +Review access can be revoked by consensus by the maintainers. + +### Committers + +Committers are individuals who are granted the write access to the repositories belong to the team. A committer is usually responsible for a certain area or several areas of the code where they oversee the code review process. The area of contribution can take all forms, including code contributions and code reviews, documents, education, and outreach. Committers are essential for a high quality and healthy project. + +Commit access is by invitation only and must be approved by consensus of the maintainers. A committer is considered emeritus by their own declaration. An emeritus committer may request reinstatement of commit access from the maintainers, which will be sufficient to restore him or her to active committer status. + +Commit access can be revoked by consensus by the maintainers. + +### Maintainers + +The maintainers consist group of active committers that moderate the discussion, manage the project release, and proposes new committers or maintainers. Potential candidates are usually proposed via an internal discussion among maintainers, followed by a consensus approval, i.e. a concrete number of approvals, and no vetoes. Any veto must be accompanied by reasoning. Maintainers should serve the community by upholding the community practices and guidelines TiDB a better community for everyone. Maintainers should nominate new reviewer, committers and maintainers, and should also strive to only nominate new candidates outside of their own organization. + +Membership of the maintainers is by invitation only and must be approved by a consensus of the maintainers. A maintainer is considered emeritus by their own declaration. An emeritus member may request reinstatement to the maintainers, which will be sufficient to restore him or her to active maintainers. + +Membership of the maintainers can be revoked by a consensus vote of all the maintainers other than the member in question. + +## Decision Making + +Within the teams, different types of decisions require different forms of approval. For example, the previous section describes several decisions which require 'consensus' approval. This section defines how voting is performed, the types of approvals, and which types of decision require which type of approval. + +### Voting + +Decisions regarding the project are made by votes on [the community repository](https://github.com/pingcap/community). Votes are clearly indicated by a pull request adding an entry under [votes](/votes/README.md) folder. Votes may contain multiple items for approval and these should be clearly separated. Voting is carried out by replying to the vote pull request. Voting may take three flavors + +* **+1**: 'Yes,' 'Agree,' or 'the action should be performed.' +* **0**: Neutral about the proposed action (or mildly negative but not enough so to want to block it). +* **-1**: This is a negative vote. On issues where consensus is required, this vote counts as a veto. All vetoes must contain an explanation of why the veto is appropriate. Vetoes with no explanation are void. It may also be appropriate for a -1 vote to include an alternative course of action. + +All participants in the TiDB community are encouraged to show their agreement with or against a particular action by voting. For team decisions, only the votes of active team maintainers are binding. Non-binding votes are still useful for those with binding votes to understand the perception of an action in the wider community. + +Only active (i.e. non-emeritus) maintainers have binding votes. + +### Approvals + +These are three types of approvals that can be sought. Different actions require different types of approvals. + +* **Consensus**: Consensus requires 2 binding +1 votes and no binding vetoes. +* **Lazy Majority**: A lazy majority vote requires 2 binding +1 votes and more binding +1 votes than -1 votes. +* **2/3 Majority**: Some actions require a 2/3 majority to pass. Such actions typically affect the foundation of the project (e.g. adopting a new codebase). The higher threshold is designed to ensure such changes are strongly supported. To pass this vote requires at least 2/3 of binding vote holders to vote +1. + +> In order to address the case of insufficient active binding voters to reach 2/3 majority, one can follow the process below to exclude a binding vote from the counting of this particular voting thread. +> +> 1. Wait until the minimum length of the voting passes. +> 2. Publicly reach out via mentioned to the remaining binding voters in the voting pull request for at least 2 attempts with at least 7 days between two attempts. +> 3. If the binding voter being contacted still failed to respond after all the attempts, the binding voter will be considered as inactive for the purpose of this particular voting. + +### Vetoes + +A valid, binding veto cannot be overruled. If a veto is cast, it must be accompanied by a valid reason explaining the reasons for the veto. The validity of a veto, if challenged, can be confirmed by anyone who has a binding vote. This does not necessarily signify agreement with the veto - merely that the veto is valid. + +If you disagree with a valid veto, you must lobby the person casting the veto to withdraw their veto. If a veto is not withdrawn, the action that has been vetoed must be reversed in a timely manner. + +### Actions + +| Actions | Description | Approval | Binding Voters | Minimum Length (days) | +| :----------------- | :---------------------------------------------- | :------------ | :----------------- | :-------------------- | +| New Reviewer | When a new reviewer is proposed for the team. | Lazy Majority | Active maintainers | 3 | +| New Committer | When a new committer is proposed for the team. | Consensus | Active maintainers | 6 | +| New Maintainer | When a new maintainer is proposed for the team. | Consensus | Active maintainers | 6 | +| Reviewer Removal | When removal of review privileges is sought. | Consensus | Active maintainers | 6 | +| Committer Removal | When removal of commit privileges is sought. | Consensus | Active maintainers | 6 | +| Maintainer Removal | When removal of maintain privileges is sought. | Consensus | Active maintainers | 6 | diff --git a/teams/bigdata/README.md b/teams/bigdata/README.md new file mode 100644 index 00000000..e0402a84 --- /dev/null +++ b/teams/bigdata/README.md @@ -0,0 +1,14 @@ +# BigData Team + +This team works for connecting TiDB with Big Data ecosystem. + +## Members + +See [membership.json](membership.json) + +## Repositories + +* [tispark](https://github.com/pingcap/tispark) +* [tispark-test](https://github.com/pingcap/tispark-test) +* [tispark-test-data](https://github.com/pingcap/tispark-test-data) +* [tidb-incubator/TiBigData](https://github.com/tidb-incubator/TiBigData) diff --git a/teams/bigdata/membership.json b/teams/bigdata/membership.json new file mode 100644 index 00000000..843d7e40 --- /dev/null +++ b/teams/bigdata/membership.json @@ -0,0 +1,21 @@ +{ + "_comment": [ + "Items of lists in this file are in alphabetical order. Please keep it on modification." + ], + + "maintainers": [ + "birdstorm", + "humengyu2012", + "marsishandsome", + "sunxiaoguang" + ], + + "committers": [ + "Coderlxl", + "LittleFall", + "ilovesoup", + "windtalker" + ], + + "reviewers": [] +} diff --git a/teams/diagnostic/README.md b/teams/diagnostic/README.md new file mode 100644 index 00000000..f5ecedc5 --- /dev/null +++ b/teams/diagnostic/README.md @@ -0,0 +1,11 @@ +# Diagnostic Team + +This team works for improving the observability and diagnostic experience of TiDB projects. + +## Members + +See [membership.json](membership.json) + +## Repositories + +* [tidb-dashboard](https://github.com/pingcap/tidb-dashboard) diff --git a/teams/diagnostic/membership.json b/teams/diagnostic/membership.json new file mode 100644 index 00000000..d1a9bf87 --- /dev/null +++ b/teams/diagnostic/membership.json @@ -0,0 +1,24 @@ +{ + "_comment": [ + "Items of lists in this file are in alphabetical order. Please keep it on modification." + ], + + "maintainers": [ + "HunDunDM", + "baurine", + "breeswish" + ], + + "committers": [ + "Deardrops", + "zhongzc", + "crazycs520", + "iosmanthus", + "shhdgit" + ], + + "reviewers": [ + "Fullstop000", + "Renkai" + ] +} diff --git a/teams/docs/README.md b/teams/docs/README.md new file mode 100644 index 00000000..6f7c72df --- /dev/null +++ b/teams/docs/README.md @@ -0,0 +1,14 @@ +# Docs Team + +This team works for documentation of TiDB projects. + +## Members + +See [membership.json](membership.json) + +## Repositories + +* [docs](https://github.com/pingcap/docs) +* [docs-cn](https://github.com/pingcap/docs-cn) +* [docs-dm](https://github.com/pingcap/docs-dm) +* [docs-tidb-operator](https://github.com/pingcap/docs-tidb-operator) diff --git a/teams/docs/membership.json b/teams/docs/membership.json new file mode 100644 index 00000000..05e64126 --- /dev/null +++ b/teams/docs/membership.json @@ -0,0 +1,59 @@ +{ + "_comment": [ + "Items of lists in this file are in alphabetical order. Please keep it on modification." + ], + + "maintainers": [ + "TomShawn", + "lilin90", + "qiancai", + "yikeke" + ], + + "committers": [ + "CaitinChen", + "CharLotteiu", + "DanielZhangQD", + "Liuxiaozhen12", + "SunRunAway", + "WangXiangUSTC", + "YiniXu9506", + "breeswish", + "cofyc", + "csuzhangxc", + "dcalvin", + "dragonly", + "jackysp", + "kissmydb", + "lance6716", + "lichunzhu", + "morgo", + "nullnotnil", + "overvenus", + "queenypingcap", + "ran-huang", + "tangenta", + "toutdesuite" + ], + + "reviewers": [ + "3pointer", + "GMHDBJD", + "Joyinqin", + "Yisaer", + "amyangfei", + "anotherrachel", + "aylei", + "crazycs520", + "dveeden", + "ericsyh", + "glkappe", + "junlan-zhang", + "lucklove", + "lysu", + "superlzs0476", + "tiancaiamao", + "weekface", + "zimulala" + ] +} diff --git a/teams/kubernetes/README.md b/teams/kubernetes/README.md new file mode 100644 index 00000000..7597faad --- /dev/null +++ b/teams/kubernetes/README.md @@ -0,0 +1,15 @@ +# Deployment Team + +This team works for Kubernetes and Docker integration. + +* Supporting new features or improving performance for TiDB Products on Kubernetes and Docker. +* Supporting TiDB ecosystem tools integrated natively with TiDB on Kubernetes. + +## Members + +See [membership.json](membership.json) + +## Repositories + +* [tidb-operator](https://github.com/pingcap/tidb-operator) +* [advanced-statefulset](https://github.com/pingcap/advanced-statefulset) diff --git a/teams/kubernetes/membership.json b/teams/kubernetes/membership.json new file mode 100644 index 00000000..2f48d6eb --- /dev/null +++ b/teams/kubernetes/membership.json @@ -0,0 +1,38 @@ +{ + "_comment": [ + "Items of lists in this file are in alphabetical order. Please keep it on modification." + ], + + "maintainers": [ + "DanielZhangQD", + "csuzhangxc" + ], + + "committers": [ + "AstroProfundis", + "LinuxGit", + "Yisaer", + "aylei", + "cofyc", + "dragonly", + "gregwebs", + "handlerww", + "jlerche", + "july2993", + "mikechengwei", + "onlymellb", + "qiffang", + "sdojjy", + "shuijing198799", + "tennix", + "weekface" + ], + + "reviewers": [ + "KanShiori", + "cvvz", + "howardlau1999", + "lichunzhu", + "shonge" + ] +} diff --git a/teams/migration/README.md b/teams/migration/README.md new file mode 100644 index 00000000..2cc0218c --- /dev/null +++ b/teams/migration/README.md @@ -0,0 +1,14 @@ +# Migration Team + +This team works for migration, replication, synchronization and transmission of data into and out of the TiDB ecosystem. + +## Members + +See [membership.json](membership.json) + +## Repositories + +* [ticdc](https://github.com/pingcap/ticdc) +* [dm](https://github.com/pingcap/dm) +* [dumpling](https://github.com/pingcap/dumpling) +* [tidb-binlog](https://github.com/pingcap/tidb-binlog) diff --git a/teams/migration/membership.json b/teams/migration/membership.json new file mode 100644 index 00000000..d344645f --- /dev/null +++ b/teams/migration/membership.json @@ -0,0 +1,44 @@ +{ + "_comment": [ + "Items of lists in this file are in alphabetical order. Please keep it on modification." + ], + + "maintainers": [ + "amyangfei", + "kennytm", + "lance6716" + ], + + "committers": [ + "3pointer", + "5kbpers", + "Ehco1996", + "GMHDBJD", + "IANTHEREAL", + "Leavrth", + "Little-Wallace", + "WangXiangUSTC", + "YuJuncen", + "csuzhangxc", + "glorv", + "holys", + "july2993", + "leoppro", + "lichunzhu", + "liuzix", + "lonng", + "overvenus", + "suzaku", + "zwj-coder" + ], + + "reviewers": [ + "3AceShowHand", + "asddongmen", + "ben1009", + "gozssky", + "hi-rustin", + "iamxy", + "tiancaiamao" + ] +} diff --git a/teams/postgresql/README.md b/teams/postgresql/README.md new file mode 100644 index 00000000..72878259 --- /dev/null +++ b/teams/postgresql/README.md @@ -0,0 +1,15 @@ +# PostgreSQL Team + +This team works for integration between TiDB and PostgreSQL protocol. + +More details can be found in the [Design Document](https://github.com/DigitalChinaOpenSource/TiDB-for-PostgreSQL/blob/main/DESIGN_DOCUMENT.md) + +## Members + +See [membership.json](membership.json) + +## Repositories + +* [DigitalChinaOpenSource/TiDB-for-PostgreSQL](https://github.com/DigitalChinaOpenSource/TiDB-for-PostgreSQL) +* [DigitalChinaOpenSource/DCParser](https://github.com/DigitalChinaOpenSource/DCParser) +* [DigitalChinaOpenSource/dcbr](https://github.com/DigitalChinaOpenSource/dcbr) diff --git a/teams/postgresql/membership.json b/teams/postgresql/membership.json new file mode 100644 index 00000000..88596630 --- /dev/null +++ b/teams/postgresql/membership.json @@ -0,0 +1,21 @@ +{ + "_comment": [ + "Items of lists in this file are in alphabetical order. Please keep it on modification." + ], + + "maintainers": [ + "RogueJin", + "pupillord" + ], + + "committers": [ + "AmoebaProtozoa", + "MichaelYuAlreadyExists", + "Orion7r", + "guoshengcc", + "hey-hoho", + "studiolee" + ], + + "reviewers": [] +} diff --git a/teams/tidb/README.md b/teams/tidb/README.md new file mode 100644 index 00000000..e4089ca8 --- /dev/null +++ b/teams/tidb/README.md @@ -0,0 +1,28 @@ +# TiDB Team + +This team works for the sql engine of TiDB, and multiple utilities. + +## Members + +See [membership.json](membership.json) + +## Repositories + +* [tidb](https://github.com/pingcap/tidb) +* [parser](https://github.com/pingcap/parser) +* [br](https://github.com/pingcap/br) +* [kvproto](https://github.com/pingcap/kvproto) +* [tipb](https://github.com/pingcap/tipb) +* [errcode](https://github.com/pingcap/errcode) +* [check](https://github.com/pingcap/check) +* [badger](https://github.com/pingcap/badger) +* [errors](https://github.com/pingcap/errors) +* [log](https://github.com/pingcap/log) +* [failpoint](https://github.com/pingcap/failpoint) +* [fn](https://github.com/pingcap/fn) +* [sysutil](https://github.com/pingcap/sysutil) +* [tidb-tools](https://github.com/pingcap/tidb-tools) +* [sqlalchemy-tidb](https://github.com/pingcap/sqlalchemy-tidb) +* [django-tidb](https://github.com/pingcap/django-tidb) +* [activerecord-tidb-adapter](https://github.com/pingcap/activerecord-tidb-adapter) +* [tidb-dev-guide](https://github.com/pingcap/tidb-dev-guide) diff --git a/teams/tidb/membership.json b/teams/tidb/membership.json new file mode 100644 index 00000000..1b484388 --- /dev/null +++ b/teams/tidb/membership.json @@ -0,0 +1,97 @@ +{ + "_comment": [ + "Items of lists in this file are in alphabetical order. Please keep it on modification." + ], + + "maintainers": [ + "XuHuaiyu", + "amyangfei", + "bb7133", + "breeswish", + "c4pt0r", + "cfzjywxk", + "coocood", + "disksing", + "jackysp", + "kennytm", + "lance6716", + "lonng", + "ngaut", + "qiuyesuifeng", + "qw4990", + "shenli", + "siddontang", + "tangenta", + "tiancaiamao", + "winkyao", + "winoros", + "zimulala", + "zz-jason" + ], + + "committers": [ + "3pointer", + "AilinKid", + "Deardrops", + "Ehco1996", + "GMHDBJD", + "Leavrth", + "Little-Wallace", + "MyonKeminta", + "Reminiscent", + "SunRunAway", + "Yisaer", + "YuJuncen", + "andylokandy", + "b41sh", + "crazycs520", + "djshow832", + "eurekaka", + "francis0407", + "fzhedu", + "glorv", + "hanfei1991", + "ichn-hu", + "imtbkcat", + "lichunzhu", + "liuzix", + "lysu", + "lzmhhh123", + "mmyj", + "morgo", + "nrc", + "overvenus", + "rebelice", + "sticnarf", + "wjhuang2016", + "wshwsh12", + "xhebox", + "xiongjiwei", + "youjiali1995", + "zhouqiang-cl", + "zwj-coder" + ], + + "reviewers": [ + "JmPotato", + "Tjianke", + "TszKitLo40", + "bobotu", + "gozssky", + "guo-shaoge", + "hi-rustin", + "js00070", + "lamxTyler", + "lcwangchao", + "nolouch", + "pingyu", + "shihongzhi", + "spongedu", + "tangwz", + "time-and-fate", + "tsthght", + "xuyifangreeneyes", + "zhangjinpeng1987", + "zhuo-zhi" + ] +} diff --git a/teams/tiup/README.md b/teams/tiup/README.md new file mode 100644 index 00000000..d2ef6b69 --- /dev/null +++ b/teams/tiup/README.md @@ -0,0 +1,11 @@ +# Deployment Team + +This team works for TiUP, a tool to download and install TiDB components. + +## Members + +See [membership.json](membership.json) + +## Repositories + +* [tiup](https://github.com/pingcap/tiup) diff --git a/teams/tiup/membership.json b/teams/tiup/membership.json new file mode 100644 index 00000000..77d1eca0 --- /dev/null +++ b/teams/tiup/membership.json @@ -0,0 +1,23 @@ +{ + "_comment": [ + "Items of lists in this file are in alphabetical order. Please keep it on modification." + ], + + "maintainers": [ + "AstroProfundis", + "lucklove", + "nexustar" + ], + + "committers": [ + "9547", + "july2993", + "lonng", + "nrc" + ], + + "reviewers": [ + "birdstorm", + "breeswish" + ] +} diff --git a/votes/README.md b/votes/README.md new file mode 100644 index 00000000..879aed16 --- /dev/null +++ b/votes/README.md @@ -0,0 +1,3 @@ +# Votes + +This folder holds all votes proposed in TiDB community. diff --git a/votes/TEMPLATE.md b/votes/TEMPLATE.md new file mode 100644 index 00000000..349c0bc2 --- /dev/null +++ b/votes/TEMPLATE.md @@ -0,0 +1,13 @@ +# A Vote for My Proposal + +## Proposal + +Replace this content with the proposal. + +## Deadline + +The vote will be open for at least {duration} unless there is an objection or not enough votes. + +## Result + +Conclude the voting result, including approvals and vetoes, binding and non-binding.