From c50e1df950cc7ee78e9b169c53865fb6c419e6e0 Mon Sep 17 00:00:00 2001 From: TC Date: Sun, 4 Aug 2024 13:56:03 +0700 Subject: [PATCH] fix: #10494 - lb4 controller fails with controllerType as BASIC - fix CLI execution with explicit --controllerType=BASIC option - add a unit test that verifies the scaffold when explicity specifying the controller type as BASIC Signed-off-by: TC --- packages/cli/generators/controller/index.js | 3 ++- .../generators/controller.integration.js | 17 +++++++++++++++-- 2 files changed, 17 insertions(+), 3 deletions(-) diff --git a/packages/cli/generators/controller/index.js b/packages/cli/generators/controller/index.js index 459257c1d731..b6bff3d4b128 100644 --- a/packages/cli/generators/controller/index.js +++ b/packages/cli/generators/controller/index.js @@ -88,7 +88,8 @@ module.exports = class ControllerGenerator extends ArtifactGenerator { if (this.options.controllerType) { Object.assign(this.artifactInfo, { - controllerType: this.options.controllerType, + controllerType: + ControllerGenerator[this.options.controllerType.toUpperCase()], }); return; } diff --git a/packages/cli/test/integration/generators/controller.integration.js b/packages/cli/test/integration/generators/controller.integration.js index 08bfbd923594..760b25c0fb41 100644 --- a/packages/cli/test/integration/generators/controller.integration.js +++ b/packages/cli/test/integration/generators/controller.integration.js @@ -24,8 +24,12 @@ const {expectFileToMatchSnapshot} = require('../../snapshots'); const sandbox = new TestSandbox(path.resolve(__dirname, '../.sandbox')); // CLI Inputs +const defaultCLIInput = { + name: 'productReview', +}; const basicCLIInput = { name: 'productReview', + controllerType: 'ControllerGenerator.BASIC', }; const restCLIInput = { name: 'productReview', @@ -54,7 +58,7 @@ describe('lb4 controller', () => { .inDir(sandbox.path, () => testUtils.givenLBProject(sandbox.path, {excludePackageJSON: true}), ) - .withPrompts(basicCLIInput), + .withPrompts(defaultCLIInput), ).to.be.rejectedWith(/No package.json found in/); }); @@ -65,12 +69,21 @@ describe('lb4 controller', () => { .inDir(sandbox.path, () => testUtils.givenLBProject(sandbox.path, {excludeLoopbackCore: true}), ) - .withPrompts(basicCLIInput), + .withPrompts(defaultCLIInput), ).to.be.rejectedWith(/No `@loopback\/core` package found/); }); describe('basic controller', () => { it('scaffolds correct file with input', async () => { + await testUtils + .executeGenerator(generator) + .inDir(sandbox.path, () => testUtils.givenLBProject(sandbox.path)) + .withPrompts(defaultCLIInput); + + checkBasicContents(); + }); + + it('scaffolds correct file with controllerType BASIC specified explicitly', async () => { await testUtils .executeGenerator(generator) .inDir(sandbox.path, () => testUtils.givenLBProject(sandbox.path))