GitLabで資産管理を行う場合に、一般的に設定を行う項目・機能について整理する。
尚、本資料はFree版で可能な設定・機能のみとする。
アカウント管理
GitLabのアカウントはユーザ毎に権限設定を行う必要がある。
通常、GitLab全体のユーザ管理では以下の2種類の権限を設定する。
- 管理者(Administrator):GitLab管理者
- 標準(Regular):GitLab管理者以外の全ユーザ
次にグループやプロジェクトに対するアクセス権限をユーザ毎に設定する必要がある。
通常、以下の3種類の権限を設定する。
- Maintainer:マージリクエストの承認者・レビュー者
- Developer:開発担当者
- Reporter:参照のみの担当者(PMOメンバ等)
尚、プロジェクト毎に設定を行うのは面倒なため、チーム毎にグループを作成し、そのグループ配下でプロジェクトを管理する。
権限設定はプロジェクトではなくグループに対して行い、プロジェクト追加時やメンバの追加・削除時にプロジェクト数分設定を行う必要がなくなる。
GitLab全体設定
Self-ManagedのGitLabの場合にはインスタンス全体に対して以下の設定が可能。
ここで設定した内容は全グループ・プロジェクトに適用される。尚、適用された内容をグループとプロジェクトで別設定をした場合はプロジェクト > サブグループ > グループ > GitLab全体
の順で上書きされる。
デフォルトブランチ(GitLab全体)
GitLab全体のデフォルトブランチの設定とそのブランチに対する保護設定をすることが可能。
プロジェクト追加時にはこの設定が反映される。
外部連携(GitLab全体)
Teams、Slack等のツール連携を設定することが可能。
下記例はTeamsへのGitLabイベントの通知を行っている設定。
何をトリガーとするか設定も可能。
GitLab Runner(GitLab全体)
GitLab CI/CDを使用する場合にパイプラインを実行するRunnerを設定する必要がある。
グループ設定
グループに設定した内容はその配下の全てのサブグループとプロジェクトに適用される。尚、適用された内容をサブグループとプロジェクトで別設定をした場合はサブグループ・プロジェクト > グループ
の順で上書きされる。
デフォルトブランチ(グループ)
GitLab全体の設定内容と同じ。
プロテクトタグ(グループ)
プロテクトタグの設定とそのタグを作成可能な権限を設定することが可能。
正規表現で指定することができる。
外部連携(グループ)
GitLab全体の設定内容と同じ。
マイルストーン(グループ)
issueとマージリクエストを紐づけて管理することができる。
例えば、Ver1.0.0対応という開発イベントをマイルストーンとして定義し、その対応となるisseuとマージリクエストをマイルストーンに紐づけることで、Ver1.0.0として対応中・対応完了したissueとマージリクエストを確認することが可能。
マイルストーンを以下のように設定。
マイルストーンに関連するissueとマージリクエストの状態を確認可能。
ラベル(グループ)
issueやマージリクエストの入力項目をカスタマイズすることはできないが、ラベルをissueやマージリクエストに設定することで代替することが可能となる。
例えば、優先度やステータスといったプロジェクトとして管理したい項目をラベルとして定義し、issueやマージリクエストに設定する。
ラベルを以下のように定義。
issueにラベルを設定すると以下のように見える。ラベル名を選択してフィルタすることも可能。
プロジェクト設定
プロジェクトで個別に設定したものが最終的な設定となるが、何も個別に設定しない場合には上位のグループやGitLab全体の設定が適用される。
デフォルトブランチ(プロジェクト)
GitLab全体の設定内容と同じ。
プロテクトブランチ(プロジェクト)
プロテクトブランチの設定とそのブランチに対してマージ、直接プッシュが可能な権限を設定することが可能。
一般的にはプロテクトブランチは必ずマージリクエストでのみ更新を許可し、その権限はMaintainers
と設定する。
また、強制プッシュを許可するかどうかも設定できるが、これは基本オフとする。
対象となるブランチは正規表現で指定することができる。
プロテクトタグ(プロジェクト)
グループの設定内容と同じ。
外部連携(プロジェクト)
GitLab全体の設定内容と同じ。
マージリクエストチェック(プロジェクト)
マージリクエストでのチェックルールを設定することが可能。
パイプラインがある場合にはそのパイプラインが成功しなければマージできないようにする設定が可能。(パイプラインがない場合には本設定は無効化しておく)
また、マージリクエストでレビューアが記入したコメント(スレッド)を全て解決済みにしないとマージができないようにする設定も可能。
基本的には両方とも設定を有効にする。
尚、Premium/Ulitimate版の場合にはマージリクエストの承認・マージ可能なユーザをユーザ個別で指定したり、何人以上承認しないとマージできないといった設定が可能となる。
マイルストーン(プロジェクト)
グループの設定内容と同じ。
ラベル(プロジェクト)
グループの設定内容と同じ。
テンプレート(プロジェクト)
以下の通りプロジェクト直下に.gitlab
というディレクトリを作成し、その配下にマークダウンファイルを格納することでissueとマージリクエストのテンプレートとして使用可能となる。
プロジェクトとして何をissueやマージリクエストに記載するべきなのか整理し、それをテンプレート化する。
- issue_templates配下:isseuのテンプレート
- merge_request_templates配下:マージリクエストのテンプレート
.gitlab/
├─issue_templates/ ※issueのテンプレート
│ 1_task.md
│ 2_add_feature.md
│ 3_change_require.md
│ 4_bug.md
│ 5_request.md
│ 6_qa.md
│ 7_etc.md
│
└─merge_request_templates/ ※マージリクエストのテンプレート
merge_request.md
issue起票・編集時にテンプレートとして登録したものを選択可能となる。
選択するとテンプレートの内容が反映されるため、後は適宜issueを更新する。
マージリクエスト起票・編集時にテンプレートとして登録したものを選択可能となる
選択するとテンプレートの内容が反映されるため、後は適宜マージリクエストを更新する