body method
Defines the actual body code. path is passed relative to lib, baseName is the filename, and className is the filename converted to Pascal case.
実際の本体コードを定義します。pathにlibからの相対パス、baseNameにファイル名が渡され、classNameにファイル名をパスカルケースに変換した値が渡されます。
Implementation
@override
String body(String baseName, String className) {
return r"""
`documents/designs/model_design.md`に記載されている`Model設計書`からモックデータを生成する方法
`documents/designs/model_design.md`が存在しない場合は絶対に実施しない
1. `Model設計書`を参照して各`Model`に対してモックデータを作成
- `lib/adapter.dart`内にある`RuntimeModelAdapter`の`initialValue`に`ModelInitialValue`を継承した値を追加していく
- 各`Model`に対する`ModelInitialValue`は`MemoModelInitialCollection`のような形で実装されているのでそれを利用する
- 各種`ModelInitialValue`は`String`をキー、対応する`Model`を値とする`Map`を渡して定義する
- キーは基本的に32桁の英数字(e.g. `a23c3fad389a45b39c9b1f930b364466`)を定義
- Masamuneフレームワーク(`package:masamune/masamune.dart`)に実装されている`generateCode(32, seed: n)`でランダムに生成可能
- テスト用にいくつかは固定IDで作成することを推奨
- `Collection`で利用する場合は10個程度のデータを用意
- `ModelRef<AnyModel>`を参照する場合は`AnyModelRefPath(uid)`を渡すことで参照可能
- `uid`は`AnyModelInitialCollection({uid: AnyModel()})`のように定義されていることが前提
- 例:
```dart
// lib/adapter.dart
/// Test user id.
///
/// Please set up mock data using this.
const testUserUid = "5da16680f3234c6a9781505cc9080909";
/// Current time.
///
/// Set the current time for testing.
///
/// Please set up mock data using this.
final testCurrentTime = Clock(2025, 1, 1, 12, 0, 0);
/// App Model.
///
/// Testing model adapter.
final runtimeModelAdapter = RuntimeModelAdapter(
initialValue: [
MemoModelInitialCollection({
"a5ba9e241dd94d32b2d869d6bb3e804b" : MemoModel(
title: "title 0",
content: "content 0",
createdBy: UserModelRefPath(testUserUid),
createdAt: ModelTimestamp(testCurrentTime.subtract(Duration(days: 0))),
updatedAt: ModelTimestamp(testCurrentTime.subtract(Duration(days: 0))),
),
"2844e503e4d242c79f5f45e59d7adeb6" : MemoModel(
title: "title 1",
content: "content 1",
createdBy: UserModelRefPath(testUserUid),
createdAt: ModelTimestamp(testCurrentTime.subtract(Duration(days: 1))),
updatedAt: ModelTimestamp(testCurrentTime.subtract(Duration(days: 1))),
),
for (var i = 2; i < 10; i++)
generateCode(32, seed: i) : MemoModel(
title: "title $i",
content: "content $i",
createdBy: UserModelRefPath(testUserUid),
createdAt: ModelTimestamp(testCurrentTime.subtract(Duration(days: i))),
updatedAt: ModelTimestamp(testCurrentTime.subtract(Duration(days: i))),
),
}),
UserModelInitialCollection({
testUserUid: UserModel(
name: "Main User",
email: "main@example.com",
createdAt: ModelTimestamp(testCurrentTime.subtract(Duration(days: i))),
updatedAt: ModelTimestamp(testCurrentTime.subtract(Duration(days: i))),
),
}),
],
);
```
- FlutterやMasamuneの実装方法の詳細や細かい制約については`documents/rules/**/*.md`を参照
""";
}