Featureブランチにチェックアウトした後、上述の手順でNuGetパッケージの更新を行う。紙面の都合上、ここでは一括で行ったものとするが、すでにリリース済みのソフトウェアにパッケージの更新を行う場合、前述の通り、一つずつ慎重に更新するべきだ。
ブランチの運用としては、前述の通り、VS Onlineのリモート側にブランチを作成してからローカルにクローンする方法と、VSでローカルのブランチを作成してからリモートにプッシュしてマージするという方法がある。手順が少なくなるので、今回はローカルでブランチを作って、サーバーにプッシュ、マージを行う手順で紹介する。
作成したローカルのFeatureブランチでNuGetパッケージの更新を行い、以下の画面のようにチームエクスプローラーの[分岐]ページからサーバーに発行すると、サーバーにFeatureリポジトリが作成される。
[分岐]ページで[発行されていない分岐]メニューから[分岐の発行]をクリックすると、VS Onlineにブランチがプッシュされる。発行されたブランチは、VS Onlineでは[CODE]ページの[Branches]タブで確認できる(以下の画面)。
Webポータルでブランチの一覧を確認するとFeatureブランチが作成されていることを確認できる。
ブランチを頻繁に使うGitではマージも日常的に使われている。GitHubではプルリクエスト(pull request)も日常的に使用する重要な機能だ。ぜひ理解して使いこなそう。
プルリクエストとは、VS OnlineやGitHubのようにホスティングサービスがGitのプルの仕組みを使い、「外部のリポジトリに対して、自分のリポジトリで行った変更を受け入れてもらうように依頼する」という機能だ。
VS Online同様、Gitをサービス提供しているGitHubの場合、コミット権を持っていないリポジトリを自分のリポジトリにクローンしてからソースコードを編集し、元のリポジトリへプルリクエストを行い、編集結果をマージしてもらうといった運用が行われている。
VS Onlineでもブランチ単位でセキュリティを掛けられるので、masterブランチには特定のメンバー以外にコミット権を与えず、他のメンバーは必ずプルリクエストを作成してマージするという、GitHubと同じフローで運用を行うことが可能だ。
VS Onlineのチームプロジェクトのホームから右上にある歯車アイコンをクリックしてプロジェクトメニューを表示して、[Version Control]タブをクリックするとセキュリティの設定を行える。
具体的には上の画面の(3)にある[Contribute]の権限を[Deny]に設定すると、そのユーザーもしくはVSO Groupはクローンできるが、プッシュできなくなる。しかし、ローカルリポジトリにブランチを作成して、VS Onlineのリモートリポジトリへプッシュすることは可能なので、リモートリポジトリからのプルリクエストは可能になる。
しかし、どんなプルリクエストでも受け入れてしまっては問題が起きるので、ブランチ単位でプルリクエストを受け入れるポリシーを設定できるようになっている。これは上述の[Version Control]タブの[Branch Policies]タブで設定する。
ブランチポリシーとして設定可能な項目は「チームメンバーがプルリクエストを作成したとき、指定されたビルドを実行する」と、「コードレビューの最低人数の指定」だ。
さらに細かく、どの階層のソースで有効にする/特定のメンバーやグループを追加するなども指定可能だ。
特にレビューを厳しく実施したいとか、複数のチームに影響するような共通モジュールに対しては、そのコードと関係のありそうなメンバーをブランチポリシーのコードレビュワーに設定すればいいだろう。
プルリクエストはVSからは作成できないため、VS OnlineのWebポータルからプルリクエストを作成する必要がある。
[New Pull Request]ボタンをクリックすると、プルリクエストが作成され、それが右側のペーンに表示される。作成されたプルリクエストは自分のもの以外にも、リポジトリ単位で確認できる。対象のプルリクエストをダブルクリックすると、詳細画面が表示される。
競合が発生していない場合、ブラウザー上で[Complete Pull Request]ボタンを押すだけで、マージが完了する。競合が発生している場合、ローカルで競合を解決した上で、再度プッシュ/プルリクエストを行う。
競合が発生した場合、マージ先のブランチ(今回の場合はmasterブランチ)をプルして、ローカルのVSで競合を解決してから、再度VS Onlineにプッシュ、プルリクエストを作成しよう。
リモート側の修正を残すか、ローカル側の修正を残すか選択後、コミットおよび、同期を行えば、リモートリポジトリに変更が反映される。
ブランチやマージの履歴はVSでもVS Onlineでも参照できる。VS 2013では少し分かりづらいが、VS 2015ではProfessional Editionでも使用可能になったCode Lensと組み合わせることにより、視覚化が強化される。
最後にVS OnlineのGitチームプロジェクトにおけるブランチの特徴をまとめておこう。
次に、TFVCでブランチを作成する手順を見てみよう。
Copyright© Digital Advantage Corp. All Rights Reserved.