以前のレクチャーでFakeについて解説しました。MeasureFakeを作りましたね。実際にはデータベースに接続して,Measureというテーブルを検索する構想ですが,データベースが存在しなくてもいろんな値でテストできるようにMeasureFakeを作成しました。Fakeはプロトタイプとしてお客さんに見せるときにも使えます。今回はそのFakeと本番コードであるSqlServerのクラスとの切り替え方法を解説していきます。
SqlServerフォルダーを作成する
まずは本番コードのSqlServerのクラスを置く場所としてSqlServerフォルダーをInfrastructureに作成します。
Infrastructureのプロジェクトを右クリックして,「追加」「新しいフォルダー」を選択して,フォルダーを作成し,名前を「SqlServer」とします。このInfrastructureのフォルダー構成はテクノロジーごとに作ります。SqlServerとOracleがあったら,それぞれでフォルダーを作ります。あとCsvとか,外部と接触するテクノロジーごとに分割します。
MeasureSqlServerクラスを作成する
作成した「SqlServer」フォルダーの中に「MeasureSqlServer」クラスを作成します。
SqlServerフォルダーで右クリックをして「追加」「クラス」の順で選択し,「MeasureSqlServer」クラスを作成してください。
MeasureSqlServerクラスを作成したら,次のように記述します。
using NDDD.Domain.Ripositories; using System; namespace NDDD.Infrastructure.SqlServer { public sealed class MeasureSqlServer : IMeasureRepository { } }
ここまで書いたら,IMeasureRepositoryがGetLatestの未実装エラーとなり,コンパイルエラーとなります。IMeasureRepositoryにカーソルを当ててctrl+ドットキーを押下してEnterを押すと,次のコードが自動生成されます。自動生成がうまくいかない場合は手入力してください。
using NDDD.Domain.Entities; using NDDD.Domain.Ripositories; using System; namespace NDDD.Infrastructure.SqlServer { public sealed class MeasureSqlServer : IMeasureRepository { public MeasureEntity GetLatest() { throw new NotImplementedException(); } } }
自動生成でGetLatestを作成するとNotImplementedExceptionの例外が通知されるようになります。これは未実装の例外です。今回,SqlServerの実装は遅らせて実装する構想なので,この未実装例外はそのまま置いておいてください。そうしておいたほうが,今後,間違えて使用したときに,すぐに未実装であることが気付けるようになります。
View側の状況
現在LatestViewの実装を見ると,MeasureFakeを生成することが固定になっています。
private LatestViewModel _viewModel = new LatestViewModel(new MeasureFake());
これではMeasureFakeにしか繋がらないので,ここをFakeかSqlServerに繋ぐのかを切り替えるようにしないといけないので,そのあたりを次回は見ていきたいと思います。