@auto-engineer/server-generator-apollo-emmett 1.139.0 → 1.140.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.turbo/turbo-build.log +1 -1
- package/.turbo/turbo-test.log +4 -4
- package/.turbo/turbo-type-check.log +1 -1
- package/CHANGELOG.md +17 -0
- package/DEBUG.md +4 -4
- package/dist/src/codegen/extract/data-sink.d.ts +2 -2
- package/dist/src/codegen/extract/data-sink.d.ts.map +1 -1
- package/dist/src/codegen/extract/data-sink.js +2 -2
- package/dist/src/codegen/extract/data-sink.js.map +1 -1
- package/dist/src/codegen/extract/events.d.ts +3 -3
- package/dist/src/codegen/extract/events.d.ts.map +1 -1
- package/dist/src/codegen/extract/events.js +11 -11
- package/dist/src/codegen/extract/events.js.map +1 -1
- package/dist/src/codegen/extract/gwt.d.ts +2 -2
- package/dist/src/codegen/extract/gwt.d.ts.map +1 -1
- package/dist/src/codegen/extract/gwt.js +2 -2
- package/dist/src/codegen/extract/gwt.js.map +1 -1
- package/dist/src/codegen/extract/imports.d.ts +4 -4
- package/dist/src/codegen/extract/imports.d.ts.map +1 -1
- package/dist/src/codegen/extract/imports.js +8 -8
- package/dist/src/codegen/extract/imports.js.map +1 -1
- package/dist/src/codegen/extract/messages.d.ts +2 -2
- package/dist/src/codegen/extract/messages.d.ts.map +1 -1
- package/dist/src/codegen/extract/messages.js +9 -9
- package/dist/src/codegen/extract/messages.js.map +1 -1
- package/dist/src/codegen/extract/projection.d.ts +7 -7
- package/dist/src/codegen/extract/projection.d.ts.map +1 -1
- package/dist/src/codegen/extract/projection.js +3 -3
- package/dist/src/codegen/extract/projection.js.map +1 -1
- package/dist/src/codegen/extract/query.d.ts +2 -2
- package/dist/src/codegen/extract/query.d.ts.map +1 -1
- package/dist/src/codegen/extract/query.js.map +1 -1
- package/dist/src/codegen/extract/slice-normalizer.d.ts +4 -4
- package/dist/src/codegen/extract/slice-normalizer.d.ts.map +1 -1
- package/dist/src/codegen/extract/slice-normalizer.js +7 -7
- package/dist/src/codegen/extract/slice-normalizer.js.map +1 -1
- package/dist/src/codegen/extract/states.d.ts +3 -3
- package/dist/src/codegen/extract/states.d.ts.map +1 -1
- package/dist/src/codegen/extract/states.js.map +1 -1
- package/dist/src/codegen/extract/step-converter.d.ts +7 -7
- package/dist/src/codegen/extract/step-converter.d.ts.map +1 -1
- package/dist/src/codegen/extract/step-converter.js +12 -12
- package/dist/src/codegen/extract/step-converter.js.map +1 -1
- package/dist/src/codegen/extract/step-types.d.ts +4 -4
- package/dist/src/codegen/extract/step-types.d.ts.map +1 -1
- package/dist/src/codegen/extract/step-types.js +1 -1
- package/dist/src/codegen/extract/step-types.js.map +1 -1
- package/dist/src/codegen/scaffoldFromSchema.d.ts +12 -12
- package/dist/src/codegen/scaffoldFromSchema.d.ts.map +1 -1
- package/dist/src/codegen/scaffoldFromSchema.js +113 -101
- package/dist/src/codegen/scaffoldFromSchema.js.map +1 -1
- package/dist/src/codegen/templates/command/commands.specs.ts +3 -3
- package/dist/src/codegen/templates/command/decide.specs.specs.ts +52 -52
- package/dist/src/codegen/templates/command/decide.specs.ts +12 -12
- package/dist/src/codegen/templates/command/decide.specs.ts.ejs +1 -1
- package/dist/src/codegen/templates/command/events.specs.ts +3 -3
- package/dist/src/codegen/templates/command/evolve.specs.ts +3 -3
- package/dist/src/codegen/templates/command/handle.specs.ts +13 -13
- package/dist/src/codegen/templates/command/mutation.resolver.specs.ts +19 -19
- package/dist/src/codegen/templates/command/register.specs.ts +3 -3
- package/dist/src/codegen/templates/command/state.specs.ts +3 -3
- package/dist/src/codegen/templates/query/events.specs.ts +4 -4
- package/dist/src/codegen/templates/query/projection.specs.specs.ts +60 -60
- package/dist/src/codegen/templates/query/projection.specs.ts +54 -29
- package/dist/src/codegen/templates/query/projection.specs.ts.ejs +2 -2
- package/dist/src/codegen/templates/query/query.resolver.specs.ts +63 -63
- package/dist/src/codegen/templates/query/query.resolver.ts.ejs +1 -1
- package/dist/src/codegen/templates/query/state.specs.ts +9 -9
- package/dist/src/codegen/templates/react/react.specs.specs.ts +15 -15
- package/dist/src/codegen/templates/react/react.specs.ts +16 -16
- package/dist/src/codegen/templates/react/react.specs.ts.ejs +9 -9
- package/dist/src/codegen/templates/react/react.ts.ejs +5 -5
- package/dist/src/codegen/templates/react/react.ts.specs.ts +33 -33
- package/dist/src/codegen/templates/react/register.specs.ts +7 -7
- package/dist/src/codegen/templates/react/register.ts.ejs +4 -4
- package/dist/src/codegen/test-data/specVariant1.d.ts.map +1 -1
- package/dist/src/codegen/test-data/specVariant1.js +3 -2
- package/dist/src/codegen/test-data/specVariant1.js.map +1 -1
- package/dist/src/codegen/types.d.ts +2 -2
- package/dist/src/codegen/types.d.ts.map +1 -1
- package/dist/src/commands/generate-server.d.ts +21 -21
- package/dist/src/commands/generate-server.d.ts.map +1 -1
- package/dist/src/commands/generate-server.js +81 -63
- package/dist/src/commands/generate-server.js.map +1 -1
- package/dist/src/commands/initialize-server.d.ts.map +1 -1
- package/dist/src/commands/initialize-server.js +2 -2
- package/dist/src/commands/initialize-server.js.map +1 -1
- package/dist/src/domain/flows/shared/types.d.ts +14 -0
- package/dist/src/domain/flows/shared/types.d.ts.map +1 -0
- package/dist/src/domain/flows/shared/types.js +2 -0
- package/dist/src/domain/flows/shared/types.js.map +1 -0
- package/dist/src/domain/flows/shared/types.ts +15 -0
- package/dist/src/domain/narratives/shared/types.d.ts +14 -0
- package/dist/src/domain/narratives/shared/types.d.ts.map +1 -0
- package/dist/src/domain/narratives/shared/types.js +2 -0
- package/dist/src/domain/narratives/shared/types.js.map +1 -0
- package/dist/src/domain/narratives/shared/types.ts +15 -0
- package/dist/src/index.d.ts +1 -1
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/server.js +3 -3
- package/dist/src/server.js.map +1 -1
- package/dist/src/server.ts +3 -3
- package/dist/src/utils/loadRegisterFiles.d.ts +2 -2
- package/dist/src/utils/loadRegisterFiles.d.ts.map +1 -1
- package/dist/src/utils/loadRegisterFiles.js.map +1 -1
- package/dist/src/utils/loadRegisterFiles.ts +5 -5
- package/dist/src/utils/loadResolvers.js +1 -1
- package/dist/src/utils/loadResolvers.js.map +1 -1
- package/dist/src/utils/loadResolvers.ts +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +4 -4
- package/src/codegen/extract/data-sink.ts +5 -5
- package/src/codegen/extract/events.ts +15 -15
- package/src/codegen/extract/gwt.ts +4 -4
- package/src/codegen/extract/imports.specs.ts +19 -19
- package/src/codegen/extract/imports.ts +13 -13
- package/src/codegen/extract/messages.specs.ts +30 -30
- package/src/codegen/extract/messages.ts +16 -16
- package/src/codegen/extract/projection.specs.ts +22 -22
- package/src/codegen/extract/projection.ts +9 -9
- package/src/codegen/extract/query.ts +2 -2
- package/src/codegen/extract/slice-normalizer.specs.ts +11 -11
- package/src/codegen/extract/slice-normalizer.ts +14 -14
- package/src/codegen/extract/states.ts +4 -4
- package/src/codegen/extract/step-converter.specs.ts +9 -9
- package/src/codegen/extract/step-converter.ts +15 -15
- package/src/codegen/extract/step-types.specs.ts +12 -12
- package/src/codegen/extract/step-types.ts +4 -4
- package/src/codegen/findEventSource.specs.ts +23 -23
- package/src/codegen/scaffoldErrors.specs.ts +4 -4
- package/src/codegen/scaffoldFromSchema.filter.specs.ts +32 -32
- package/src/codegen/scaffoldFromSchema.ts +146 -132
- package/src/codegen/templates/command/commands.specs.ts +3 -3
- package/src/codegen/templates/command/decide.specs.specs.ts +52 -52
- package/src/codegen/templates/command/decide.specs.ts +12 -12
- package/src/codegen/templates/command/decide.specs.ts.ejs +1 -1
- package/src/codegen/templates/command/events.specs.ts +3 -3
- package/src/codegen/templates/command/evolve.specs.ts +3 -3
- package/src/codegen/templates/command/handle.specs.ts +13 -13
- package/src/codegen/templates/command/mutation.resolver.specs.ts +19 -19
- package/src/codegen/templates/command/register.specs.ts +3 -3
- package/src/codegen/templates/command/state.specs.ts +3 -3
- package/src/codegen/templates/query/events.specs.ts +4 -4
- package/src/codegen/templates/query/projection.specs.specs.ts +60 -60
- package/src/codegen/templates/query/projection.specs.ts +54 -29
- package/src/codegen/templates/query/projection.specs.ts.ejs +2 -2
- package/src/codegen/templates/query/query.resolver.specs.ts +63 -63
- package/src/codegen/templates/query/query.resolver.ts.ejs +1 -1
- package/src/codegen/templates/query/state.specs.ts +9 -9
- package/src/codegen/templates/react/react.specs.specs.ts +15 -15
- package/src/codegen/templates/react/react.specs.ts +16 -16
- package/src/codegen/templates/react/react.specs.ts.ejs +9 -9
- package/src/codegen/templates/react/react.ts.ejs +5 -5
- package/src/codegen/templates/react/react.ts.specs.ts +33 -33
- package/src/codegen/templates/react/register.specs.ts +7 -7
- package/src/codegen/templates/react/register.ts.ejs +4 -4
- package/src/codegen/test-data/specVariant1.json +1 -1
- package/src/codegen/test-data/specVariant1.ts +3 -2
- package/src/codegen/test-data/specVariant2.json +1 -1
- package/src/codegen/types.ts +2 -2
- package/src/commands/generate-server.specs.ts +81 -79
- package/src/commands/generate-server.ts +110 -88
- package/src/commands/initialize-server.specs.ts +4 -4
- package/src/commands/initialize-server.ts +5 -2
- package/src/domain/flows/shared/types.ts +15 -0
- package/src/domain/narratives/shared/types.ts +15 -0
- package/src/index.ts +1 -1
- package/src/server.ts +3 -3
- package/src/utils/loadRegisterFiles.ts +5 -5
- package/src/utils/loadResolvers.ts +1 -1
|
@@ -1,13 +1,13 @@
|
|
|
1
|
-
import type {
|
|
1
|
+
import type { Scene } from '@auto-engineer/narrative';
|
|
2
2
|
import { describe, expect, it } from 'vitest';
|
|
3
3
|
import { findEventSource } from './scaffoldFromSchema';
|
|
4
4
|
|
|
5
5
|
describe('findEventSource', () => {
|
|
6
6
|
it('should find event in command slice GWT then steps', () => {
|
|
7
|
-
const
|
|
7
|
+
const scenes: Scene[] = [
|
|
8
8
|
{
|
|
9
|
-
name: 'order
|
|
10
|
-
|
|
9
|
+
name: 'order scene',
|
|
10
|
+
moments: [
|
|
11
11
|
{
|
|
12
12
|
type: 'command',
|
|
13
13
|
name: 'place order',
|
|
@@ -39,17 +39,17 @@ describe('findEventSource', () => {
|
|
|
39
39
|
},
|
|
40
40
|
];
|
|
41
41
|
|
|
42
|
-
expect(findEventSource(
|
|
43
|
-
|
|
44
|
-
|
|
42
|
+
expect(findEventSource(scenes, 'OrderPlaced')).toEqual({
|
|
43
|
+
sceneName: 'order scene',
|
|
44
|
+
momentName: 'place order',
|
|
45
45
|
});
|
|
46
46
|
});
|
|
47
47
|
|
|
48
48
|
it('should find event produced by react data target', () => {
|
|
49
|
-
const
|
|
49
|
+
const scenes: Scene[] = [
|
|
50
50
|
{
|
|
51
|
-
name: 'booking
|
|
52
|
-
|
|
51
|
+
name: 'booking scene',
|
|
52
|
+
moments: [
|
|
53
53
|
{
|
|
54
54
|
type: 'react',
|
|
55
55
|
name: 'notify barber of new booking',
|
|
@@ -89,17 +89,17 @@ describe('findEventSource', () => {
|
|
|
89
89
|
},
|
|
90
90
|
];
|
|
91
91
|
|
|
92
|
-
expect(findEventSource(
|
|
93
|
-
|
|
94
|
-
|
|
92
|
+
expect(findEventSource(scenes, 'BarberNotified')).toEqual({
|
|
93
|
+
sceneName: 'booking scene',
|
|
94
|
+
momentName: 'notify barber of new booking',
|
|
95
95
|
});
|
|
96
96
|
});
|
|
97
97
|
|
|
98
98
|
it('should find event in command slice data.items when not in GWT specs', () => {
|
|
99
|
-
const
|
|
99
|
+
const scenes: Scene[] = [
|
|
100
100
|
{
|
|
101
|
-
name: 'workout
|
|
102
|
-
|
|
101
|
+
name: 'workout scene',
|
|
102
|
+
moments: [
|
|
103
103
|
{
|
|
104
104
|
type: 'command',
|
|
105
105
|
name: 'submit workout log',
|
|
@@ -143,17 +143,17 @@ describe('findEventSource', () => {
|
|
|
143
143
|
},
|
|
144
144
|
];
|
|
145
145
|
|
|
146
|
-
expect(findEventSource(
|
|
147
|
-
|
|
148
|
-
|
|
146
|
+
expect(findEventSource(scenes, 'PointsEarned')).toEqual({
|
|
147
|
+
sceneName: 'workout scene',
|
|
148
|
+
momentName: 'submit workout log',
|
|
149
149
|
});
|
|
150
150
|
});
|
|
151
151
|
|
|
152
152
|
it('should return null when event is not found anywhere', () => {
|
|
153
|
-
const
|
|
153
|
+
const scenes: Scene[] = [
|
|
154
154
|
{
|
|
155
|
-
name: 'empty
|
|
156
|
-
|
|
155
|
+
name: 'empty scene',
|
|
156
|
+
moments: [
|
|
157
157
|
{
|
|
158
158
|
type: 'query',
|
|
159
159
|
name: 'some query',
|
|
@@ -166,6 +166,6 @@ describe('findEventSource', () => {
|
|
|
166
166
|
},
|
|
167
167
|
];
|
|
168
168
|
|
|
169
|
-
expect(findEventSource(
|
|
169
|
+
expect(findEventSource(scenes, 'NonExistentEvent')).toEqual(null);
|
|
170
170
|
});
|
|
171
171
|
});
|
|
@@ -20,7 +20,7 @@ describe('TemplateRenderError', () => {
|
|
|
20
20
|
});
|
|
21
21
|
|
|
22
22
|
describe('ScaffoldError', () => {
|
|
23
|
-
it('captures
|
|
23
|
+
it('captures scene/slice/type and chains cause', () => {
|
|
24
24
|
const templateError = new TemplateRenderError('evolve.ts.ejs', new Error('bad data'));
|
|
25
25
|
const error = new ScaffoldError('Checkout', 'PlaceOrder', 'command', templateError);
|
|
26
26
|
|
|
@@ -28,9 +28,9 @@ describe('ScaffoldError', () => {
|
|
|
28
28
|
expect.objectContaining({
|
|
29
29
|
name: 'ScaffoldError',
|
|
30
30
|
message: 'Scaffold failed for Checkout/PlaceOrder (command)',
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
31
|
+
sceneName: 'Checkout',
|
|
32
|
+
momentName: 'PlaceOrder',
|
|
33
|
+
momentType: 'command',
|
|
34
34
|
cause: templateError,
|
|
35
35
|
}),
|
|
36
36
|
);
|
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
import { tmpdir } from 'node:os';
|
|
2
2
|
import { join } from 'node:path';
|
|
3
|
-
import type {
|
|
3
|
+
import type { CommandMoment, Message, Scene } from '@auto-engineer/narrative';
|
|
4
4
|
import { describe, expect, it } from 'vitest';
|
|
5
5
|
import { generateScaffoldFilePlans } from './scaffoldFromSchema';
|
|
6
6
|
|
|
7
|
-
const
|
|
7
|
+
const makeMoment = (name: string): CommandMoment => ({
|
|
8
8
|
name,
|
|
9
9
|
type: 'command',
|
|
10
10
|
client: { specs: [] },
|
|
@@ -40,14 +40,14 @@ const messages: Message[] = [
|
|
|
40
40
|
{ name: 'RemoveTodoDone', type: 'event', fields: [{ name: 'id', type: 'string', required: true }] },
|
|
41
41
|
];
|
|
42
42
|
|
|
43
|
-
const
|
|
43
|
+
const scenes: Scene[] = [
|
|
44
44
|
{
|
|
45
45
|
name: 'Todo',
|
|
46
|
-
|
|
46
|
+
moments: [makeMoment('AddTodo'), makeMoment('RemoveTodo')],
|
|
47
47
|
},
|
|
48
48
|
];
|
|
49
49
|
|
|
50
|
-
const
|
|
50
|
+
const makeMomentWithCommand = (name: string, commandName: string): CommandMoment => ({
|
|
51
51
|
name,
|
|
52
52
|
type: 'command',
|
|
53
53
|
client: { specs: [] },
|
|
@@ -76,55 +76,55 @@ const makeSliceWithCommand = (name: string, commandName: string): CommandSlice =
|
|
|
76
76
|
},
|
|
77
77
|
});
|
|
78
78
|
|
|
79
|
-
describe('generateScaffoldFilePlans with
|
|
79
|
+
describe('generateScaffoldFilePlans with affectedMomentIds filter', () => {
|
|
80
80
|
const baseDir = join(tmpdir(), `scaffold-filter-test-${Date.now()}`);
|
|
81
81
|
|
|
82
|
-
it('generates plans for all
|
|
83
|
-
const { plans } = await generateScaffoldFilePlans(
|
|
84
|
-
const
|
|
85
|
-
expect(
|
|
86
|
-
expect(
|
|
82
|
+
it('generates plans for all moments when no filter is provided', async () => {
|
|
83
|
+
const { plans } = await generateScaffoldFilePlans(scenes, messages, undefined, baseDir);
|
|
84
|
+
const momentDirs = new Set(plans.map((p) => p.outputPath.split('/').slice(-3, -1).join('/')));
|
|
85
|
+
expect(momentDirs.has('todo/add-todo')).toBe(true);
|
|
86
|
+
expect(momentDirs.has('todo/remove-todo')).toBe(true);
|
|
87
87
|
});
|
|
88
88
|
|
|
89
|
-
it('generates plans only for affected
|
|
90
|
-
const
|
|
91
|
-
const { plans } = await generateScaffoldFilePlans(
|
|
92
|
-
const
|
|
93
|
-
expect(
|
|
94
|
-
expect(
|
|
89
|
+
it('generates plans only for affected moments when filter is provided', async () => {
|
|
90
|
+
const affectedMomentIds = new Set(['todo/add-todo']);
|
|
91
|
+
const { plans } = await generateScaffoldFilePlans(scenes, messages, undefined, baseDir, affectedMomentIds);
|
|
92
|
+
const momentDirs = new Set(plans.map((p) => p.outputPath.split('/').slice(-3, -1).join('/')));
|
|
93
|
+
expect(momentDirs.has('todo/add-todo')).toBe(true);
|
|
94
|
+
expect(momentDirs.has('todo/remove-todo')).toBe(false);
|
|
95
95
|
});
|
|
96
96
|
});
|
|
97
97
|
|
|
98
98
|
describe('generateScaffoldFilePlans with duplicate command handlers', () => {
|
|
99
99
|
const baseDir = join(tmpdir(), `scaffold-duplicate-test-${Date.now()}`);
|
|
100
100
|
|
|
101
|
-
it('skips register.ts for
|
|
101
|
+
it('skips register.ts for moments with duplicate command handlers across scenes', async () => {
|
|
102
102
|
const duplicateMessages: Message[] = [
|
|
103
103
|
{ name: 'DoAction', type: 'command', fields: [{ name: 'id', type: 'string', required: true }] },
|
|
104
104
|
{ name: 'DoActionDone', type: 'event', fields: [{ name: 'id', type: 'string', required: true }] },
|
|
105
105
|
];
|
|
106
106
|
|
|
107
|
-
const
|
|
108
|
-
{ name: 'FlowA',
|
|
109
|
-
{ name: 'FlowB',
|
|
107
|
+
const duplicateScenes: Scene[] = [
|
|
108
|
+
{ name: 'FlowA', moments: [makeMomentWithCommand('HandleAction', 'DoAction')] },
|
|
109
|
+
{ name: 'FlowB', moments: [makeMomentWithCommand('ProcessAction', 'DoAction')] },
|
|
110
110
|
];
|
|
111
111
|
|
|
112
|
-
const result = await generateScaffoldFilePlans(
|
|
112
|
+
const result = await generateScaffoldFilePlans(duplicateScenes, duplicateMessages, undefined, baseDir);
|
|
113
113
|
|
|
114
|
-
const
|
|
115
|
-
const
|
|
114
|
+
const sceneAFiles = result.plans.filter((p) => p.outputPath.includes('flow-a/handle-action'));
|
|
115
|
+
const sceneBFiles = result.plans.filter((p) => p.outputPath.includes('flow-b/process-action'));
|
|
116
116
|
|
|
117
|
-
const
|
|
118
|
-
const
|
|
117
|
+
const sceneAHasRegister = sceneAFiles.some((p) => p.outputPath.endsWith('register.ts'));
|
|
118
|
+
const sceneBHasRegister = sceneBFiles.some((p) => p.outputPath.endsWith('register.ts'));
|
|
119
119
|
|
|
120
|
-
expect(
|
|
121
|
-
expect(
|
|
120
|
+
expect(sceneAHasRegister).toBe(true);
|
|
121
|
+
expect(sceneBHasRegister).toBe(false);
|
|
122
122
|
|
|
123
123
|
expect(result.duplicateCommands).toEqual([
|
|
124
124
|
{
|
|
125
125
|
command: 'DoAction',
|
|
126
|
-
|
|
127
|
-
|
|
126
|
+
existingScene: 'FlowA',
|
|
127
|
+
existingMoment: 'HandleAction',
|
|
128
128
|
},
|
|
129
129
|
]);
|
|
130
130
|
});
|
|
@@ -146,7 +146,7 @@ describe('generateScaffoldFilePlans with invalid field names', () => {
|
|
|
146
146
|
{ name: 'AddTodoDone', type: 'event', fields: [{ name: 'id', type: 'string', required: true }] },
|
|
147
147
|
];
|
|
148
148
|
|
|
149
|
-
const singleFlow:
|
|
149
|
+
const singleFlow: Scene[] = [{ name: 'Todo', moments: [makeMoment('AddTodo')] }];
|
|
150
150
|
|
|
151
151
|
const result = await generateScaffoldFilePlans(singleFlow, messagesWithInvalid, undefined, baseDir);
|
|
152
152
|
|
|
@@ -179,7 +179,7 @@ describe('generateScaffoldFilePlans with malformed map types', () => {
|
|
|
179
179
|
{ name: 'LogWorkoutDone', type: 'event', fields: [{ name: 'id', type: 'string', required: true }] },
|
|
180
180
|
];
|
|
181
181
|
|
|
182
|
-
const singleFlow:
|
|
182
|
+
const singleFlow: Scene[] = [{ name: 'Workout', moments: [makeMoment('LogWorkout')] }];
|
|
183
183
|
|
|
184
184
|
const result = await generateScaffoldFilePlans(singleFlow, messagesWithMalformedType, undefined, baseDir);
|
|
185
185
|
|