管理者あるいはオーナー権限を持つ人は、リポジトリ中に CODEOWNERS ファイルをセットアップできます。
コードオーナーに指定する人は、リポジトリへの書き込み権限を持っていなければなりません。 コードオーナーが Team である場合、Team の個々のメンバーが直接、書き込み権限を持っているときでも、Organization のメンバーであることまたは他の Team のメンバーであることを通じて、Team が書き込み権限を持っている必要があります。
コードオーナーについて
コードオーナーは、他者が所有するコードを変更するプルリクエストをオープンすると、自動的にレビューをリクエストされます。 コードオーナーはドラフトのプルリクエストのレビューを自動的にリクエストされません。 ドラフトのプルリクエストに関する詳しい情報については「プルリクエストについて」を参照してください。 コードオーナーはドラフトのプルリクエストのレビューを自動的にリクエストされません。 プルリクエストをドラフトに変換する場合、通知を既にサブスクライブしているユーザは自動的にサブスクライブ解除されません。 詳しい情報については、「プルリクエストのステージを変更する」を参照してください。
管理者あるいはオーナー権限を持つ誰かがレビュー必須を有効化した場合、作者がリポジトリ中でプルリクエストをマージできるための条件としてコードオーナーからの承認を必須とすることもできます。 詳しい情報については保護されたブランチについてを参照してください。
Team がコードレビューの割り当てを有効にしている場合、個々の承認は、保護されたブランチでのコードオーナーの承認要件を満たしません。 詳しい情報については、「Team のコードレビューの割り当てを管理する」を参照してください。
CODEOWNERSファイルの場所
CODEOWNERS ファイルを使うためには、コードオーナーを追加したいブランチで、リポジトリのルート、docs/、.github/ のいずれかのディレクトリに CODEOWNERS という新しいファイルを作成してください。
各CODEOWNERSファイルは、リポジトリ内の単一のブランチにコードオーナーを割り当てます。 したがって、デフォルトブランチのコードベースに @octo-org/codeowners-team、gh-pages ブランチの GitHub Pages サイトに @octocat など、ブランチごとに異なるコードオーナーを割り当てることができます。
コードオーナーがレビューのリクエストを受け取るためには、CODEOWNERS ファイルがプルリクエストの base ブランチになければなりません。 たとえばリポジトリ中のgh-pagesブランチの、.jsファイルのコードオーナーとして@octocatを割り当てたなら、.jsに変更を加えるプルリクエストがheadブランチとgh-pagesの間でオープンされると、@octocatはレビューのリクエストを受けることになります。
CODEOWNERSの構文
CODEOWNERS ファイルは、一部の例外を除いて、gitignore ファイルで使用されるルールのほとんどに従うパターンを使用します。 パターンの後には1つ以上のGitHubのユーザー名あるいはTeam名が続きます。これらの名前には標準の@usernameあるいは@org/team-nameフォーマットが使われます。 たとえば user@example.com のような、ユーザの GitHub Enterprise Server アカウントに追加されたメールアドレスでユーザを参照することもできます。
CODEOWNERS ファイルのいずれかの行に無効な構文が含まれている場合、そのファイルは検出されず、レビューのリクエストには使用されません。
CODEOWNERS ファイルの例
# これはコメントです。 # 各行はファイルパターンの後に一人以上のオーナーが続きます。 # これらのオーナーは、リポジトリ中のすべてに対する # デフォルトのオーナーになります。 後のマッチが優先されないかぎり、 # 誰かがプルリクエストをオープンすると、 # @global-owner1と@global-owner2にはレビューがリクエストされます。 * @global-owner1 @global-owner2 # 順序は重要です。最後にマッチしたパターンが最も # 高い優先度を持ちます。 誰かがJSファイルだけを変更する # プルリクエストをオープンすると、@js-ownerだけにレビューが # リクエストされ、グローバルのオーナーにはリクエストされません。 *.js @js-owner # メールアドレスの方が良ければ、そちらを使うこともできます。 それらは # コミット作者のメールの場合と同じようにユーザの # ルックアップに使われます。 *.go docs@example.com # この例では、@doctocatはリポジトリのルートにある # build/logs及びそのサブディレクトリ内のすべてのファイルの # オーナーです。 /build/logs/ @doctocat # `docs/*`パターンは`docs/getting-started.md`のようなファイルには # マッチしますが、それ以上にネストしている # `docs/build-app/troubleshooting.md`のようなファイルにはマッチしません。 docs/* docs@example.com # この例では、@octocatはリポジトリ中のあらゆる場所にある # appsディレクトリ内のすべてのファイルのオーナーになります。 apps/ @octocat # この例では、@doctocatはリポジトリのルートにある # `/docs` ディレクトリとそのサブディレクトリにある # ファイルを所有しています。 /docs/ @doctocat 構文の例外
gitignore ファイルには、CODEOWNERS ファイルでは動作しないいくつかの構文ルールがあります。
- Escaping a pattern starting with
#using\so it is treated as a pattern and not a comment !を使用してパターンを否定する[ ]を使用して文字範囲を定義する