はじめに
これは 環境構築から始めるテスト駆動開発 ~ プログラミング環境の共通基盤を構築する ~ の開発言語セットアップ記事です。Windows 10 Home で共通基盤が構築されていることを前提としています。
インストール
スタートメニューから Windows PowerShell
を選択します。
data:image/s3,"s3://crabby-images/c1de7/c1de7f37ed8c4d9a1d36584e312aa1a872003052" alt=""
.NET 開発環境をインストールします。
1
| > scoop install dotnet-sdk
|
バージョンを確認しておきます。
1 2
| > dotnet -version 5.0.202
|
Hello world
プログラムを作成する
Projects
フォルダ内に dotnet
フォルダを作成してエディタからフォルダを開きます。
data:image/s3,"s3://crabby-images/03f5b/03f5bc8809dfb896127d9aa6fe5cfaccb996c159" alt=""
新しいターミナルを
を実行してターミナルに以下のコマンドを入力します。
data:image/s3,"s3://crabby-images/34a05/34a05cb2411d29389c5c9e8120702a6936188181" alt=""
1 2 3 4 5 6 7
| dotnet new sln -o hello-dotnet cd hello-dotnet dotnet new classlib -o Program dotnet sln add ./Program/Program.csproj dotnet new xunit -o Program.Tests dotnet sln add ./Program.Tests/Program.Tests.csproj dotnet add ./Program.Tests/Program.Tests.csproj reference ./Program/Program.csproj
|
セットアップが完了したら UnitTest1.cs
を開きます。
拡張機能インストールの案内が表示されるので インストール
を押します。
data:image/s3,"s3://crabby-images/f4619/f461922679efce5373df1e215a07669f64d5e639" alt=""
拡張機能インストールが終わると画面左下に .NET プロジェクト読み込みの確認メッセージが表示されるので Yes
を押します。
data:image/s3,"s3://crabby-images/1270b/1270b820c9e99a0ce4bfc658fd387e5301b229b9" alt=""
読み込みが完了したら Run All Tests
と表示されるのでそこを押します。
data:image/s3,"s3://crabby-images/435d7/435d743a627d77de359e446b5b141df2fbe903bf" alt=""
テストが実行されます。
data:image/s3,"s3://crabby-images/d556d/d556d5cb8e839dbe0e71a8110fdbc32382a97256" alt=""
.NET Core Test Explorer
機能拡張を追加します。
data:image/s3,"s3://crabby-images/b70d8/b70d818da8f1bc8bab7d59adb1fd071d15a6941e" alt=""
機能拡張のインストールが終わったらソリューション内のテストを読み込むためhello-dotnet
フォルダを開きます。
data:image/s3,"s3://crabby-images/d882a/d882a88fe287a3691628333b5275ad3a7dd19e79" alt=""
data:image/s3,"s3://crabby-images/db773/db7732b6216c85f28b592be52f75db0746a8e6f2" alt=""
サイドメニューの テスト
からテストが実行できるようになります。
data:image/s3,"s3://crabby-images/abaa5/abaa58904fe08440169519f8e966246f12b6d7ae" alt=""
UnitTest1.cs
ファイルを以下のコードに書き換えます。
1 2 3 4 5 6 7 8 9 10 11 12 13 14
| using System; using Xunit;
namespace Program.Tests { public class UnitTest1 { [Fact] public void 何か便利なもの() { Assert.Equal(true, false); } } }
|
Run All Tests
またはサイドメニューの テスト
から実行ボタンを押してテストを実行します。
data:image/s3,"s3://crabby-images/52ee3/52ee3019231eca573afcc446429d447c95cab1f4" alt=""
テストをパスするようにコードを修正してプログラムを実行します。
1 2 3 4 5 6 7 8 9 10 11 12 13 14
| using System; using Xunit;
namespace Program.Tests { public class UnitTest1 { [Fact] public void 何か便利なもの() { Assert.Equal(true, true); } } }
|
data:image/s3,"s3://crabby-images/df994/df9943465a93585041581671d11b609c98ae268a" alt=""
テスティングフレームワークの動作が確認できたので helloWorld
メソッドの作成に入ります。まず以下のコードを追加して テストが失敗することを確認します。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20
| using System; using Xunit;
namespace Program.Tests { public class UnitTest1 { [Fact] public void 何か便利なもの() { Assert.Equal(true, true); }
[Fact] public void 簡単な挨拶を返す() { Assert.Equal("Hello from .NET", App.helloWorld()); } } }
|
data:image/s3,"s3://crabby-images/e3bd5/e3bd5585cef0ac2bd146e2e684b59ed3a955d7bc" alt=""
App
クラスに helloWorld
メソッドを 追加してテストをパスさせます。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28
| using System; using Xunit;
namespace Program.Tests { public class UnitTest1 { [Fact] public void 何か便利なもの() { Assert.Equal(true, true); }
[Fact] public void 簡単な挨拶を返す() { Assert.Equal("Hello from .NET", App.helloWorld()); } } }
class App { public static String helloWorld() { return "Hello from .NET"; } }
|
data:image/s3,"s3://crabby-images/cd68c/cd68cd962277f3cd74144582bd1791a581b30cbc" alt=""
指定された名前で挨拶を返すようにします。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33
| using System; using Xunit;
namespace Program.Tests { public class UnitTest1 { [Fact] public void 何か便利なもの() { Assert.Equal(true, true); }
[Fact] public void 簡単な挨拶を返す() { Assert.Equal("Hello from .NET", App.helloWorld()); }
[Fact] public void 指定された名前で挨拶を返す() { Assert.Equal("Hello from VSCode", App.helloWorld("VSCode")); } } }
class App { public static String helloWorld() { return "Hello from .NET"; } }
|
data:image/s3,"s3://crabby-images/cd68c/cd68cd962277f3cd74144582bd1791a581b30cbc" alt=""
メソッドに引数を追加します。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34
| using System; using Xunit;
namespace Program.Tests { public class UnitTest1 { [Fact] public void 何か便利なもの() { Assert.Equal(true, true); }
[Fact] public void 簡単な挨拶を返す() { Assert.Equal("Hello from .NET", App.helloWorld()); }
[Fact] public void 指定された名前で挨拶を返す() { Assert.Equal("Hello from VSCode", App.helloWorld("VSCode")); } } }
class App { public static String helloWorld(String name) { return $"Hello from {name}"; } }
|
data:image/s3,"s3://crabby-images/32388/323882d771d73c63a469d304c39943b137c8670c" alt=""
ビルドエラー 'App.helloWorld(string)' の必要な仮パラメーター 'name' に対応する特定の引数がありません
が表示されています 簡単な挨拶を返す
に対応するメソッドが存在しないのでメソッドをオーバーロードしてテストをパスするようにします。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38
| using System; using Xunit;
namespace Program.Tests { public class UnitTest1 { [Fact] public void 何か便利なもの() { Assert.Equal(true, true); }
[Fact] public void 簡単な挨拶を返す() { Assert.Equal("Hello from .NET", App.helloWorld()); }
[Fact] public void 指定された名前で挨拶を返す() { Assert.Equal("Hello from VSCode", App.helloWorld("VSCode")); } } }
class App { public static String helloWorld() { return "Hello from .NET"; } public static String helloWorld(String name) { return $"Hello from {name}"; } }
|
data:image/s3,"s3://crabby-images/89377/89377075354dfc22fb8a1e970bba9f0fab6e60ec" alt=""
仕上げに不要なテストを削除してテストケースの文言をわかりやすくしておきます。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32
| using System; using Xunit;
namespace Program.Tests { public class UnitTest1 { [Fact] public void 何も指定されていない場合は既定の挨拶を返す() { Assert.Equal("Hello from .NET", App.helloWorld()); }
[Fact] public void 指定された名前で挨拶を返す() { Assert.Equal("Hello from VSCode", App.helloWorld("VSCode")); } } }
class App { public static String helloWorld() { return "Hello from .NET"; } public static String helloWorld(String name) { return $"Hello from {name}"; } }
|
data:image/s3,"s3://crabby-images/359e7/359e7f4a28a88ee15cae2c93740600914ba6f943" alt=""
プログラムをデバッグする
まず確認したいプログラムの行を左部分を押してブレークポイント(赤丸)を設定します。
data:image/s3,"s3://crabby-images/71528/7152841a6625871b6eef4343d82505358305f624" alt=""
ブレークポイントを設定したら Debug All Tests
を押してプログラムの実行します。そうするとブレークポイント部分でプログラムが停止して変数などの情報が確認できるようになります。
data:image/s3,"s3://crabby-images/45b0f/45b0f903e2daf1787b1cef3bc1af9f92de018a4b" alt=""
画面上の実行ボタンを押すと次のブレークポイントに移動します。
data:image/s3,"s3://crabby-images/ae0fb/ae0fbd149f737758473090c36f8d37407c40a781" alt=""
デバッガを終了するには終了ボタンを押します。
data:image/s3,"s3://crabby-images/ae0fb/ae0fbd149f737758473090c36f8d37407c40a781" alt=""
ブレークポイントを再度押すことで解除ができます。
data:image/s3,"s3://crabby-images/b1730/b17307f332d47b5be98f19b0445178701efc2d55" alt=""
プログラムをリポジトリに保存する
新しいターミナル
を実行して以下のコマンドを入力します。
ソース管理を選択して リポジトリを初期化する
を押します。
data:image/s3,"s3://crabby-images/b1730/b17307f332d47b5be98f19b0445178701efc2d55" alt=""
全ての変更をステージ
を選択します。
data:image/s3,"s3://crabby-images/17b11/17b11e34b57a186fd5918d4f13ab801815332aa8" alt=""
変更内容に feat: HelloWorld
と入力して コミット
を押します。
data:image/s3,"s3://crabby-images/04f1e/04f1e6abffdb9c81b4631663ab680de2c3a299d6" alt=""
変更内容は ソース管理
から確認できます。
data:image/s3,"s3://crabby-images/60885/6088599a829fa853169c83316d67271ec03dc808" alt=""
GitHub に公開する
続いて、GitHub を使ってレポジトリを外部に公開できるようにしてみましょう。
まず、GitHub でレポジトリを作成します。
ログインしたら画面右上の+マークから New repository
を選択します。
data:image/s3,"s3://crabby-images/3b0be/3b0bee155824e71153f13fc5ee65864b4cd6b9cc" alt=""
レポジトリ名は hello-dotnet
として Public
で公開します。 公開したくない場合は Private
を選択します。
Add a README file
にもチェックを入れておきます。
最後に Create repository
を押して公開レポジトリを作成します。
data:image/s3,"s3://crabby-images/865d0/865d0ee382b5f7ca4bb0bd50a6b8dc1049c68f4c" alt=""
公開レポジトリが作成されたら VSCode から読み込めるようにするためリンク先の情報を取得します。
data:image/s3,"s3://crabby-images/f8ca1/f8ca1bd70a30c4a795274cd7529810f22d91e275" alt=""
クリップボードのアイコンをクリックするとレポジトリの URL がコピーできます。
data:image/s3,"s3://crabby-images/dfe22/dfe22bdee5ee81392771c43ea381905ec1b23fe8" alt=""
続いて VSCode に戻り、表示
メニューから コマンドパレット
を選択します。
data:image/s3,"s3://crabby-images/abc22/abc22748271db1b753bb5e782304cb56791fec20" alt=""
clone
と入力して Git クローン
を選択します。
data:image/s3,"s3://crabby-images/84692/846927edbd764a55b6bded0ce156e75e1802e2fb" alt=""
リポジトリの URL へ先ほどコピーした公開レポジトリの URL を貼り付けます。
data:image/s3,"s3://crabby-images/a9fd4/a9fd49c0c51acc7fc1646f9638630287dddc0b65" alt=""
公開レポジトリの保存場所を指定する必要があるのでここでは Projects
フォルダに GitHub
フォルダを追加してそこに保存することにします。
data:image/s3,"s3://crabby-images/a141b/a141bba4bd3d5f6e5e5bec40225f8753737ba692" alt=""
チェックアウトが終わると画面左下に通知が出ますので 開く
を押します。
data:image/s3,"s3://crabby-images/cef1c/cef1caae0a0d1c12acc7d33d623b1cdcd5b8239c" alt=""
新しいターミナル
を実行して以下のコマンドを入力します。
1 2 3 4 5 6 7 8 9
| $var = "Program" $var_test = ${var} + "." + "Tests" dotnet new gitignore dotnet new sln -o . dotnet new classlib -o ${var} dotnet sln add ./${var}/${var}.csproj dotnet new xunit -o ${var_test} dotnet sln add ./${var_test}/${var_test}.csproj dotnet add ./${var_test}/${var_test}.csproj reference ./${var}/${var}.csproj
|
準備ができましたので先ほどやった HelloWorld
プログラムをもう一度作成して先ほどと同様にローカルレポジトリに保存します。
data:image/s3,"s3://crabby-images/7736c/7736c10634f7558bee9d7fe2a7719038ba4e1fd7" alt=""
ローカルレポジトリの内容を GitHub の公開レポジトリに登録します。表示
メニューから コマンドパレット
を選択します。
data:image/s3,"s3://crabby-images/4b7a6/4b7a655cb793c8bb5f4636cf337d70b1d1bdce42" alt=""
push
と入力して Git プッシュ
を選択します。
data:image/s3,"s3://crabby-images/a141b/a141bba4bd3d5f6e5e5bec40225f8753737ba692" alt=""
以下の GitHub 認証画面が表示された場合は Sign in with your browser
を押します。
data:image/s3,"s3://crabby-images/e7e4b/e7e4b320a2d8f62f914e7615e5b443ecbbdb814b" alt=""
Authorize GitCrendtialManager
を押します。
data:image/s3,"s3://crabby-images/2bb9a/2bb9a707ce6bded645ddc2d541e50e55de4a5c97" alt=""
GitHub アカウントのパスワードを入力します。
data:image/s3,"s3://crabby-images/37bae/37baeb311a364b86d5d28dfeb8ef0c738a1e4bf1" alt=""
data:image/s3,"s3://crabby-images/0db8c/0db8c66d0816b26328541cfdcfdb1050afddae4d" alt=""
認証が完了してローカルレポジトリの内容が公開レポジトリに登録されました。
data:image/s3,"s3://crabby-images/abfaa/abfaa4bab3719528c5a8e321504d155db885384c" alt=""
内容が反映されているかをブラウザ画面から確認します。
data:image/s3,"s3://crabby-images/fea86/fea865c9bf585cecda80bf0429a343111b7563fe" alt=""