はじめに
社内でSubversionを使っていて、そろそろGitへ移行しようかな?との考えへ至りました。
そこで、移行の足掛かりとして、まずはGitに慣れてもらうためにgit-svnの運用を開始。
「git-svn。。。闇だな。。。」とか言わない。
元々社内全員がWindows環境なので、リポジトリの操作はTortoiseSVNで統一しています。
ということで、git-svnの操作も同じUIであるTortoiseGitを選択しました。
「社内全員がWindows環境。。。TortoiseSVNにTortoiseGit。。。闇だな。。。」とか言わない。
エンジニアメンバーについては、Subversion → git-svn → Gitと次々に移行しても説明さえしてしまえば、運用方法の差異やgit-svn特有の「git svn clone」、「git svn rebase」、「git svn dcommit」といったコマンドが「git clone」、「git pull」、「git push」と同じであるということはほぼ理解してもらえます。
しかし、非エンジニアなデザイナーにとって、このような急激な変化は受け入れられるでしょうか?
Subversionを社内に導入した時もかなりなインパクトだったみたいで、バージョン管理システムの仕組みを理解してもらうのもかなりの時間を要しました。というより、恐らくまだ完全には理解してもらえてないような気がします。
そこで、移行によって覚えてもらうことを減らすために、Subversion → git-svn → Gitではなく、Subversion → Gitのような環境を提供できないかと考え、その解決方法としてSourceTreeを利用してもらうことにしました。
ご存じの方もいらっしゃるかもしれませんが、SourceTreeはgit-svnのリポジトリを操作することが可能で、しかも、git-svn特有のコマンド(git svn rebaseやgit svn dcommitなどなど)が表に出てくることなく、あたかもGitとして振る舞ってくれます。これを利用しない手はありません。
これから何をやるの?
さて、前置きがかなり長くなってしまいましたが、ここではGit及びgit-svnの環境でマージ操作を行った場合に、コマンド(CUI)、TortoiseGit、SourceTreeで、それぞれどのような挙動の違いが発生するのかを見ていきたいと思います。
Git環境での検証前提と作業内容
- 中央リポジトリはGit。(今回の検証にはGitHubを利用しました)
- ローカルに「git clone」する。
- cloneした直後のmasterブランチからfeatureブランチ(ローカルブランチ)を作成する。
- featureブランチで3回コミットする。
- masterブランチでfeatureブランチのコミット内容をマージする。
- マージは「--ff(Fast-Forward)」と「--no-ff(Non Fast-Forward)」の両方のパターンを実行する。
- マージ後「git push」でGitに反映。
- Git側で増えたコミット数を確認。
Git環境での検証結果
ツール | コマンド | コマンド | TortoiseGit | TortoiseGit | SourceTree | SourceTree |
---|---|---|---|---|---|---|
Fast-Forward | --ff | --no-ff | --ff | --no-ff | --ff | --no-ff |
増えたコミット数 | 3 | 4 | 3 | 4 | 3 | 4 |
マージコミット | なし | あり | なし | あり | なし | あり |
上記の通り、Git環境下ではツールによって動作の差異はありませんでした。(当然か)
git-svn環境での検証前提と作業内容
- 中央リポジトリはSubversion。(今回の検証にはAssemblaを利用しました)
- ローカルに「git svn clone」する。
- cloneした直後のmasterブランチからfeatureブランチ(ローカルブランチ)を作成する。
- featureブランチで3回コミットする。
- masterブランチでfeatureブランチのコミット内容をマージする。
- マージは「--ff(Fast-Forward)」と「--no-ff(Non Fast-Forward)」の両方のパターンを実行する。
- マージ後「git svn dcommit」でSubversionに反映。
- Subversion側で増えたコミット数を確認。
git-svn環境での検証結果
ツール | コマンド | コマンド | TortoiseGit | TortoiseGit | SourceTree | SourceTree |
---|---|---|---|---|---|---|
Fast-Forward | --ff | --no-ff | --ff | --no-ff | --ff | --no-ff |
増えたコミット数 | 3 | 1 | 3 | 1 | 3 | 3 |
マージコミット | なし | あり | なし | あり | なし | なし |
Git環境と大きく異なるのは、「--no-ff」オプションの場合の挙動です。
Subversionのマージでは「--no-ff」が表現できないためか、マージコミット「のみ」を反映するようです。
もう一点、特筆すべきはSourceTreeの挙動で、「--ff」と「--no-ff」の動作に差異がありません。
このような動作に関連するか分かりませんが、SourceTreeでgit-svnのマージを行おうとすると、以下のような警告が表示されます。
ということは、git-svn環境でのマージをSourceTree自体があまりオススメしていないのかもしれません。
しかも、「--no-ff」の場合にマージコミットが作られないので、「SourceTreeを使うことであたかもGitとして振る舞ってくれる」という当初の目論見は外れてしまい、結局Gitとgit-svn環境で差異が出てしまうなーと気づいてしまいました。。。
おまけ
- TortoiseGitで「--ff」オプションによるマージ方法
- TortoiseGitで「--no-ff」オプションによるマージ方法
- SourceTreeで「--ff」オプションによるマージ方法
- SourceTreeで「--no-ff」オプションによるマージ方法