From 4369fd2c6e85f60af648b890e067f1fb5db96d78 Mon Sep 17 00:00:00 2001 From: Meligy Date: Tue, 10 Jan 2017 00:44:33 +1100 Subject: [PATCH] fix(generate): correct component path when module is generated in subfolder, and parent folder is not a module too fixes #3255 --- .../angular-cli/blueprints/module/index.js | 17 +++++++--- tests/acceptance/generate-module.spec.js | 34 +++++++++++++++++-- 2 files changed, 44 insertions(+), 7 deletions(-) diff --git a/packages/angular-cli/blueprints/module/index.js b/packages/angular-cli/blueprints/module/index.js index 035a1355d7f2..4134ec82d535 100644 --- a/packages/angular-cli/blueprints/module/index.js +++ b/packages/angular-cli/blueprints/module/index.js @@ -58,13 +58,20 @@ module.exports = { }, afterInstall: function (options) { - // Note that `this.generatePath` already contains `this.dasherizedModuleName` - // So, the path will end like `name/name`, - // which is correct for `name.component.ts` created in module `name` if (this.options && this.options.routing) { - var componentPath = path.join(this.generatePath, this.dasherizedModuleName); - options.entity.name = path.relative(this.dynamicPath.appRoot, componentPath); + + // Component folder needs to be `/{moduleName}/{ComponentName}` + // Note that we are using `flat`, so no extra dir will be created + // We need the leading `/` so the component path resolution work for both cases below: + // 1. If module name has no path (no `/`), that's going to be `/mod-name/mod-name` + // as `this.dynamicPath.dir` will be the same as `this.dynamicPath.appRoot` + // 2. If it does have `/` (like `parent/mod-name`), it'll be `/parent/mod-name/mod-name` + // as `this.dynamicPath.dir` minus `this.dynamicPath.appRoot` will be `/parent` + var dmouleDir = + this.dynamicPath.dir.replace(this.dynamicPath.appRoot, '') + path.sep + this.dasherizedModuleName; + options.entity.name = dmouleDir + path.sep + this.dasherizedModuleName; options.flat = true; + options.route = false; options.inlineTemplate = false; options.inlineStyle = false; diff --git a/tests/acceptance/generate-module.spec.js b/tests/acceptance/generate-module.spec.js index 26119548215e..40a55475b867 100644 --- a/tests/acceptance/generate-module.spec.js +++ b/tests/acceptance/generate-module.spec.js @@ -2,9 +2,10 @@ const ng = require('../helpers/ng'); const tmp = require('../helpers/tmp'); - +const fs = require('fs-extra'); const existsSync = require('exists-sync'); const expect = require('chai').expect; +const Promise = require('angular-cli/ember-cli/lib/ext/promise'); const path = require('path'); const root = process.cwd(); @@ -40,7 +41,7 @@ describe('Acceptance: ng generate module', function () { }); it('ng generate module generate routing and component files when passed flag --routing', function () { - return ng(['generate', 'module', 'my-module', '--routing']).then( () => { + return ng(['generate', 'module', 'my-module', '--routing']).then(() => { expect(existsSync(path.join(testPath, 'my-module', 'my-module.module.ts'))).to.equal(true); expect(existsSync(path.join(testPath, 'my-module', 'my-module-routing.module.ts'))).to.equal(true); expect(existsSync(path.join(testPath, 'my-module', 'my-module.module.spec.ts'))).to.equal(false); @@ -72,6 +73,35 @@ describe('Acceptance: ng generate module', function () { ); }); + it('ng generate module child should work in sub-dir', function () { + fs.mkdirpSync(path.join(testPath, './sub-dir')); + return new Promise(resolve => { + process.chdir(path.join(testPath, './sub-dir')); + return resolve(); + }).then(() => + ng(['generate', 'module', 'child']).then(() => { + expect(existsSync(path.join(testPath, 'sub-dir/child', 'child.module.ts'))).to.equal(true); + expect(existsSync(path.join(testPath, 'sub-dir/child', 'child.module.spec.ts'))).to.equal(false); + expect(existsSync(path.join(testPath, 'sub-dir/child', 'child.component.ts'))).to.equal(false); + }) + ); + }); + + it('ng generate module child should work in sub-dir with routing and component files when passed --routing flag', function () { + fs.mkdirpSync(path.join(testPath, './sub-dir')); + return new Promise(resolve => { + process.chdir(path.join(testPath, './sub-dir')); + return resolve(); + }).then(() => + ng(['generate', 'module', 'child', '--routing']).then(() => { + expect(existsSync(path.join(testPath, 'sub-dir/child', 'child.module.ts'))).to.equal(true); + expect(existsSync(path.join(testPath, 'sub-dir/child', 'child-routing.module.ts'))).to.equal(true); + expect(existsSync(path.join(testPath, 'sub-dir/child', 'child.module.spec.ts'))).to.equal(false); + expect(existsSync(path.join(testPath, 'sub-dir/child', 'child.component.ts'))).to.equal(true); + }) + ); + }); + it('ng generate module should generate parent/child module with routing and component files when passed --routing flag', function () { return ng(['generate', 'module', 'parent']).then(() => ng(['generate', 'module', 'parent/child', '--routing']).then(() => {