@nrwl/nx-plugin 15.8.4 → 15.9.0-beta.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/migrations.json +12 -0
- package/package.json +7 -6
- package/src/executors/e2e/e2e.impl.js +1 -0
- package/src/executors/e2e/e2e.impl.js.map +1 -1
- package/src/generators/e2e-project/e2e.d.ts +1 -1
- package/src/generators/e2e-project/e2e.js +1 -2
- package/src/generators/e2e-project/e2e.js.map +1 -1
- package/src/migrations/update-15-9-0/jest-29-configs.d.ts +3 -0
- package/src/migrations/update-15-9-0/jest-29-configs.js +154 -0
- package/src/migrations/update-15-9-0/jest-29-configs.js.map +1 -0
- package/src/migrations/update-15-9-0/jest-29-tests.d.ts +5 -0
- package/src/migrations/update-15-9-0/jest-29-tests.js +65 -0
- package/src/migrations/update-15-9-0/jest-29-tests.js.map +1 -0
package/migrations.json
CHANGED
|
@@ -17,6 +17,18 @@
|
|
|
17
17
|
"version": "15.0.0-beta.0",
|
|
18
18
|
"description": "Migrates executor schema files to v2",
|
|
19
19
|
"factory": "./src/migrations/update-15-0-0/specify-output-capture"
|
|
20
|
+
},
|
|
21
|
+
"update-configs-jest-29": {
|
|
22
|
+
"version": "15.9.0-beta.0",
|
|
23
|
+
"cli": "nx",
|
|
24
|
+
"description": "Update nx plugin jest configs to support jest 29 changes (https://jestjs.io/docs/upgrading-to-jest29)",
|
|
25
|
+
"factory": "./src/migrations/update-15-9-0/jest-29-configs"
|
|
26
|
+
},
|
|
27
|
+
"update-tests-jest-29": {
|
|
28
|
+
"version": "15.9.0-beta.0",
|
|
29
|
+
"cli": "nx",
|
|
30
|
+
"description": "Update nx plugin jest test files to support jest 29 changes (https://jestjs.io/docs/upgrading-to-jest29)",
|
|
31
|
+
"factory": "./src/migrations/update-15-9-0/jest-29-tests"
|
|
20
32
|
}
|
|
21
33
|
}
|
|
22
34
|
}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@nrwl/nx-plugin",
|
|
3
|
-
"version": "15.
|
|
3
|
+
"version": "15.9.0-beta.0",
|
|
4
4
|
"private": false,
|
|
5
5
|
"description": "This plugin is used to create Nx plugins! It contains generators for generating common plugin features like generators, executors, migrations and more.",
|
|
6
6
|
"repository": {
|
|
@@ -28,10 +28,11 @@
|
|
|
28
28
|
"migrations": "./migrations.json"
|
|
29
29
|
},
|
|
30
30
|
"dependencies": {
|
|
31
|
-
"@nrwl/devkit": "15.
|
|
32
|
-
"@nrwl/jest": "15.
|
|
33
|
-
"@nrwl/js": "15.
|
|
34
|
-
"@nrwl/linter": "15.
|
|
31
|
+
"@nrwl/devkit": "15.9.0-beta.0",
|
|
32
|
+
"@nrwl/jest": "15.9.0-beta.0",
|
|
33
|
+
"@nrwl/js": "15.9.0-beta.0",
|
|
34
|
+
"@nrwl/linter": "15.9.0-beta.0",
|
|
35
|
+
"@phenomnomnominal/tsquery": "4.1.1",
|
|
35
36
|
"dotenv": "~10.0.0",
|
|
36
37
|
"fs-extra": "^11.1.0",
|
|
37
38
|
"tslib": "^2.3.0"
|
|
@@ -39,5 +40,5 @@
|
|
|
39
40
|
"publishConfig": {
|
|
40
41
|
"access": "public"
|
|
41
42
|
},
|
|
42
|
-
"gitHead": "
|
|
43
|
+
"gitHead": "e3e87f57fd740bf78945a4907745d03f18d057c3"
|
|
43
44
|
}
|
|
@@ -5,6 +5,7 @@ const tslib_1 = require("tslib");
|
|
|
5
5
|
require("dotenv/config");
|
|
6
6
|
const devkit_1 = require("@nrwl/devkit");
|
|
7
7
|
const jest_impl_1 = require("@nrwl/jest/src/executors/jest/jest.impl");
|
|
8
|
+
// TODO(Caleb & Craigory): can we get rid of this and just use @nrwl/jest directly?
|
|
8
9
|
function nxPluginE2EExecutor(options, context) {
|
|
9
10
|
return tslib_1.__asyncGenerator(this, arguments, function* nxPluginE2EExecutor_1() {
|
|
10
11
|
var _a, e_1, _b, _c;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"e2e.impl.js","sourceRoot":"","sources":["../../../../../../packages/nx-plugin/src/executors/e2e/e2e.impl.ts"],"names":[],"mappings":";;;;AAAA,yBAAuB;AAIvB,yCAKsB;AAEtB,uEAAuE;AAGvE,SAAuB,mBAAmB,CACxC,OAAmC,EACnC,OAAwB;;;QAExB,MAAM,EAAE,MAAM,KAAqB,OAAO,EAAvB,WAAW,kBAAK,OAAO,EAApC,UAA0B,CAAU,CAAC;QAE3C,IAAI,OAAgB,CAAC;;YACrB,KAAsB,eAAA,KAAA,sBAAA,cAAc,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA,IAAA;gBAA/B,cAA+B;gBAA/B,WAA+B;;oBAA1C,MAAM,CAAC,KAAA,CAAA;oBAChB,IAAI;wBACF,OAAO,GAAG,sBAAM,QAAQ,CAAC,WAAW,EAAE,OAAO,CAAC,CAAA,CAAC;qBAChD;oBAAC,OAAO,CAAC,EAAE;wBACV,eAAM,CAAC,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC;wBACxB,OAAO,GAAG,KAAK,CAAC;qBACjB;;;;;aACF;;;;;;;;;QAED,6BAAO,EAAE,OAAO,EAAE,EAAC;IACrB,CAAC;CAAA;AAjBD,kDAiBC;AAED,SAAgB,cAAc,CAC5B,WAAmB,EACnB,OAAwB;;;QAExB,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,aAAa,EAAE,GAAG,IAAA,0BAAiB,EAAC,WAAW,CAAC,CAAC;QAC1E,MAAM,kBAAkB,GAAG,IAAA,0BAAiB,EAC1C,EAAE,OAAO,EAAE,MAAM,EAAE,aAAa,EAAE,EAClC,OAAO,CACR,CAAC;QACF,MAAM,mBAAmB,GAAG,MAAM,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;;YAE9E,KAA2B,eAAA,KAAA,sBAAA,sBAAM,IAAA,oBAAW,EAC1C,EAAE,OAAO,EAAE,MAAM,EAAE,aAAa,EAAE,EAClC,mBAAmB,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC,EAAE,EAC3C,OAAO,CACR,CAAA,CAAA,IAAA;gBAJ0B,cAI1B;gBAJ0B,WAI1B;;oBAJU,MAAM,MAAM,KAAA,CAAA;oBAKrB,IAAI,CAAC,MAAM,CAAC,OAAO;wBACjB,MAAM,IAAI,KAAK,CAAC,sCAAsC,CAAC,CAAC;oBAC1D,4BAAM,MAAM,CAAC,OAAO,CAAA,CAAC;;;;;aACtB;;;;;;;;;IACH,CAAC;CAAA;AAED,SAAe,QAAQ,CACrB,WAAgC,EAChC,OAAwB;;QAExB,MAAM,EAAE,OAAO,EAAE,GAAG,MAAM,IAAA,wBAAY,kCAC/B,WAAW,KAAE,KAAK,EAAE,KAAK,KAC9B,OAAO,CACR,CAAC;QAEF,OAAO,OAAO,CAAC;IACjB,CAAC;CAAA;AAED,kBAAe,mBAAmB,CAAC"}
|
|
1
|
+
{"version":3,"file":"e2e.impl.js","sourceRoot":"","sources":["../../../../../../packages/nx-plugin/src/executors/e2e/e2e.impl.ts"],"names":[],"mappings":";;;;AAAA,yBAAuB;AAIvB,yCAKsB;AAEtB,uEAAuE;AAGvE,mFAAmF;AACnF,SAAuB,mBAAmB,CACxC,OAAmC,EACnC,OAAwB;;;QAExB,MAAM,EAAE,MAAM,KAAqB,OAAO,EAAvB,WAAW,kBAAK,OAAO,EAApC,UAA0B,CAAU,CAAC;QAE3C,IAAI,OAAgB,CAAC;;YACrB,KAAsB,eAAA,KAAA,sBAAA,cAAc,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA,IAAA;gBAA/B,cAA+B;gBAA/B,WAA+B;;oBAA1C,MAAM,CAAC,KAAA,CAAA;oBAChB,IAAI;wBACF,OAAO,GAAG,sBAAM,QAAQ,CAAC,WAAW,EAAE,OAAO,CAAC,CAAA,CAAC;qBAChD;oBAAC,OAAO,CAAC,EAAE;wBACV,eAAM,CAAC,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC;wBACxB,OAAO,GAAG,KAAK,CAAC;qBACjB;;;;;aACF;;;;;;;;;QAED,6BAAO,EAAE,OAAO,EAAE,EAAC;IACrB,CAAC;CAAA;AAjBD,kDAiBC;AAED,SAAgB,cAAc,CAC5B,WAAmB,EACnB,OAAwB;;;QAExB,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,aAAa,EAAE,GAAG,IAAA,0BAAiB,EAAC,WAAW,CAAC,CAAC;QAC1E,MAAM,kBAAkB,GAAG,IAAA,0BAAiB,EAC1C,EAAE,OAAO,EAAE,MAAM,EAAE,aAAa,EAAE,EAClC,OAAO,CACR,CAAC;QACF,MAAM,mBAAmB,GAAG,MAAM,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;;YAE9E,KAA2B,eAAA,KAAA,sBAAA,sBAAM,IAAA,oBAAW,EAC1C,EAAE,OAAO,EAAE,MAAM,EAAE,aAAa,EAAE,EAClC,mBAAmB,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC,EAAE,EAC3C,OAAO,CACR,CAAA,CAAA,IAAA;gBAJ0B,cAI1B;gBAJ0B,WAI1B;;oBAJU,MAAM,MAAM,KAAA,CAAA;oBAKrB,IAAI,CAAC,MAAM,CAAC,OAAO;wBACjB,MAAM,IAAI,KAAK,CAAC,sCAAsC,CAAC,CAAC;oBAC1D,4BAAM,MAAM,CAAC,OAAO,CAAA,CAAC;;;;;aACtB;;;;;;;;;IACH,CAAC;CAAA;AAED,SAAe,QAAQ,CACrB,WAAgC,EAChC,OAAwB;;QAExB,MAAM,EAAE,OAAO,EAAE,GAAG,MAAM,IAAA,wBAAY,kCAC/B,WAAW,KAAE,KAAK,EAAE,KAAK,KAC9B,OAAO,CACR,CAAC;QAEF,OAAO,OAAO,CAAC;IACjB,CAAC;CAAA;AAED,kBAAe,mBAAmB,CAAC"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { GeneratorCallback } from '@nrwl/devkit';
|
|
2
1
|
import type { Tree } from '@nrwl/devkit';
|
|
2
|
+
import { GeneratorCallback } from '@nrwl/devkit';
|
|
3
3
|
import type { Schema } from './schema';
|
|
4
4
|
export declare function e2eProjectGenerator(host: Tree, schema: Schema): Promise<GeneratorCallback>;
|
|
5
5
|
export default e2eProjectGenerator;
|
|
@@ -7,7 +7,6 @@ const jest_1 = require("@nrwl/jest");
|
|
|
7
7
|
const js_1 = require("@nrwl/js");
|
|
8
8
|
const path = require("path");
|
|
9
9
|
const linter_1 = require("@nrwl/linter");
|
|
10
|
-
const run_tasks_in_serial_1 = require("@nrwl/workspace/src/utilities/run-tasks-in-serial");
|
|
11
10
|
function normalizeOptions(host, options) {
|
|
12
11
|
var _a, _b;
|
|
13
12
|
const { layoutDirectory, projectDirectory } = (0, devkit_1.extractLayoutDirectory)(options.projectDirectory);
|
|
@@ -94,7 +93,7 @@ function e2eProjectGenerator(host, schema) {
|
|
|
94
93
|
tasks.push(lintTask);
|
|
95
94
|
}
|
|
96
95
|
yield (0, devkit_1.formatFiles)(host);
|
|
97
|
-
return (0,
|
|
96
|
+
return (0, devkit_1.runTasksInSerial)(...tasks);
|
|
98
97
|
});
|
|
99
98
|
}
|
|
100
99
|
exports.e2eProjectGenerator = e2eProjectGenerator;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"e2e.js","sourceRoot":"","sources":["../../../../../../packages/nx-plugin/src/generators/e2e-project/e2e.ts"],"names":[],"mappings":";;;;
|
|
1
|
+
{"version":3,"file":"e2e.js","sourceRoot":"","sources":["../../../../../../packages/nx-plugin/src/generators/e2e-project/e2e.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,154 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.updateConfigsJest29 = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const devkit_1 = require("@nrwl/devkit");
|
|
6
|
+
const tsquery_1 = require("@phenomnomnominal/tsquery");
|
|
7
|
+
const ts = require("typescript");
|
|
8
|
+
const executor_options_utils_1 = require("@nrwl/devkit/src/generators/executor-options-utils");
|
|
9
|
+
const ast_utils_1 = require("@nrwl/jest/src/utils/ast-utils");
|
|
10
|
+
const find_root_jest_files_1 = require("@nrwl/jest/src/utils/config/find-root-jest-files");
|
|
11
|
+
// NOTE: this is a copy of the @nrwl/jest v15.8.0 migrations
|
|
12
|
+
function updateConfigsJest29(tree) {
|
|
13
|
+
return tslib_1.__awaiter(this, void 0, void 0, function* () {
|
|
14
|
+
const rootPreset = (0, find_root_jest_files_1.findRootJestPreset)(tree);
|
|
15
|
+
const targetsWithJest = new Set();
|
|
16
|
+
// have to use graph so the negative configuration targets are expanded
|
|
17
|
+
const graph = yield (0, devkit_1.createProjectGraphAsync)();
|
|
18
|
+
(0, executor_options_utils_1.forEachExecutorOptionsInGraph)(graph, '@nrwl/nx-plugin:e2e', (options, projectName, targetName) => {
|
|
19
|
+
if (options.jestConfig && tree.exists(options.jestConfig)) {
|
|
20
|
+
targetsWithJest.add(targetName);
|
|
21
|
+
// if the default root preset exists or if the project doesn't have a 'preset' configured
|
|
22
|
+
// -> update snapshot config
|
|
23
|
+
if (!rootPreset || !hasPresetConfigured(tree, options.jestConfig)) {
|
|
24
|
+
addSnapshotOptionsToConfig(tree, options.jestConfig, `From within the project directory, run "nx test --update-snapshot"`);
|
|
25
|
+
}
|
|
26
|
+
updateTsJestOptions(tree, options.jestConfig);
|
|
27
|
+
updateNgJestOptions(tree, options.jestConfig);
|
|
28
|
+
}
|
|
29
|
+
});
|
|
30
|
+
if (rootPreset && tree.exists(rootPreset)) {
|
|
31
|
+
const cmd = `"nx affected --targets=${Array.from(targetsWithJest).join(',')} --update-snapshot"`;
|
|
32
|
+
addSnapshotOptionsToConfig(tree, rootPreset, cmd);
|
|
33
|
+
updateTsJestOptions(tree, rootPreset);
|
|
34
|
+
updateNgJestOptions(tree, rootPreset);
|
|
35
|
+
}
|
|
36
|
+
yield (0, devkit_1.formatFiles)(tree);
|
|
37
|
+
devkit_1.logger.info((0, devkit_1.stripIndents) `NX Jest Snapshot format changed in v29.
|
|
38
|
+
By default Nx kept the older style to prevent breaking of existing tests with snapshots.
|
|
39
|
+
It's recommend you update to the latest format.
|
|
40
|
+
You can do this in your project's jest config file.
|
|
41
|
+
Remove the snapshotFormat property and re-run tests with the --update-snapshot flag.
|
|
42
|
+
More info: https://jestjs.io/docs/upgrading-to-jest29#snapshot-format`);
|
|
43
|
+
});
|
|
44
|
+
}
|
|
45
|
+
exports.updateConfigsJest29 = updateConfigsJest29;
|
|
46
|
+
function addSnapshotOptionsToConfig(tree, configPath, updateSnapshotExample) {
|
|
47
|
+
const config = tree.read(configPath, 'utf-8');
|
|
48
|
+
const hasSnapshotOptions = tsquery_1.tsquery.query(config, `${ast_utils_1.TS_QUERY_JEST_CONFIG_PREFIX} > ObjectLiteralExpression PropertyAssignment:has(Identifier[name="snapshotFormat"])`);
|
|
49
|
+
if (hasSnapshotOptions.length > 0) {
|
|
50
|
+
return;
|
|
51
|
+
}
|
|
52
|
+
const updatedConfig = tsquery_1.tsquery.replace(config, `${ast_utils_1.TS_QUERY_JEST_CONFIG_PREFIX} > ObjectLiteralExpression`, (node) => {
|
|
53
|
+
return `{
|
|
54
|
+
${node.properties.map((p) => getNodeWithComments(config, p)).join(',\n')},
|
|
55
|
+
/* TODO: Update to latest Jest snapshotFormat
|
|
56
|
+
* By default Nx has kept the older style of Jest Snapshot formats
|
|
57
|
+
* to prevent breaking of any existing tests with snapshots.
|
|
58
|
+
* It's recommend you update to the latest format.
|
|
59
|
+
* You can do this by removing snapshotFormat property
|
|
60
|
+
* and running tests with --update-snapshot flag.
|
|
61
|
+
* Example: ${updateSnapshotExample}
|
|
62
|
+
* More info: https://jestjs.io/docs/upgrading-to-jest29#snapshot-format
|
|
63
|
+
*/
|
|
64
|
+
snapshotFormat: { escapeString: true, printBasicPrototype: true }
|
|
65
|
+
}`;
|
|
66
|
+
}, { visitAllChildren: false });
|
|
67
|
+
tree.write(configPath, updatedConfig);
|
|
68
|
+
}
|
|
69
|
+
function hasPresetConfigured(tree, configPath) {
|
|
70
|
+
var _a;
|
|
71
|
+
const contents = tree.read(configPath, 'utf-8');
|
|
72
|
+
return (((_a = tsquery_1.tsquery.query(contents, `${ast_utils_1.TS_QUERY_JEST_CONFIG_PREFIX} > ObjectLiteralExpression PropertyAssignment:has(Identifier[name="preset"])`)) === null || _a === void 0 ? void 0 : _a.length) > 0);
|
|
73
|
+
}
|
|
74
|
+
function updateTsJestOptions(tree, configPath) {
|
|
75
|
+
// query for the globals property, if they don't have one then there's nothing to modify.
|
|
76
|
+
const contents = tree.read(configPath, 'utf-8');
|
|
77
|
+
let tsJestGlobalsConfig;
|
|
78
|
+
const noTsJestGlobals = tsquery_1.tsquery.replace(contents, `${ast_utils_1.TS_QUERY_JEST_CONFIG_PREFIX} > ObjectLiteralExpression PropertyAssignment:has(Identifier[name="globals"])`, (node) => {
|
|
79
|
+
if (tsJestGlobalsConfig) {
|
|
80
|
+
devkit_1.logger.warn((0, devkit_1.stripIndents) `Found more than one "globals" object in the jest config, ${configPath}
|
|
81
|
+
Will use the first one`);
|
|
82
|
+
return;
|
|
83
|
+
}
|
|
84
|
+
tsJestGlobalsConfig = getGlobalTsJestConfig(node);
|
|
85
|
+
return getGlobalConfigWithoutTsJest(node);
|
|
86
|
+
});
|
|
87
|
+
if (!tsJestGlobalsConfig) {
|
|
88
|
+
return;
|
|
89
|
+
}
|
|
90
|
+
const updatedTsJestTransformer = tsquery_1.tsquery.replace(noTsJestGlobals, `${ast_utils_1.TS_QUERY_JEST_CONFIG_PREFIX}> ObjectLiteralExpression PropertyAssignment:has(Identifier[name="transform"]) PropertyAssignment > :has(StringLiteral[value="ts-jest"], StringLiteral[value="jest-preset-angular"])`, (node) => {
|
|
91
|
+
return `[${node.getText()}, ${tsJestGlobalsConfig}]`;
|
|
92
|
+
});
|
|
93
|
+
tree.write(configPath, updatedTsJestTransformer);
|
|
94
|
+
}
|
|
95
|
+
function updateNgJestOptions(tree, configPath) {
|
|
96
|
+
const contents = tree.read(configPath, 'utf-8');
|
|
97
|
+
let ngJestTeardownConfig;
|
|
98
|
+
const noTeardownConfig = tsquery_1.tsquery.replace(contents, 'BinaryExpression:has(PropertyAccessExpression:has(Identifier[name=ngJest])) PropertyAssignment:has(Identifier[name=teardown])', (node) => {
|
|
99
|
+
ngJestTeardownConfig = node.initializer.getText();
|
|
100
|
+
return ' ';
|
|
101
|
+
});
|
|
102
|
+
if (!ngJestTeardownConfig) {
|
|
103
|
+
return;
|
|
104
|
+
}
|
|
105
|
+
let maybeUpdatedTestEnvOpts = tsquery_1.tsquery.replace(noTeardownConfig, `${ast_utils_1.TS_QUERY_JEST_CONFIG_PREFIX} > ObjectLiteralExpression PropertyAssignment:has(Identifier[name="testEnvironmentOptions"]) ObjectLiteralExpression`, (node) => {
|
|
106
|
+
return `{
|
|
107
|
+
${node.properties
|
|
108
|
+
.map((p) => getNodeWithComments(noTeardownConfig, p))
|
|
109
|
+
.join(',\n')},
|
|
110
|
+
teardown: ${ngJestTeardownConfig}
|
|
111
|
+
}`;
|
|
112
|
+
});
|
|
113
|
+
if (maybeUpdatedTestEnvOpts !== noTeardownConfig) {
|
|
114
|
+
tree.write(configPath, maybeUpdatedTestEnvOpts);
|
|
115
|
+
return;
|
|
116
|
+
}
|
|
117
|
+
// didn't find existing testEnvironmentOptions, so add the new property
|
|
118
|
+
const updatedConfig = tsquery_1.tsquery.replace(maybeUpdatedTestEnvOpts, `${ast_utils_1.TS_QUERY_JEST_CONFIG_PREFIX} > ObjectLiteralExpression`, (node) => {
|
|
119
|
+
return `{
|
|
120
|
+
${node.properties
|
|
121
|
+
.map((p) => getNodeWithComments(maybeUpdatedTestEnvOpts, p))
|
|
122
|
+
.join(',\n')},
|
|
123
|
+
testEnvironmentOptions: { teardown: ${ngJestTeardownConfig} },
|
|
124
|
+
}`;
|
|
125
|
+
}, { visitAllChildren: false });
|
|
126
|
+
tree.write(configPath, updatedConfig);
|
|
127
|
+
}
|
|
128
|
+
function getGlobalTsJestConfig(node) {
|
|
129
|
+
var _a;
|
|
130
|
+
const globalObject = node.initializer;
|
|
131
|
+
const foundConfig = globalObject.properties.find((p) => ts.isPropertyAssignment(p) && p.name.getText().includes('ts-jest'));
|
|
132
|
+
return ((_a = foundConfig === null || foundConfig === void 0 ? void 0 : foundConfig.initializer) === null || _a === void 0 ? void 0 : _a.getText()) || '';
|
|
133
|
+
}
|
|
134
|
+
function getGlobalConfigWithoutTsJest(node) {
|
|
135
|
+
var _a;
|
|
136
|
+
const globalObject = node === null || node === void 0 ? void 0 : node.initializer;
|
|
137
|
+
const withoutTsJest = (_a = globalObject === null || globalObject === void 0 ? void 0 : globalObject.properties) === null || _a === void 0 ? void 0 : _a.filter((p) => {
|
|
138
|
+
return !(ts.isPropertyAssignment(p) && p.name.getText().includes('ts-jest'));
|
|
139
|
+
});
|
|
140
|
+
const globalConfigs = withoutTsJest.map((c) => c.getText()).join(',\n');
|
|
141
|
+
return `globals: { ${globalConfigs} }`;
|
|
142
|
+
}
|
|
143
|
+
function getNodeWithComments(fullText, node) {
|
|
144
|
+
const commentRanges = ts.getLeadingCommentRanges(fullText, node.getFullStart());
|
|
145
|
+
if ((commentRanges === null || commentRanges === void 0 ? void 0 : commentRanges.length) > 0) {
|
|
146
|
+
const withComments = `${commentRanges
|
|
147
|
+
.map((r) => fullText.slice(r.pos, r.end))
|
|
148
|
+
.join('\n')}\n${node.getText()}`;
|
|
149
|
+
return withComments;
|
|
150
|
+
}
|
|
151
|
+
return node.getText();
|
|
152
|
+
}
|
|
153
|
+
exports.default = updateConfigsJest29;
|
|
154
|
+
//# sourceMappingURL=jest-29-configs.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"jest-29-configs.js","sourceRoot":"","sources":["../../../../../../packages/nx-plugin/src/migrations/update-15-9-0/jest-29-configs.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import { Tree } from '@nrwl/devkit';
|
|
2
|
+
export declare function updateTestsJest29(tree: Tree): Promise<void>;
|
|
3
|
+
export declare function updateJestMockTypes(tree: Tree, filePath: string): void;
|
|
4
|
+
export declare function updateJestMocked(tree: Tree, filePath: string): void;
|
|
5
|
+
export default updateTestsJest29;
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.updateJestMocked = exports.updateJestMockTypes = exports.updateTestsJest29 = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
5
|
+
const devkit_1 = require("@nrwl/devkit");
|
|
6
|
+
const ast_utils_1 = require("@nrwl/jest/src/utils/ast-utils");
|
|
7
|
+
const executor_options_utils_1 = require("@nrwl/devkit/src/generators/executor-options-utils");
|
|
8
|
+
const tsquery_1 = require("@phenomnomnominal/tsquery");
|
|
9
|
+
// NOTE: this is a copy of the @nrwl/jest v15.8.0 migrations
|
|
10
|
+
function updateTestsJest29(tree) {
|
|
11
|
+
return tslib_1.__awaiter(this, void 0, void 0, function* () {
|
|
12
|
+
const graph = yield (0, devkit_1.createProjectGraphAsync)();
|
|
13
|
+
(0, executor_options_utils_1.forEachExecutorOptionsInGraph)(graph, '@nrwl/nx-plugin:e2e', (options, projectName) => {
|
|
14
|
+
const projectConfig = (0, devkit_1.readProjectConfiguration)(tree, projectName);
|
|
15
|
+
(0, devkit_1.visitNotIgnoredFiles)(tree, projectConfig.sourceRoot || projectConfig.root, (file) => {
|
|
16
|
+
if (!ast_utils_1.TEST_FILE_PATTERN.test(file)) {
|
|
17
|
+
return;
|
|
18
|
+
}
|
|
19
|
+
updateJestMockTypes(tree, file);
|
|
20
|
+
updateJestMocked(tree, file);
|
|
21
|
+
});
|
|
22
|
+
});
|
|
23
|
+
yield (0, devkit_1.formatFiles)(tree);
|
|
24
|
+
});
|
|
25
|
+
}
|
|
26
|
+
exports.updateTestsJest29 = updateTestsJest29;
|
|
27
|
+
function updateJestMockTypes(tree, filePath) {
|
|
28
|
+
const contents = tree.read(filePath, 'utf-8');
|
|
29
|
+
const updatedContent = tsquery_1.tsquery.replace(contents, ':matches(ImportDeclaration, VariableStatement):has(Identifier[name="MaybeMockedDeep"], Identifier[name="MaybeMocked"]):has(StringLiteral[value="jest-mock"])', (node) => {
|
|
30
|
+
const text = node.getText();
|
|
31
|
+
return (text
|
|
32
|
+
// MaybeMockedDeep and MaybeMocked now are exported as Mocked and MockedShallow
|
|
33
|
+
.replace('MaybeMockedDeep', 'Mocked')
|
|
34
|
+
.replace('MaybeMocked', 'MockedShallow'));
|
|
35
|
+
});
|
|
36
|
+
tree.write(filePath, updatedContent);
|
|
37
|
+
}
|
|
38
|
+
exports.updateJestMockTypes = updateJestMockTypes;
|
|
39
|
+
function updateJestMocked(tree, filePath) {
|
|
40
|
+
const contents = tree.read(filePath, 'utf-8');
|
|
41
|
+
const jestGlobalNodes = tsquery_1.tsquery.query(contents, ':matches(ImportDeclaration, VariableStatement):has(Identifier[name="jest"]):has(StringLiteral[value="@jest/globals"])');
|
|
42
|
+
// this only applies if using jest from @jest/globals
|
|
43
|
+
if (jestGlobalNodes.length === 0) {
|
|
44
|
+
return;
|
|
45
|
+
}
|
|
46
|
+
const updatedJestMockTypes = tsquery_1.tsquery.replace(contents, 'CallExpression:has(Identifier[name="jest"]):has(Identifier[name="mocked"])', (node) => {
|
|
47
|
+
if (node.arguments.length === 2 &&
|
|
48
|
+
node.getText().startsWith('jest.mocked(')) {
|
|
49
|
+
const text = node.getText();
|
|
50
|
+
// jest.mocked(someObject, true); => jest.mocked(someObject);
|
|
51
|
+
if (node.arguments[1].getText() === 'true') {
|
|
52
|
+
return text.replace(/,\s*true/g, '');
|
|
53
|
+
}
|
|
54
|
+
// jest.mocked(someObject, false); => jest.mocked(someObject, {shallow: true});
|
|
55
|
+
// opt into the new behavior unless explicitly opting out
|
|
56
|
+
if (node.arguments[1].getText() === 'false') {
|
|
57
|
+
return text.replace('false', '{shallow: true}');
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
});
|
|
61
|
+
tree.write(filePath, updatedJestMockTypes);
|
|
62
|
+
}
|
|
63
|
+
exports.updateJestMocked = updateJestMocked;
|
|
64
|
+
exports.default = updateTestsJest29;
|
|
65
|
+
//# sourceMappingURL=jest-29-tests.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"jest-29-tests.js","sourceRoot":"","sources":["../../../../../../packages/nx-plugin/src/migrations/update-15-9-0/jest-29-tests.ts"],"names":[],"mappings":"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"}
|