From c1e65294e7ef12247e00e606c65370d380e096b7 Mon Sep 17 00:00:00 2001 From: Alan Agius Date: Sun, 5 May 2019 16:06:19 +0200 Subject: [PATCH] fix(@schematics/angular): older projects are not migrated to support differential loading Fixes #14321 --- .../update-8/differential-loading.ts | 70 ++++++++++++++----- .../update-8/differential-loading_spec.ts | 21 ++++++ 2 files changed, 75 insertions(+), 16 deletions(-) diff --git a/packages/schematics/angular/migrations/update-8/differential-loading.ts b/packages/schematics/angular/migrations/update-8/differential-loading.ts index 2d55c33cd4d9..652b1acd292a 100644 --- a/packages/schematics/angular/migrations/update-8/differential-loading.ts +++ b/packages/schematics/angular/migrations/update-8/differential-loading.ts @@ -6,6 +6,7 @@ * found in the LICENSE file at https://angular.io/license */ import { + JsonAstObject, JsonParseMode, isJsonObject, join, @@ -17,6 +18,7 @@ import { Rule, Tree } from '@angular-devkit/schematics'; import { findPropertyInAstObject, insertPropertyInAstObjectInOrder, + removePropertyInAstObject, } from '../../utility/json-utils'; // tslint:disable-next-line:max-line-length @@ -40,24 +42,12 @@ not IE 9-11 # For IE 9-11 support, remove 'not'.`; export function updateES5Projects(): Rule { return (host: Tree) => { const tsConfigPath = '/tsconfig.json'; - const buffer = host.read(tsConfigPath); - if (!buffer) { - return host; - } - - const tsCfgAst = parseJsonAst(buffer.toString(), JsonParseMode.Loose); - - if (tsCfgAst.kind !== 'object') { - return host; - } - - const compilerOptions = findPropertyInAstObject(tsCfgAst, 'compilerOptions'); - if (!compilerOptions || compilerOptions.kind !== 'object') { + const compilerOptions = getCompilerOptionsAstObject(host, tsConfigPath); + if (!compilerOptions) { return host; } const recorder = host.beginUpdate(tsConfigPath); - const scriptTarget = findPropertyInAstObject(compilerOptions, 'target'); if (!scriptTarget) { insertPropertyInAstObjectInOrder(recorder, compilerOptions, 'target', 'es2015', 4); @@ -78,11 +68,11 @@ export function updateES5Projects(): Rule { host.commitUpdate(recorder); - return updateBrowserlist; + return updateProjects; }; } -function updateBrowserlist(): Rule { +function updateProjects(): Rule { return (tree) => { const angularConfigContent = tree.read('angular.json') || tree.read('.angular.json'); @@ -110,6 +100,34 @@ function updateBrowserlist(): Rule { continue; } + // Older projects app and spec ts configs had script and module set in them. + const tsConfigs = []; + const architect = project.architect; + if (isJsonObject(architect) + && isJsonObject(architect.build) + && isJsonObject(architect.build.options) + && typeof architect.build.options.tsConfig === 'string') { + tsConfigs.push(architect.build.options.tsConfig); + } + + if (isJsonObject(architect) + && isJsonObject(architect.test) + && isJsonObject(architect.test.options) + && typeof architect.test.options.tsConfig === 'string') { + tsConfigs.push(architect.test.options.tsConfig); + } + + for (const tsConfig of tsConfigs) { + const compilerOptions = getCompilerOptionsAstObject(tree, tsConfig); + if (!compilerOptions) { + continue; + } + const recorder = tree.beginUpdate(tsConfig); + removePropertyInAstObject(recorder, compilerOptions, 'target'); + removePropertyInAstObject(recorder, compilerOptions, 'module'); + tree.commitUpdate(recorder); + } + const browserslistPath = join(normalize(project.root), 'browserslist'); if (typeof project.sourceRoot === 'string') { // Move the CLI 7 style browserlist to root if it's there. @@ -143,3 +161,23 @@ function updateBrowserlist(): Rule { return tree; }; } + +function getCompilerOptionsAstObject(host: Tree, tsConfigPath: string): JsonAstObject | undefined { + const buffer = host.read(tsConfigPath); + if (!buffer) { + return; + } + + const tsCfgAst = parseJsonAst(buffer.toString(), JsonParseMode.Loose); + + if (tsCfgAst.kind !== 'object') { + return; + } + + const compilerOptions = findPropertyInAstObject(tsCfgAst, 'compilerOptions'); + if (!compilerOptions || compilerOptions.kind !== 'object') { + return; + } + + return compilerOptions; +} diff --git a/packages/schematics/angular/migrations/update-8/differential-loading_spec.ts b/packages/schematics/angular/migrations/update-8/differential-loading_spec.ts index e3faba69f09e..01bcb5809364 100644 --- a/packages/schematics/angular/migrations/update-8/differential-loading_spec.ts +++ b/packages/schematics/angular/migrations/update-8/differential-loading_spec.ts @@ -102,5 +102,26 @@ describe('Migration to version 8', () => { expect(content).toContain('Chrome 41'); expect(content).toContain('last 2 Chrome versions'); }); + + it(`should remove 'target' and 'module' from non workspace tsconfig.json`, () => { + const appTsConfig = '/tsconfig.app.json'; + const specsTsConfig = '/tsconfig.spec.json'; + const compilerOptions = { + ...oldTsConfig.compilerOptions, + target: 'es2015', + module: 'es2015', + }; + + tree.overwrite(appTsConfig, JSON.stringify({ compilerOptions }, null, 2)); + const tree2 = schematicRunner.runSchematic('migration-07', {}, tree.branch()); + const { compilerOptions: appCompilerOptions } = JSON.parse(tree2.readContent(appTsConfig)); + expect(appCompilerOptions.target).toBeUndefined(); + expect(appCompilerOptions.module).toBeUndefined(); + + const { compilerOptions: specsCompilerOptions } + = JSON.parse(tree2.readContent(specsTsConfig)); + expect(specsCompilerOptions.target).toBeUndefined(); + expect(specsCompilerOptions.module).toBeUndefined(); + }); }); });