ドメイン駆動開発_フォルダー構成編_#20_Fakeとデータベースの値を切り替える方法

当サイトではアフィリエイト広告を利用しています。

NDDD

以前のレクチャーで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に繋ぐのかを切り替えるようにしないといけないので,そのあたりを次回は見ていきたいと思います。