1 | "use strict";
|
---|
2 | /**
|
---|
3 | * @license
|
---|
4 | * Copyright Google LLC All Rights Reserved.
|
---|
5 | *
|
---|
6 | * Use of this source code is governed by an MIT-style license that can be
|
---|
7 | * found in the LICENSE file at https://angular.io/license
|
---|
8 | */
|
---|
9 | var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
---|
10 | function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
---|
11 | return new (P || (P = Promise))(function (resolve, reject) {
|
---|
12 | function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
---|
13 | function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
---|
14 | function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
---|
15 | step((generator = generator.apply(thisArg, _arguments || [])).next());
|
---|
16 | });
|
---|
17 | };
|
---|
18 | Object.defineProperty(exports, "__esModule", { value: true });
|
---|
19 | exports.isDevkitMigration = exports.createMigrationSchematicRule = exports.cdkMigrations = void 0;
|
---|
20 | const tasks_1 = require("@angular-devkit/schematics/tasks");
|
---|
21 | const update_tool_1 = require("../update-tool");
|
---|
22 | const project_tsconfig_paths_1 = require("../utils/project-tsconfig-paths");
|
---|
23 | const devkit_file_system_1 = require("./devkit-file-system");
|
---|
24 | const devkit_migration_1 = require("./devkit-migration");
|
---|
25 | const find_stylesheets_1 = require("./find-stylesheets");
|
---|
26 | const attribute_selectors_1 = require("./migrations/attribute-selectors");
|
---|
27 | const class_inheritance_1 = require("./migrations/class-inheritance");
|
---|
28 | const class_names_1 = require("./migrations/class-names");
|
---|
29 | const constructor_signature_1 = require("./migrations/constructor-signature");
|
---|
30 | const css_selectors_1 = require("./migrations/css-selectors");
|
---|
31 | const element_selectors_1 = require("./migrations/element-selectors");
|
---|
32 | const input_names_1 = require("./migrations/input-names");
|
---|
33 | const method_call_arguments_1 = require("./migrations/method-call-arguments");
|
---|
34 | const misc_template_1 = require("./migrations/misc-template");
|
---|
35 | const output_names_1 = require("./migrations/output-names");
|
---|
36 | const property_names_1 = require("./migrations/property-names");
|
---|
37 | /** List of migrations which run for the CDK update. */
|
---|
38 | exports.cdkMigrations = [
|
---|
39 | attribute_selectors_1.AttributeSelectorsMigration,
|
---|
40 | class_inheritance_1.ClassInheritanceMigration,
|
---|
41 | class_names_1.ClassNamesMigration,
|
---|
42 | constructor_signature_1.ConstructorSignatureMigration,
|
---|
43 | css_selectors_1.CssSelectorsMigration,
|
---|
44 | element_selectors_1.ElementSelectorsMigration,
|
---|
45 | input_names_1.InputNamesMigration,
|
---|
46 | method_call_arguments_1.MethodCallArgumentsMigration,
|
---|
47 | misc_template_1.MiscTemplateMigration,
|
---|
48 | output_names_1.OutputNamesMigration,
|
---|
49 | property_names_1.PropertyNamesMigration,
|
---|
50 | ];
|
---|
51 | /**
|
---|
52 | * Creates a Angular schematic rule that runs the upgrade for the
|
---|
53 | * specified target version.
|
---|
54 | */
|
---|
55 | function createMigrationSchematicRule(targetVersion, extraMigrations, upgradeData, onMigrationCompleteFn) {
|
---|
56 | return (tree, context) => __awaiter(this, void 0, void 0, function* () {
|
---|
57 | const logger = context.logger;
|
---|
58 | const workspace = yield project_tsconfig_paths_1.getWorkspaceConfigGracefully(tree);
|
---|
59 | if (workspace === null) {
|
---|
60 | logger.error('Could not find workspace configuration file.');
|
---|
61 | return;
|
---|
62 | }
|
---|
63 | // Keep track of all project source files which have been checked/migrated. This is
|
---|
64 | // necessary because multiple TypeScript projects can contain the same source file and
|
---|
65 | // we don't want to check these again, as this would result in duplicated failure messages.
|
---|
66 | const analyzedFiles = new Set();
|
---|
67 | const fileSystem = new devkit_file_system_1.DevkitFileSystem(tree);
|
---|
68 | const projectNames = workspace.projects.keys();
|
---|
69 | const migrations = [...exports.cdkMigrations, ...extraMigrations];
|
---|
70 | let hasFailures = false;
|
---|
71 | for (const projectName of projectNames) {
|
---|
72 | const project = workspace.projects.get(projectName);
|
---|
73 | const buildTsconfigPath = project_tsconfig_paths_1.getTargetTsconfigPath(project, 'build');
|
---|
74 | const testTsconfigPath = project_tsconfig_paths_1.getTargetTsconfigPath(project, 'test');
|
---|
75 | if (!buildTsconfigPath && !testTsconfigPath) {
|
---|
76 | logger.warn(`Could not find TypeScript project for project: ${projectName}`);
|
---|
77 | continue;
|
---|
78 | }
|
---|
79 | // In some applications, developers will have global stylesheets which are not
|
---|
80 | // specified in any Angular component. Therefore we glob up all CSS and SCSS files
|
---|
81 | // in the project and migrate them if needed.
|
---|
82 | // TODO: rework this to collect global stylesheets from the workspace config. COMP-280.
|
---|
83 | const additionalStylesheetPaths = find_stylesheets_1.findStylesheetFiles(tree, project.root);
|
---|
84 | if (buildTsconfigPath !== null) {
|
---|
85 | runMigrations(project, projectName, buildTsconfigPath, additionalStylesheetPaths, false);
|
---|
86 | }
|
---|
87 | if (testTsconfigPath !== null) {
|
---|
88 | runMigrations(project, projectName, testTsconfigPath, additionalStylesheetPaths, true);
|
---|
89 | }
|
---|
90 | }
|
---|
91 | let runPackageManager = false;
|
---|
92 | // Run the global post migration static members for all
|
---|
93 | // registered devkit migrations.
|
---|
94 | migrations.forEach(m => {
|
---|
95 | const actionResult = isDevkitMigration(m) && m.globalPostMigration !== undefined ?
|
---|
96 | m.globalPostMigration(tree, context) : null;
|
---|
97 | if (actionResult) {
|
---|
98 | runPackageManager = runPackageManager || actionResult.runPackageManager;
|
---|
99 | }
|
---|
100 | });
|
---|
101 | // If a migration requested the package manager to run, we run it as an
|
---|
102 | // asynchronous post migration task. We cannot run it synchronously,
|
---|
103 | // as file changes from the current migration task are not applied to
|
---|
104 | // the file system yet.
|
---|
105 | if (runPackageManager) {
|
---|
106 | context.addTask(new tasks_1.NodePackageInstallTask({ quiet: false }));
|
---|
107 | }
|
---|
108 | if (onMigrationCompleteFn) {
|
---|
109 | onMigrationCompleteFn(context, targetVersion, hasFailures);
|
---|
110 | }
|
---|
111 | /** Runs the migrations for the specified workspace project. */
|
---|
112 | function runMigrations(project, projectName, tsconfigPath, additionalStylesheetPaths, isTestTarget) {
|
---|
113 | const program = update_tool_1.UpdateProject.createProgramFromTsconfig(tsconfigPath, fileSystem);
|
---|
114 | const updateContext = {
|
---|
115 | isTestTarget,
|
---|
116 | projectName,
|
---|
117 | project,
|
---|
118 | tree,
|
---|
119 | };
|
---|
120 | const updateProject = new update_tool_1.UpdateProject(updateContext, program, fileSystem, analyzedFiles, context.logger);
|
---|
121 | const result = updateProject.migrate(migrations, targetVersion, upgradeData, additionalStylesheetPaths);
|
---|
122 | // Commit all recorded edits in the update recorder. We apply the edits after all
|
---|
123 | // migrations ran because otherwise offsets in the TypeScript program would be
|
---|
124 | // shifted and individual migrations could no longer update the same source file.
|
---|
125 | fileSystem.commitEdits();
|
---|
126 | hasFailures = hasFailures || result.hasFailures;
|
---|
127 | }
|
---|
128 | });
|
---|
129 | }
|
---|
130 | exports.createMigrationSchematicRule = createMigrationSchematicRule;
|
---|
131 | /** Whether the given migration type refers to a devkit migration */
|
---|
132 | function isDevkitMigration(value) {
|
---|
133 | return devkit_migration_1.DevkitMigration.isPrototypeOf(value);
|
---|
134 | }
|
---|
135 | exports.isDevkitMigration = isDevkitMigration;
|
---|
136 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"devkit-migration-rule.js","sourceRoot":"","sources":["../../../../../../../src/cdk/schematics/ng-update/devkit-migration-rule.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {Rule, SchematicContext, Tree} from '@angular-devkit/schematics';\nimport {NodePackageInstallTask} from '@angular-devkit/schematics/tasks';\nimport {ProjectDefinition} from '@angular-devkit/core/src/workspace';\n\nimport {UpdateProject} from '../update-tool';\nimport {WorkspacePath} from '../update-tool/file-system';\nimport {MigrationCtor} from '../update-tool/migration';\nimport {TargetVersion} from '../update-tool/target-version';\nimport {getTargetTsconfigPath, getWorkspaceConfigGracefully} from '../utils/project-tsconfig-paths';\n\nimport {DevkitFileSystem} from './devkit-file-system';\nimport {DevkitContext, DevkitMigration, DevkitMigrationCtor} from './devkit-migration';\nimport {findStylesheetFiles} from './find-stylesheets';\nimport {AttributeSelectorsMigration} from './migrations/attribute-selectors';\nimport {ClassInheritanceMigration} from './migrations/class-inheritance';\nimport {ClassNamesMigration} from './migrations/class-names';\nimport {ConstructorSignatureMigration} from './migrations/constructor-signature';\nimport {CssSelectorsMigration} from './migrations/css-selectors';\nimport {ElementSelectorsMigration} from './migrations/element-selectors';\nimport {InputNamesMigration} from './migrations/input-names';\nimport {MethodCallArgumentsMigration} from './migrations/method-call-arguments';\nimport {MiscTemplateMigration} from './migrations/misc-template';\nimport {OutputNamesMigration} from './migrations/output-names';\nimport {PropertyNamesMigration} from './migrations/property-names';\nimport {UpgradeData} from './upgrade-data';\n\n\n/** List of migrations which run for the CDK update. */\nexport const cdkMigrations: MigrationCtor<UpgradeData>[] = [\n  AttributeSelectorsMigration,\n  ClassInheritanceMigration,\n  ClassNamesMigration,\n  ConstructorSignatureMigration,\n  CssSelectorsMigration,\n  ElementSelectorsMigration,\n  InputNamesMigration,\n  MethodCallArgumentsMigration,\n  MiscTemplateMigration,\n  OutputNamesMigration,\n  PropertyNamesMigration,\n];\n\nexport type NullableDevkitMigration = MigrationCtor<UpgradeData|null, DevkitContext>;\n\ntype PostMigrationFn =\n    (context: SchematicContext, targetVersion: TargetVersion, hasFailure: boolean) => void;\n\n/**\n * Creates a Angular schematic rule that runs the upgrade for the\n * specified target version.\n */\nexport function createMigrationSchematicRule(\n    targetVersion: TargetVersion, extraMigrations: NullableDevkitMigration[],\n    upgradeData: UpgradeData, onMigrationCompleteFn?: PostMigrationFn): Rule {\n  return async (tree: Tree, context: SchematicContext) => {\n    const logger = context.logger;\n    const workspace = await getWorkspaceConfigGracefully(tree);\n\n    if (workspace === null) {\n      logger.error('Could not find workspace configuration file.');\n      return;\n    }\n\n    // Keep track of all project source files which have been checked/migrated. This is\n    // necessary because multiple TypeScript projects can contain the same source file and\n    // we don't want to check these again, as this would result in duplicated failure messages.\n    const analyzedFiles = new Set<WorkspacePath>();\n    const fileSystem = new DevkitFileSystem(tree);\n    const projectNames = workspace.projects.keys();\n    const migrations = [...cdkMigrations, ...extraMigrations] as NullableDevkitMigration[];\n    let hasFailures = false;\n\n    for (const projectName of projectNames) {\n      const project = workspace.projects.get(projectName)!;\n      const buildTsconfigPath = getTargetTsconfigPath(project, 'build');\n      const testTsconfigPath = getTargetTsconfigPath(project, 'test');\n\n      if (!buildTsconfigPath && !testTsconfigPath) {\n        logger.warn(`Could not find TypeScript project for project: ${projectName}`);\n        continue;\n      }\n\n      // In some applications, developers will have global stylesheets which are not\n      // specified in any Angular component. Therefore we glob up all CSS and SCSS files\n      // in the project and migrate them if needed.\n      // TODO: rework this to collect global stylesheets from the workspace config. COMP-280.\n      const additionalStylesheetPaths = findStylesheetFiles(tree, project.root);\n\n      if (buildTsconfigPath !== null) {\n        runMigrations(project, projectName, buildTsconfigPath, additionalStylesheetPaths, false);\n      }\n      if (testTsconfigPath !== null) {\n        runMigrations(project, projectName, testTsconfigPath, additionalStylesheetPaths, true);\n      }\n    }\n\n    let runPackageManager = false;\n    // Run the global post migration static members for all\n    // registered devkit migrations.\n    migrations.forEach(m => {\n      const actionResult = isDevkitMigration(m) && m.globalPostMigration !== undefined ?\n          m.globalPostMigration(tree, context) : null;\n      if (actionResult) {\n        runPackageManager = runPackageManager || actionResult.runPackageManager;\n      }\n    });\n\n    // If a migration requested the package manager to run, we run it as an\n    // asynchronous post migration task. We cannot run it synchronously,\n    // as file changes from the current migration task are not applied to\n    // the file system yet.\n    if (runPackageManager) {\n      context.addTask(new NodePackageInstallTask({quiet: false}));\n    }\n\n    if (onMigrationCompleteFn) {\n      onMigrationCompleteFn(context, targetVersion, hasFailures);\n    }\n\n    /** Runs the migrations for the specified workspace project. */\n    function runMigrations(project: ProjectDefinition, projectName: string,\n                           tsconfigPath: WorkspacePath, additionalStylesheetPaths: string[],\n                           isTestTarget: boolean) {\n      const program = UpdateProject.createProgramFromTsconfig(tsconfigPath, fileSystem);\n      const updateContext: DevkitContext = {\n        isTestTarget,\n        projectName,\n        project,\n        tree,\n      };\n\n      const updateProject = new UpdateProject(\n        updateContext,\n        program,\n        fileSystem,\n        analyzedFiles,\n        context.logger,\n      );\n\n      const result =\n        updateProject.migrate(migrations, targetVersion, upgradeData, additionalStylesheetPaths);\n\n      // Commit all recorded edits in the update recorder. We apply the edits after all\n      // migrations ran because otherwise offsets in the TypeScript program would be\n      // shifted and individual migrations could no longer update the same source file.\n      fileSystem.commitEdits();\n\n      hasFailures = hasFailures || result.hasFailures;\n    }\n  };\n}\n\n/** Whether the given migration type refers to a devkit migration */\nexport function isDevkitMigration(value: MigrationCtor<any, any>)\n    : value is DevkitMigrationCtor<any> {\n  return DevkitMigration.isPrototypeOf(value);\n}\n"]} |
---|