ドメイン駆動設計のコンテキストマップ

| 2 min read
Author: shigeki-shoji shigeki-shojiの画像

ドメイン駆動設計の戦略的設計では、システム全体をどのように境界づけられたコンテキストを統合するかを表すコンテキストマップ (Context Map) を描きます。さらに、このコンテキストマップには時間の経過とともに、コンテキストが追加、更新、削除のように修正されていくことも考慮しておく必要があります。

したがって、コンテキストマップは単なる画像としてではなく、git などのバージョン管理ツールで比較が容易なテキストで記述できると便利です。

Context Mapper というツールを使うと、CML というドメイン固有言語でコンテキストマップを記述できます。

ここからの説明では、Context Mapper VS Code ExtensionPlantUML 拡張 がインストールされた Visual Studio Code を使用しています。

これらの拡張機能には、Java と Graphviz も必要です。

Graphviz は mac ユーザーであれば、Homebrew を使ってインストールできます。

brew install graphviz

では、実践ドメイン駆動設計 の第3章の図から始めることにしましょう。

この図を描くための CML は次のようになります。

ContextMap {
type SYSTEM_LANDSCAPE

contains A_Context, B_Context, C_Context
A_Context -> B_Context
A_Context -> C_Context
B_Context -> C_Context
}

BoundedContext A_Context
BoundedContext B_Context
BoundedContext C_Context

コンテキスト間の矢印によって、U (Upstream) と D (Downstream) の関係が表現されます。

Upstream、Downstream 以外の統合パターンもサポートされています。

  • パートナーシップ (Partnership)
  • 共有カーネル (Shared Kernel)
  • 顧客/供給者 (Customer/Supplier)
  • 順応者 (Conformist)
  • 腐敗防止層 (Anticorruption Layer)
  • 公開ホストサービス (Open Host Service)
  • 公表された言語 (Published Language)

上のいくつかが含まれる図の例です。

この図を描くための CML は次のようになります。

ContextMap {
type SYSTEM_LANDSCAPE

contains AuthContext
contains CollaborationContext
contains AgileProjectManagementContext

AuthContext [OHS,PL] -> [ACL] CollaborationContext
AuthContext [OHS,PL] -> [ACL] AgileProjectManagementContext
CollaborationContext [OHS,PL] -> [ACL] AgileProjectManagementContext
}

BoundedContext AuthContext
BoundedContext CollaborationContext
BoundedContext AgileProjectManagementContext

さらに上の定義をPlantUMLで出力したイメージは次のようになります。

CML を使って、ドメイン (Domain) やサブドメイン (Subdomain) の定義もできます。

まとめ

#

描画ツールではなく、Context Mapper を利用することで、保守性が高く、コンテキストマップとしてだけでなく、その先のドメインの構造を表す UML が出力できるため非常に価値のあるツールと考えています。

参考

#
豆蔵デベロッパーサイト - 先週のアクセスランキング
  1. 自然言語処理初心者が「GPT2-japanese」で遊んでみた (2022-07-08)
  2. Tauri でデスクトップアプリ開発を始める (2022-07-08)
  3. Deno による Slack プラットフォーム(オープンベータ) (2022-09-27)
  4. Jest再入門 - 関数・モジュールモック編 (2022-07-03)
  5. ORマッパーのTypeORMをTypeScriptで使う (2022-07-27)
  6. 第1回 OpenAPI Generator を使ったコード生成 (2022-06-04)
  7. 直感が理性に大反抗!「モンティ・ホール問題」 (2022-07-04)
  8. Rust によるデスクトップアプリケーションフレームワーク Tauri (2022-03-06)
  9. 箱ひげ図で外れ値を確認する (2022-05-18)
  10. Nuxt3入門(第1回) - Nuxtがサポートするレンダリングモードを理解する (2022-09-25)