Skip to content

Commit

Permalink
fix(generate): correct component path when module is generated in sub…
Browse files Browse the repository at this point in the history
…folder, and parent folder is not a module too

fixes #3255
  • Loading branch information
Meligy committed Jan 9, 2017
1 parent 338e69b commit b4e3266
Show file tree
Hide file tree
Showing 2 changed files with 44 additions and 7 deletions.
17 changes: 12 additions & 5 deletions packages/angular-cli/blueprints/module/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -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`
let 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;
Expand Down
34 changes: 32 additions & 2 deletions tests/acceptance/generate-module.spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -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();

Expand Down Expand Up @@ -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);
Expand Down Expand Up @@ -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(() => {
Expand Down

0 comments on commit b4e3266

Please sign in to comment.