VisualStudioとGitHubを連携~Pull Requestまでの一連の流れと操作方法を解説します。
Contents
はじめに
この記事は、Visual Studio 2019をGitHubに連携させて使う方法を解説しています。
GitHubのアカウントが必要になるので、事前にアカウント作成しておいてください。
VisualStudioとGithubを連携する
GitHub連携プラグインをインストール
VisualStudio2019でツール → ツールと機能を取得 をクリック
data:image/s3,"s3://crabby-images/24e0b/24e0b3916ffbf8cc231494e520a1ce357462fa16" alt=""
個別のコンポーネントタブを選択、Visual Studio向けGitHub拡張にチェックして変更ボタンをクリック
検索窓でgitと入力すれば一発で出てくると思います。
data:image/s3,"s3://crabby-images/f1bcd/f1bcdfdb3399d76f5e108d7353d3dc56dd455c07" alt=""
GitHubに接続する
チームエクスプローラーの接続の管理→Connect to GitHubをクリック
data:image/s3,"s3://crabby-images/2ec48/2ec48f8bca2a4e793d030e77646fe0b649b09791" alt=""
ブラウザーでサインインしますをクリック
data:image/s3,"s3://crabby-images/380f0/380f021525ae2072b55a6ba7522370d72216c8ee" alt=""
Authorize githubをクリック
data:image/s3,"s3://crabby-images/714b1/714b1879697dfa6dabb418859de072917e580202" alt=""
GitHubアカウントのパスワードを入力してConfirm passwordをクリック
data:image/s3,"s3://crabby-images/dce60/dce60404b9a5efa1051ada4c382ff738ddc3bdc8" alt=""
開発の流れ
- まずは、開発するプロジェクトをローカルに作成します。
ローカルで一から作成しているのであれば、いいですが、
GitHubからプロジェクトを持ってくる際は、Cloneしてプロジェクトを持ってきてください。 - 実際修正を加える前にBranchを作成して、そっちに修正を入れましょう。
- 修正したら、Commitしましょう。こまめにやっておくのがよいですかね。
- 修正が完了したら、Pushしましょう。GitHubにUpするってことです。
- Pull Requestして、Masterに取り込んでもらいましょう。
- あとは、本番にDeployするなりしてください。
Clone ~ Push まで
Clone
プロジェクトがすでにローカルにある場合は、Clone不要です。
プロジェクトが無い場合で、GitHubから丸々持ってくる場合は、このCloneを実行してください。
VisualStudioではClone=複製と表記されています。
GitHubにアクセスし、CloneするリポジトリのURLをコピーします。
data:image/s3,"s3://crabby-images/592d2/592d2b6706e53863a29b6ff183ea1346180c2dd9" alt=""
VisualStudio2019側で、チームエクスプローラー→接続→GitHub→複製をクリック
data:image/s3,"s3://crabby-images/36aec/36aeca2876f415ddb11a0fd588ca7676718d55da" alt=""
GitHubでコピーしたリポジトリURLを貼り付けて複製をクリック
data:image/s3,"s3://crabby-images/5e77b/5e77b68426d287114fdda9864cfaf4ea4b4281c2" alt=""
Branchを作成
Masterに直修正するのではなく、Branchを作ってそっちに修正を入れておきましょう。Branchで修正が一通り終わったら、Masterに反映させます。
右下のmaster→新しいブランチをクリック
data:image/s3,"s3://crabby-images/fc136/fc1365bb26677db76707b174f6611da2d7fdfab9" alt=""
ブランチ名を入力して、ブランチの作成をクリック
data:image/s3,"s3://crabby-images/d93d5/d93d56ee041a054615b8b30c9ced69e97355a5ec" alt=""
右下の表示が先ほど入力したブランチ名になります。
data:image/s3,"s3://crabby-images/cda34/cda3494009f7bb87e6b5943f166cb713fee80c59" alt=""
Commit
修正が終わったら、一旦Commitしましょう。
VisualStudio2019ではCommit=変更と表記されます。
チームエクスプローラー→変更
data:image/s3,"s3://crabby-images/bebef/bebef00bed9c629224064c31eef22d8a48391e09" alt=""
変更した内容を記入して、すべてをコミットをクリック
data:image/s3,"s3://crabby-images/efa0c/efa0c6e57c45351c23431390c8de552ccde6e153" alt=""
以下のようなメッセージが表示されれば成功です。
data:image/s3,"s3://crabby-images/28926/289267a3eae2b3d4f9423e285fdd2d1125b32e57" alt=""
Push
先ほど変更した内容をGitHubに反映させます。
チームエクスプローラー→同期をクリック
data:image/s3,"s3://crabby-images/cedb8/cedb8fd230fcf12debf29cf1b3ffa594588c71b3" alt=""
プッシュをクリック
data:image/s3,"s3://crabby-images/f69d7/f69d774aebb2e143ef7440007fdc142bedc52705" alt=""
以下のようなメッセージが表示されれば成功です。
data:image/s3,"s3://crabby-images/3d0dc/3d0dcdc7ff3a78a027f30c61f2ca1976a50e8310" alt=""
Pull Request
変更した内容をmasterに反映してもらいます。
変更内容のレビューを依頼→問題なければ変更内容をMasterに反映、が一連の流れです。
VisualStudio側とGitHub側でそれぞれ作業が発生します。
VisualStudio2019側の作業
ソースをPushしたので、レビューしてMasterに反映(Pull)してください~ってことですね。
チームエクスプローラー→Pull Requestをクリック
data:image/s3,"s3://crabby-images/c9e32/c9e32f92073b604ff5b7abf27d959dc1e679df04" alt=""
新規作成をクリック
data:image/s3,"s3://crabby-images/6cd46/6cd46c668d74d260a334aa274454067274a970be" alt=""
メッセージを適当に記入して、pull requestの作成をクリック
data:image/s3,"s3://crabby-images/3b836/3b836fe69312227927dabe673f35b5395676371f" alt=""
これで、VisualStudio側の作業は完了です。
GitHub側の作業
Pull Requestを受けた人が、ソースの内容をチェックして、問題なければMasterに反映します。
GitHub側のPull requestsタブを見ると、先ほどのリクエストが来ていることがわかります。
data:image/s3,"s3://crabby-images/8ef68/8ef68c311b2e30452783074f2609e2c620456203" alt=""
変更内容をレビューしましょう。
Files changedタブをクリック。
data:image/s3,"s3://crabby-images/2c224/2c224a87f66af5dae3a056c78350cb8edd923eff" alt=""
レビューして問題なければViewedにチェック。
data:image/s3,"s3://crabby-images/69ba9/69ba9f734ef51efa77f148f10eae9fd8705fb30c" alt=""
Merge pull requestをクリック
data:image/s3,"s3://crabby-images/cbe33/cbe336707456689c7901447a1c33c5b76e5f9c96" alt=""
Confirm mergeをクリック
data:image/s3,"s3://crabby-images/d6180/d6180b3b8221d2cb20bbd464aee4ae5764071416" alt=""
成功しました。
data:image/s3,"s3://crabby-images/f97eb/f97eb5025eeb1a818ef3f9de982d8942017b89f8" alt=""
ブランチは不要なので削除します。
Delete branchをクリック
data:image/s3,"s3://crabby-images/91513/91513ede3224b1c77385a3e51b0ddcdb4aed101b" alt=""
成功しました。
data:image/s3,"s3://crabby-images/9ebb5/9ebb587333f600a34bdfb0555f3b06f1c3b52fae" alt=""
以上で一連の作業は終了です。お疲れ様でした!
data:image/s3,"s3://crabby-images/f708c/f708c4d6a9bf06880508ce4ee83ebd61fa7a0866" alt=""