feat: add mock generation for DTOs, models, and repositories with corresponding templates
This commit is contained in:
@@ -4,6 +4,7 @@ import mustache from 'mustache';
|
||||
import { logStep, logSuccess, logInfo } from '../utils/logger';
|
||||
import { mapSwaggerTypeToTs } from '../utils/type-mapper';
|
||||
import { toCamelCase } from '../utils/name-formatter';
|
||||
import { resolveMockValue } from '../utils/mock-value-resolver';
|
||||
import type {
|
||||
SwaggerAnalysis,
|
||||
OpenApiSchema,
|
||||
@@ -72,7 +73,8 @@ export function generateCleanArchitecture(
|
||||
repositories: 0,
|
||||
mappers: 0,
|
||||
useCases: 0,
|
||||
providers: 0
|
||||
providers: 0,
|
||||
mocks: 0
|
||||
};
|
||||
|
||||
const schemas =
|
||||
@@ -166,6 +168,48 @@ export function generateCleanArchitecture(
|
||||
fs.writeFileSync(destPath, output);
|
||||
generatedCount.mappers++;
|
||||
}
|
||||
|
||||
// DTO mock — values resolved from raw schema (example, format, type)
|
||||
const dtoMockVarsMap = Object.keys(rawProperties).map((k) => ({
|
||||
name: k,
|
||||
mockValue: resolveMockValue(k, rawProperties[k], 'dto')
|
||||
}));
|
||||
const dtoMockImports = [...referencedTypes]
|
||||
.filter(Boolean)
|
||||
.map((name) => ({ classname: name, classFilename: toCamelCase(name) }));
|
||||
|
||||
const dtoMockViewData = {
|
||||
models: [
|
||||
{
|
||||
model: {
|
||||
classname: baseName,
|
||||
classFilename: toCamelCase(baseName),
|
||||
classVarName: toCamelCase(baseName),
|
||||
mockImports: dtoMockImports,
|
||||
vars: dtoMockVarsMap
|
||||
}
|
||||
}
|
||||
]
|
||||
};
|
||||
|
||||
renderTemplate(
|
||||
templatesDir,
|
||||
'dto.mock.mustache',
|
||||
dtoMockViewData,
|
||||
path.join(outputDir, 'data/dtos', `${toCamelCase(baseName)}.dto.mock.ts`),
|
||||
generatedCount,
|
||||
'mocks'
|
||||
);
|
||||
|
||||
// Model mock — delegates to mapper + DTO mock (no property values needed)
|
||||
renderTemplate(
|
||||
templatesDir,
|
||||
'model.mock.mustache',
|
||||
modelViewData,
|
||||
path.join(outputDir, 'entities/models', `${toCamelCase(baseName)}.model.mock.ts`),
|
||||
generatedCount,
|
||||
'mocks'
|
||||
);
|
||||
});
|
||||
|
||||
// 2. Generate Use Cases and Repositories from Paths/Tags
|
||||
@@ -357,10 +401,47 @@ export function generateCleanArchitecture(
|
||||
generatedCount,
|
||||
'providers'
|
||||
);
|
||||
|
||||
// Mocks — repository impl, use-cases impl, repository provider, use-cases provider
|
||||
renderTemplate(
|
||||
templatesDir,
|
||||
'api.repository.impl.mock.mustache',
|
||||
apiViewData,
|
||||
path.join(outputDir, 'data/repositories', `${toCamelCase(tag)}.repository.impl.mock.ts`),
|
||||
generatedCount,
|
||||
'mocks'
|
||||
);
|
||||
|
||||
renderTemplate(
|
||||
templatesDir,
|
||||
'api.use-cases.mock.mustache',
|
||||
apiViewData,
|
||||
path.join(outputDir, 'domain/use-cases', `${toCamelCase(tag)}.use-cases.mock.ts`),
|
||||
generatedCount,
|
||||
'mocks'
|
||||
);
|
||||
|
||||
renderTemplate(
|
||||
templatesDir,
|
||||
'repository.provider.mock.mustache',
|
||||
apiViewData,
|
||||
path.join(outputDir, 'di/repositories', `${toCamelCase(tag)}.repository.provider.mock.ts`),
|
||||
generatedCount,
|
||||
'mocks'
|
||||
);
|
||||
|
||||
renderTemplate(
|
||||
templatesDir,
|
||||
'use-cases.provider.mock.mustache',
|
||||
apiViewData,
|
||||
path.join(outputDir, 'di/use-cases', `${toCamelCase(tag)}.use-cases.provider.mock.ts`),
|
||||
generatedCount,
|
||||
'mocks'
|
||||
);
|
||||
});
|
||||
|
||||
logSuccess(
|
||||
`${generatedCount.models} Models, ${generatedCount.repositories} Repos, ${generatedCount.useCases} Use Cases, ${generatedCount.mappers} Mappers, ${generatedCount.providers} Providers generados con Mustache`
|
||||
`${generatedCount.models} Models, ${generatedCount.repositories} Repos, ${generatedCount.useCases} Use Cases, ${generatedCount.mappers} Mappers, ${generatedCount.providers} Providers, ${generatedCount.mocks} Mocks generated`
|
||||
);
|
||||
return generatedCount;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user