<目次>
(1) Azure DevOpsの使い方についてご紹介
やりたいこと
概要
(1-1) STEP1:リポジトリを作る
(1-2) STEP2:クローン~ブランチ作成~修正~コミット&プッシュ
(1-3) STEP3:プルリクエスト~マージ
エラー対処①:fatal: cannot lock ref ‘HEAD’: is at xxx but expected yy
(1) Azure DevOpsの使い方についてご紹介
やりたいこと
・Azure DevOpsのリポジトリ上に資産を登録したり、他の人がブランチを切ってプルリクエストを出す手順を素早く押さえる。
概要
・「Azure DevOps」(開発と運用を密に連携して進める為のツール)の基本的な使い方を知る(Repository作成、資産のプッシュ・ブランチ作成・プルリクエストなど)
(前提条件)
・Azure DevOpsの環境が使えること
・Visual Studio Codeが使用可能であること
(1-1) STEP1:リポジトリを作る
・①「New Repository」押下
(図111)
data:image/s3,"s3://crabby-images/8cd79/8cd79efc158633f31d86589857ed4a2853095769" alt=""
↓
・②リポジトリ名などを入力
(図112)
(備考)
.gitignoreファイルは、Gitによって追跡されるべきでないファイルやディレクトリを指定するためのファイルであり、開発者が手動で作成する必要があります。しかし、Azure DevOpsはリポジトリ作成時に一般的なプログラミング言語やフレームワークに基づいたデフォルトの.gitignoreファイルを作成できます。
(1-2) STEP2:クローン~ブランチ作成~修正~コミット&プッシュ
※Gitの使い方の流れについて知りたい方は下記記事を参照
●STEP2-1:Gitクローン
・①「Clone」を押下
(図121①)
data:image/s3,"s3://crabby-images/9034d/9034d9f382bfe9cefa6199c3cb0325ceee55e0fa" alt=""
↓
・②Cloneの方法を選択
⇒今回は「Clone in VS Code」を選択
(図121②)
data:image/s3,"s3://crabby-images/3b8db/3b8db934efce89b25c7c5ffe0f10037c7555a382" alt=""
↓
・③「Visual Studio Codeを開く」を押下
(図121③)
data:image/s3,"s3://crabby-images/06616/06616ce150ec512528cd032e1bfbf619f8a4bd4d" alt=""
↓
・④リポジトリをクローンするフォルダを選択
(図121④)
data:image/s3,"s3://crabby-images/3c0de/3c0de7843eb92b8c9bc1b1cb945596826b2ae4c6" alt=""
↓
・⑤DevOpsのアカウントを選択する
(図121⑤)
data:image/s3,"s3://crabby-images/c13da/c13da5cf230a26c3e230200c15022ab3aad0a592" alt=""
↓
・⑥クローンしたリポジトリを開くか聞かれたら「Open」
(図121⑥)
data:image/s3,"s3://crabby-images/2b42a/2b42ad5eb840c34acc6e24e53af7cbd4c620227b" alt=""
●STEP2-2:ブランチを切る
・①「・・・」ボタン→「Branch」→「Create Branch」
(図131)
data:image/s3,"s3://crabby-images/1e2da/1e2dadef836f92fe18711424783bdbf226267fdf" alt=""
↓
・②ブランチ名を入力して「Enter」押下
(図132)
data:image/s3,"s3://crabby-images/f6421/f64210d7af35fb9aa25a4152beadbdb01ad9742e" alt=""
↓
・③ブランチが切り替わる
(図133)
data:image/s3,"s3://crabby-images/b61a5/b61a527020ab62a3fb339f1455dfa40f6442e7d2" alt=""
●STEP2-3:ローカルでソース修正
・①例でPythonのサンプルコードを追加
(図134)
●STEP2-4:ローカルブランチに追加&コミット
・①「・・・」ボタン→「Changes」→「Stage All Changes」(Gitの「Add」)
(図135)
data:image/s3,"s3://crabby-images/16443/16443a631fc7e9760376e40623f64f6cf913e3b0" alt=""
↓
・②コミットメッセージを入力して「Commit」を押下
(図136)
data:image/s3,"s3://crabby-images/dc0ab/dc0ab3c79814c7ede143d92f893b9d36a2066ff3" alt=""
↓
●STEP2-5:リモートリポジトリのブランチにプッシュ
・①「・・・」ボタン→「Pull, Push」→「Push」
(図137)
data:image/s3,"s3://crabby-images/64331/6433164eedc990035a94b1f92c09e09ae50614c5" alt=""
↓
・②「OK」
(図138)
data:image/s3,"s3://crabby-images/1e849/1e849b2a0731b7e01bfb1c979c545a5f5de95789" alt=""
↓
・③ブランチが作成された
(図139①)
data:image/s3,"s3://crabby-images/14e21/14e21f1c8f5d8454eaa2e84cba9e6c35636af994" alt=""
(1-3) STEP3:プルリクエスト~マージ
●STEP3-1:開発者がプルリクエストする
(図211)
data:image/s3,"s3://crabby-images/f70b3/f70b311aad8fd683291105f6a10663af29868c8f" alt=""
↓
(図212)
data:image/s3,"s3://crabby-images/26fdf/26fdf3e6389dfdacf8dd6ce5b2c027250ff42a52" alt=""
●STEP3-2:レビュー&マージ
・①レビューして「Approve」を選択
(図213)
data:image/s3,"s3://crabby-images/b4f46/b4f4670bdfd904a63c6ec7ccd6a7ca99eb625767" alt=""
↓
・②OKなら「Complete」押下
(図214)
data:image/s3,"s3://crabby-images/3ab1b/3ab1b4416487d405edb27fd522b246f26940942f" alt=""
↓
・③「Complete Merge」を押下
(図215)
data:image/s3,"s3://crabby-images/2edd5/2edd50ae7dab7554e6b28f8528e929ad3270fca8" alt=""
↓
(図216)
Complete: |
プルリクエストの全ての変更をリポジトリのデフォルトブランチにマージ。
(利用シーン)
開発者がブランチを完全に統合し、リポジトリに取り込む必要がある場合。 |
Squash: |
プルリクエストの全ての変更を1つの新しいコミットにまとめて、リポジトリのデフォルトブランチにマージ
(利用シーン)
プルリクエストが多数の小さなコミットで構成されている場合に、履歴をきれいに保つために使用 |
Rebase: |
プルリクエストで行われた変更を、リポジトリのデフォルトブランチに取り込むために、現在のブランチのコミットを取り出して、デフォルトブランチに置き換える。
(利用シーン)
歴史をきれいに保ち、履歴の重複を削除するとき |
Semi-linear merge: |
リポジトリのデフォルトブランチにマージする前に、プルリクエストがターゲットブランチで更新された場合に、マージコミットを生成することによって変更を取り込みます。
(利用シーン)
このタイプのマージは、プルリクエストが他のブランチと競合している場合に有効。 |
(図221)
エラー対処①:fatal: cannot lock ref ‘HEAD’: is at xxx but expected yy
●エラーメッセージ
> git -c user.useConfigOnly=true commit –quiet
fatal: cannot lock ref ‘HEAD’: is at xxx but expected yyy
(図311)
data:image/s3,"s3://crabby-images/4298c/4298cad8005e7c7cff08d6b2c5b84fbc774f1d13" alt=""
●原因/対処
コミットメッセージが入っていないため、(図136)のようにコミットメッセージを入力してから再実行。