@rspack/test-tools 1.0.13 → 1.1.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.
Files changed (77) hide show
  1. package/dist/case/builtin.js +1 -2
  2. package/dist/case/compiler.js +1 -2
  3. package/dist/case/config.js +1 -2
  4. package/dist/case/defaults.js +1 -2
  5. package/dist/case/diagnostic.js +1 -2
  6. package/dist/case/diff.js +1 -2
  7. package/dist/case/error.js +1 -3
  8. package/dist/case/hash.js +1 -2
  9. package/dist/case/hook.js +1 -2
  10. package/dist/case/hot-step.js +1 -2
  11. package/dist/case/hot.js +1 -2
  12. package/dist/case/new-incremental.js +4 -13
  13. package/dist/case/normal.js +2 -3
  14. package/dist/case/stats-api.js +1 -3
  15. package/dist/case/stats-output.js +1 -2
  16. package/dist/case/treeshaking.js +1 -2
  17. package/dist/case/watch.js +2 -3
  18. package/dist/compare/compare.js +3 -4
  19. package/dist/compare/format-code.js +1 -2
  20. package/dist/compare/replace-module-argument.js +1 -2
  21. package/dist/compare/replace-runtime-module-name.js +2 -3
  22. package/dist/compiler.d.ts +0 -1
  23. package/dist/compiler.js +1 -1
  24. package/dist/helper/directory.d.ts +0 -1
  25. package/dist/helper/directory.js +2 -2
  26. package/dist/helper/expect/char.d.ts +4 -0
  27. package/dist/helper/expect/char.js +25 -0
  28. package/dist/helper/expect/diff.d.ts +3 -0
  29. package/dist/helper/expect/diff.js +21 -0
  30. package/dist/helper/expect/error.d.ts +5 -0
  31. package/dist/helper/expect/error.js +51 -0
  32. package/dist/helper/expect/placeholder.d.ts +1 -0
  33. package/dist/helper/expect/placeholder.js +34 -0
  34. package/dist/helper/expect/rspack.d.ts +3 -0
  35. package/dist/helper/expect/rspack.js +14 -0
  36. package/dist/helper/expect/to-be-typeof.js +1 -2
  37. package/dist/helper/expect/to-end-with.js +1 -2
  38. package/dist/helper/expect/to-match-file-snapshot.d.ts +0 -1
  39. package/dist/helper/expect/to-match-file-snapshot.js +1 -2
  40. package/dist/helper/index.d.ts +1 -0
  41. package/dist/helper/index.js +1 -0
  42. package/dist/helper/legacy/EventSourceForNode.d.ts +2 -3
  43. package/dist/helper/legacy/FakeDocument.d.ts +2 -2
  44. package/dist/helper/legacy/asModule.d.ts +0 -1
  45. package/dist/helper/legacy/createFakeWorker.d.ts +0 -1
  46. package/dist/helper/legacy/fakeSystem.d.ts +3 -3
  47. package/dist/helper/legacy/walkCssTokens.d.ts +5 -3
  48. package/dist/helper/parse-modules.js +1 -2
  49. package/dist/helper/read-config-file.js +1 -2
  50. package/dist/helper/replace-paths.js +1 -2
  51. package/dist/helper/setup-env.d.ts +1 -0
  52. package/dist/helper/setup-env.js +1 -0
  53. package/dist/helper/setup-expect.js +58 -1
  54. package/dist/helper/update-snapshot.js +1 -2
  55. package/dist/helper/util/checkSourceMap.js +1 -1
  56. package/dist/helper/util/checkStats.d.ts +2 -0
  57. package/dist/helper/util/checkStats.js +43 -0
  58. package/dist/helper/util/filterUtil.d.ts +4 -4
  59. package/dist/helper/util/identifier.d.ts +9 -9
  60. package/dist/helper/win.js +2 -3
  61. package/dist/processor/defaults.d.ts +2 -5
  62. package/dist/processor/defaults.js +2 -36
  63. package/dist/processor/error.d.ts +4 -6
  64. package/dist/processor/error.js +5 -66
  65. package/dist/processor/hook.d.ts +0 -1
  66. package/dist/processor/hot-new-incremental.js +1 -9
  67. package/dist/processor/stats-api.d.ts +0 -3
  68. package/dist/processor/stats-api.js +0 -4
  69. package/dist/processor/stats.js +7 -28
  70. package/dist/processor/watch.js +39 -1
  71. package/dist/runner/runner/cjs.js +3 -0
  72. package/dist/runner/type.d.ts +0 -2
  73. package/dist/runner/type.js +1 -1
  74. package/dist/test/simple.js +1 -2
  75. package/dist/type.d.ts +0 -3
  76. package/dist/type.js +3 -3
  77. package/package.json +6 -5
@@ -3,7 +3,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
3
3
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.createBuiltinCase = void 0;
6
+ exports.createBuiltinCase = createBuiltinCase;
7
7
  const node_path_1 = __importDefault(require("node:path"));
8
8
  const processor_1 = require("../processor");
9
9
  const creator_1 = require("../test/creator");
@@ -36,4 +36,3 @@ const creator = new creator_1.BasicCaseCreator({
36
36
  function createBuiltinCase(name, src, dist) {
37
37
  creator.create(name, src, dist);
38
38
  }
39
- exports.createBuiltinCase = createBuiltinCase;
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.createCompilerCase = void 0;
3
+ exports.createCompilerCase = createCompilerCase;
4
4
  const processor_1 = require("../processor");
5
5
  const simple_1 = require("../test/simple");
6
6
  const type_1 = require("../type");
@@ -15,4 +15,3 @@ function createCompilerCase(name, src, dist, testConfig) {
15
15
  }));
16
16
  });
17
17
  }
18
- exports.createCompilerCase = createCompilerCase;
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.createConfigCase = void 0;
3
+ exports.createConfigCase = createConfigCase;
4
4
  const config_1 = require("../processor/config");
5
5
  const runner_1 = require("../runner");
6
6
  const creator_1 = require("../test/creator");
@@ -32,4 +32,3 @@ const creator = new creator_1.BasicCaseCreator({
32
32
  function createConfigCase(name, src, dist) {
33
33
  creator.create(name, src, dist);
34
34
  }
35
- exports.createConfigCase = createConfigCase;
@@ -3,7 +3,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
3
3
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.createDefaultsCase = void 0;
6
+ exports.createDefaultsCase = createDefaultsCase;
7
7
  const node_path_1 = __importDefault(require("node:path"));
8
8
  const processor_1 = require("../processor");
9
9
  const context_1 = require("../test/context");
@@ -37,4 +37,3 @@ function createDefaultsCase(name, src) {
37
37
  }));
38
38
  });
39
39
  }
40
- exports.createDefaultsCase = createDefaultsCase;
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.createDiagnosticCase = void 0;
3
+ exports.createDiagnosticCase = createDiagnosticCase;
4
4
  const processor_1 = require("../processor");
5
5
  const creator_1 = require("../test/creator");
6
6
  const type_1 = require("../type");
@@ -24,4 +24,3 @@ const creator = new creator_1.BasicCaseCreator({
24
24
  function createDiagnosticCase(name, src, dist) {
25
25
  creator.create(name, src, dist);
26
26
  }
27
- exports.createDiagnosticCase = createDiagnosticCase;
package/dist/case/diff.js CHANGED
@@ -3,7 +3,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
3
3
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.createDiffCase = void 0;
6
+ exports.createDiffCase = createDiffCase;
7
7
  const node_path_1 = __importDefault(require("node:path"));
8
8
  const fs_extra_1 = __importDefault(require("fs-extra"));
9
9
  const rimraf_1 = __importDefault(require("rimraf"));
@@ -77,7 +77,6 @@ function createDiffCase(name, src, dist) {
77
77
  await tester.resume();
78
78
  });
79
79
  }
80
- exports.createDiffCase = createDiffCase;
81
80
  function createDiffProcessor(config) {
82
81
  const fileCompareMap = new Map();
83
82
  const createCompareResultHandler = (type) => {
@@ -1,13 +1,12 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.createErrorCase = void 0;
3
+ exports.createErrorCase = createErrorCase;
4
4
  const processor_1 = require("../processor");
5
5
  const simple_1 = require("../test/simple");
6
6
  const type_1 = require("../type");
7
7
  let addedSerializer = false;
8
8
  function createErrorCase(name, src, dist, testConfig) {
9
9
  if (!addedSerializer) {
10
- processor_1.ErrorProcessor.addSnapshotSerializer(expect);
11
10
  addedSerializer = true;
12
11
  }
13
12
  const caseConfig = require(testConfig);
@@ -20,4 +19,3 @@ function createErrorCase(name, src, dist, testConfig) {
20
19
  }));
21
20
  });
22
21
  }
23
- exports.createErrorCase = createErrorCase;
package/dist/case/hash.js CHANGED
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.createHashCase = void 0;
3
+ exports.createHashCase = createHashCase;
4
4
  const processor_1 = require("../processor");
5
5
  const creator_1 = require("../test/creator");
6
6
  const type_1 = require("../type");
@@ -28,4 +28,3 @@ const creator = new HashCaseCreator({
28
28
  function createHashCase(name, src, dist) {
29
29
  creator.create(name, src, dist);
30
30
  }
31
- exports.createHashCase = createHashCase;
package/dist/case/hook.js CHANGED
@@ -3,7 +3,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
3
3
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.createHookCase = void 0;
6
+ exports.createHookCase = createHookCase;
7
7
  const node_path_1 = __importDefault(require("node:path"));
8
8
  const createLazyTestEnv_1 = __importDefault(require("../helper/legacy/createLazyTestEnv"));
9
9
  const processor_1 = require("../processor");
@@ -33,4 +33,3 @@ function createHookCase(name, src, dist, source) {
33
33
  });
34
34
  const env = (0, createLazyTestEnv_1.default)(10000);
35
35
  }
36
- exports.createHookCase = createHookCase;
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.createHotStepCase = void 0;
3
+ exports.createHotStepCase = createHotStepCase;
4
4
  const hot_step_1 = require("../processor/hot-step");
5
5
  const runner_1 = require("../runner");
6
6
  const creator_1 = require("../test/creator");
@@ -29,4 +29,3 @@ function createHotStepCase(name, src, dist, target) {
29
29
  const creator = getCreator(target);
30
30
  creator.create(name, src, dist);
31
31
  }
32
- exports.createHotStepCase = createHotStepCase;
package/dist/case/hot.js CHANGED
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.createHotCase = void 0;
3
+ exports.createHotCase = createHotCase;
4
4
  const hot_1 = require("../processor/hot");
5
5
  const runner_1 = require("../runner");
6
6
  const creator_1 = require("../test/creator");
@@ -29,4 +29,3 @@ function createHotCase(name, src, dist, target) {
29
29
  const creator = getCreator(target);
30
30
  creator.create(name, src, dist);
31
31
  }
32
- exports.createHotCase = createHotCase;
@@ -3,7 +3,8 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
3
3
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.createWatchNewIncrementalCase = exports.createHotNewIncrementalCase = void 0;
6
+ exports.createHotNewIncrementalCase = createHotNewIncrementalCase;
7
+ exports.createWatchNewIncrementalCase = createWatchNewIncrementalCase;
7
8
  const node_fs_1 = __importDefault(require("node:fs"));
8
9
  const node_path_1 = __importDefault(require("node:path"));
9
10
  const hot_new_incremental_1 = require("../processor/hot-new-incremental");
@@ -37,14 +38,13 @@ function createHotNewIncrementalCase(name, src, dist, target, documentType) {
37
38
  const creator = getHotCreator(target, documentType);
38
39
  creator.create(name, src, dist);
39
40
  }
40
- exports.createHotNewIncrementalCase = createHotNewIncrementalCase;
41
41
  const watchCreator = new creator_1.BasicCaseCreator({
42
42
  clean: true,
43
43
  runner: runner_1.WatchRunnerFactory,
44
44
  description: (name, index) => {
45
45
  return index === 0
46
46
  ? `${name} should compile`
47
- : "should compile the next step";
47
+ : `should compile the next step ${index}`;
48
48
  },
49
49
  describe: false,
50
50
  steps: ({ name, src, temp }) => {
@@ -64,15 +64,7 @@ const watchCreator = new creator_1.BasicCaseCreator({
64
64
  compilerType: type_1.ECompilerType.Rspack,
65
65
  configFiles: ["rspack.config.js", "webpack.config.js"],
66
66
  experiments: {
67
- incremental: {
68
- make: true,
69
- emitAssets: true,
70
- inferAsyncModules: true,
71
- providedExports: true,
72
- moduleHashes: true,
73
- moduleCodegen: true,
74
- moduleRuntimeRequirements: true
75
- }
67
+ incremental: true
76
68
  }
77
69
  })
78
70
  : new watch_1.WatchStepProcessor({
@@ -88,4 +80,3 @@ const watchCreator = new creator_1.BasicCaseCreator({
88
80
  function createWatchNewIncrementalCase(name, src, dist, temp) {
89
81
  watchCreator.create(name, src, dist, temp);
90
82
  }
91
- exports.createWatchNewIncrementalCase = createWatchNewIncrementalCase;
@@ -3,7 +3,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
3
3
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.createNormalCase = void 0;
6
+ exports.createNormalCase = createNormalCase;
7
7
  const node_path_1 = __importDefault(require("node:path"));
8
8
  const normal_1 = require("../processor/normal");
9
9
  const runner_1 = require("../runner");
@@ -16,7 +16,7 @@ const creator = new creator_1.BasicCaseCreator({
16
16
  new normal_1.NormalProcessor({
17
17
  name,
18
18
  root: node_path_1.default.resolve(__dirname, "../../tests/normalCases"),
19
- compilerOptions: {},
19
+ compilerOptions: {}, // do not used in rspack
20
20
  runable: true,
21
21
  compilerType: type_1.ECompilerType.Rspack
22
22
  })
@@ -26,4 +26,3 @@ const creator = new creator_1.BasicCaseCreator({
26
26
  function createNormalCase(name, src, dist) {
27
27
  creator.create(name, src, dist);
28
28
  }
29
- exports.createNormalCase = createNormalCase;
@@ -1,13 +1,12 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.createStatsAPICase = void 0;
3
+ exports.createStatsAPICase = createStatsAPICase;
4
4
  const processor_1 = require("../processor");
5
5
  const simple_1 = require("../test/simple");
6
6
  const type_1 = require("../type");
7
7
  let addedSerializer = false;
8
8
  function createStatsAPICase(name, src, dist, testConfig) {
9
9
  if (!addedSerializer) {
10
- processor_1.StatsAPIProcessor.addSnapshotSerializer(expect);
11
10
  addedSerializer = true;
12
11
  }
13
12
  const caseConfig = require(testConfig);
@@ -20,4 +19,3 @@ function createStatsAPICase(name, src, dist, testConfig) {
20
19
  }));
21
20
  });
22
21
  }
23
- exports.createStatsAPICase = createStatsAPICase;
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.createStatsOutputCase = void 0;
3
+ exports.createStatsOutputCase = createStatsOutputCase;
4
4
  const stats_1 = require("../processor/stats");
5
5
  const creator_1 = require("../test/creator");
6
6
  const type_1 = require("../type");
@@ -19,4 +19,3 @@ const creator = new creator_1.BasicCaseCreator({
19
19
  function createStatsOutputCase(name, src, dist) {
20
20
  creator.create(name, src, dist);
21
21
  }
22
- exports.createStatsOutputCase = createStatsOutputCase;
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.createTreeShakingCase = void 0;
3
+ exports.createTreeShakingCase = createTreeShakingCase;
4
4
  const treeshaking_1 = require("../processor/treeshaking");
5
5
  const creator_1 = require("../test/creator");
6
6
  const type_1 = require("../type");
@@ -21,4 +21,3 @@ const creator = new creator_1.BasicCaseCreator({
21
21
  function createTreeShakingCase(name, src, dist) {
22
22
  creator.create(name, src, dist);
23
23
  }
24
- exports.createTreeShakingCase = createTreeShakingCase;
@@ -3,7 +3,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
3
3
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.createWatchCase = void 0;
6
+ exports.createWatchCase = createWatchCase;
7
7
  const node_fs_1 = __importDefault(require("node:fs"));
8
8
  const node_path_1 = __importDefault(require("node:path"));
9
9
  const watch_1 = require("../processor/watch");
@@ -16,7 +16,7 @@ const creator = new creator_1.BasicCaseCreator({
16
16
  description: (name, index) => {
17
17
  return index === 0
18
18
  ? `${name} should compile`
19
- : "should compile the next step";
19
+ : `should compile the next step ${index}`;
20
20
  },
21
21
  describe: false,
22
22
  steps: ({ name, src, temp }) => {
@@ -49,4 +49,3 @@ const creator = new creator_1.BasicCaseCreator({
49
49
  function createWatchCase(name, src, dist, temp) {
50
50
  creator.create(name, src, dist, temp);
51
51
  }
52
- exports.createWatchCase = createWatchCase;
@@ -3,7 +3,9 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
3
3
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.compareContent = exports.compareModules = exports.compareFile = void 0;
6
+ exports.compareFile = compareFile;
7
+ exports.compareModules = compareModules;
8
+ exports.compareContent = compareContent;
7
9
  const fs_extra_1 = __importDefault(require("fs-extra"));
8
10
  const jest_diff_1 = require("jest-diff");
9
11
  const helper_1 = require("../helper");
@@ -66,7 +68,6 @@ function compareFile(sourceFile, distFile, compareOptions) {
66
68
  }
67
69
  return result;
68
70
  }
69
- exports.compareFile = compareFile;
70
71
  function compareModules(modules, sourceModules, distModules, compareOptions) {
71
72
  const compareResults = [];
72
73
  for (const name of modules) {
@@ -82,7 +83,6 @@ function compareModules(modules, sourceModules, distModules, compareOptions) {
82
83
  }
83
84
  return compareResults;
84
85
  }
85
- exports.compareModules = compareModules;
86
86
  function compareContent(sourceContent, distContent, compareOptions) {
87
87
  if (sourceContent) {
88
88
  if (distContent) {
@@ -145,4 +145,3 @@ function compareContent(sourceContent, distContent, compareOptions) {
145
145
  }
146
146
  };
147
147
  }
148
- exports.compareContent = compareContent;
@@ -26,7 +26,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
26
26
  return (mod && mod.__esModule) ? mod : { "default": mod };
27
27
  };
28
28
  Object.defineProperty(exports, "__esModule", { value: true });
29
- exports.formatCode = void 0;
29
+ exports.formatCode = formatCode;
30
30
  const generator_1 = __importDefault(require("@babel/generator"));
31
31
  const parser_1 = require("@babel/parser");
32
32
  const traverse_1 = __importDefault(require("@babel/traverse"));
@@ -224,4 +224,3 @@ function formatCode(name, raw, options) {
224
224
  }
225
225
  }).code.trim();
226
226
  }
227
- exports.formatCode = formatCode;
@@ -1,9 +1,8 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.replaceModuleArgument = void 0;
3
+ exports.replaceModuleArgument = replaceModuleArgument;
4
4
  function replaceModuleArgument(raw) {
5
5
  return raw
6
6
  .trim()
7
7
  .replace(/^\(function\s?\([\w_,\s]+\)\s?{/, "(function () {");
8
8
  }
9
- exports.replaceModuleArgument = replaceModuleArgument;
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.replaceRuntimeModuleName = void 0;
3
+ exports.replaceRuntimeModuleName = replaceRuntimeModuleName;
4
4
  const RUNTIME_MODULE_NAME_MAPPING = {
5
5
  "webpack/runtime/auto_public_path": "webpack/runtime/publicPath",
6
6
  "webpack/runtime/public_path": "webpack/runtime/publicPath",
@@ -42,7 +42,7 @@ const RUNTIME_MODULE_NAME_MAPPING = {
42
42
  "webpack/runtime/remote": "webpack/runtime/remotes loading",
43
43
  "webpack/runtime/share": "webpack/runtime/sharing",
44
44
  "webpack/runtime/consume_shared": "webpack/runtime/consumes",
45
- "webpack/runtime/harmony_module_decorator": "webpack/runtime/harmony module decorator",
45
+ "webpack/runtime/esm_module_decorator": "webpack/runtime/harmony module decorator",
46
46
  "webpack/runtime/node_module_decorator": "webpack/runtime/node module decorator",
47
47
  // module name with parameters
48
48
  "webpack/runtime/get_chunk_filename": "webpack/runtime/get $1 chunk filename",
@@ -64,4 +64,3 @@ function replaceRuntimeModuleName(name) {
64
64
  return name.split(rspackName).join(webpackName);
65
65
  }, name);
66
66
  }
67
- exports.replaceRuntimeModuleName = replaceRuntimeModuleName;
@@ -1,4 +1,3 @@
1
- /// <reference types="node" />
2
1
  import EventEmitter from "node:events";
3
2
  import { ECompilerType, type ITestCompilerManager, type TCompiler, type TCompilerFactories, type TCompilerOptions, type TCompilerStats } from "./type";
4
3
  export declare enum ECompilerEvent {
package/dist/compiler.js CHANGED
@@ -13,7 +13,7 @@ var ECompilerEvent;
13
13
  ECompilerEvent["Option"] = "option";
14
14
  ECompilerEvent["Create"] = "create";
15
15
  ECompilerEvent["Close"] = "close";
16
- })(ECompilerEvent = exports.ECompilerEvent || (exports.ECompilerEvent = {}));
16
+ })(ECompilerEvent || (exports.ECompilerEvent = ECompilerEvent = {}));
17
17
  exports.COMPILER_FACTORIES = {
18
18
  [type_1.ECompilerType.Rspack]: ((options) => require("@rspack/core")(options)),
19
19
  [type_1.ECompilerType.Webpack]: ((options) => require("webpack")(options))
@@ -1,4 +1,3 @@
1
- /// <reference types="jest" />
2
1
  export declare const isDirectory: (p: string) => boolean;
3
2
  export declare const isFile: (p: string) => boolean;
4
3
  export declare const isValidCaseDirectory: (name: string) => boolean;
@@ -3,7 +3,8 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
3
3
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.describeByWalk = exports.isValidCaseDirectory = exports.isFile = exports.isDirectory = void 0;
6
+ exports.isValidCaseDirectory = exports.isFile = exports.isDirectory = void 0;
7
+ exports.describeByWalk = describeByWalk;
7
8
  const node_fs_1 = __importDefault(require("node:fs"));
8
9
  const node_path_1 = __importDefault(require("node:path"));
9
10
  const _1 = require(".");
@@ -78,4 +79,3 @@ function describeByWalk(testFile, createCase, options = {}) {
78
79
  describeDirectory("", level);
79
80
  });
80
81
  }
81
- exports.describeByWalk = describeByWalk;
@@ -0,0 +1,4 @@
1
+ export declare const normalizeCRLF: (str: string) => string;
2
+ export declare const normalizeCLR: (str: string) => string;
3
+ export declare const normalizeColor: (str: string) => string;
4
+ export declare const normalizeSlash: (str: string) => string;
@@ -0,0 +1,25 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.normalizeSlash = exports.normalizeColor = exports.normalizeCLR = exports.normalizeCRLF = void 0;
4
+ const normalizeCRLF = (str) => {
5
+ return str.replace(/\r\n?/g, "\n");
6
+ };
7
+ exports.normalizeCRLF = normalizeCRLF;
8
+ const normalizeCLR = (str) => {
9
+ return (str
10
+ .replace(/\u001b\[1m\u001b\[([0-9;]*)m/g, "<CLR=$1,BOLD>")
11
+ .replace(/\u001b\[1m/g, "<CLR=BOLD>")
12
+ .replace(/\u001b\[39m\u001b\[22m/g, "</CLR>")
13
+ .replace(/\u001b\[([0-9;]*)m/g, "<CLR=$1>")
14
+ // CHANGE: The time unit display in Rspack is second
15
+ .replace(/[.0-9]+(<\/CLR>)?(\s?s)/g, "X$1$2"));
16
+ };
17
+ exports.normalizeCLR = normalizeCLR;
18
+ const normalizeColor = (str) => {
19
+ return str.replace(/\u001b\[[0-9;]*m/g, "");
20
+ };
21
+ exports.normalizeColor = normalizeColor;
22
+ const normalizeSlash = (str) => {
23
+ return str.replace(/(\\)+/g, "/");
24
+ };
25
+ exports.normalizeSlash = normalizeSlash;
@@ -0,0 +1,3 @@
1
+ export declare const normalizeDiff: (diff: {
2
+ value: string;
3
+ }) => string;
@@ -0,0 +1,21 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.normalizeDiff = void 0;
4
+ const CURRENT_CWD = process.cwd();
5
+ const quoteMeta = (str) => str.replace(/[-[\]\\/{}()*+?.^$|]/g, "\\$&");
6
+ const cwdRegExp = new RegExp(`${quoteMeta(CURRENT_CWD)}((?:\\\\)?(?:[a-zA-Z.\\-_]+\\\\)*)`, "g");
7
+ const escapedCwd = JSON.stringify(CURRENT_CWD).slice(1, -1);
8
+ const escapedCwdRegExp = new RegExp(`${quoteMeta(escapedCwd)}((?:\\\\\\\\)?(?:[a-zA-Z.\\-_]+\\\\\\\\)*)`, "g");
9
+ const normalizeDiff = (diff) => {
10
+ let normalizedStr = diff.value;
11
+ if (CURRENT_CWD.startsWith("/")) {
12
+ normalizedStr = normalizedStr.replace(new RegExp(quoteMeta(CURRENT_CWD), "g"), "<cwd>");
13
+ }
14
+ else {
15
+ normalizedStr = normalizedStr.replace(cwdRegExp, (_, g) => `<cwd>${g.replace(/\\/g, "/")}`);
16
+ normalizedStr = normalizedStr.replace(escapedCwdRegExp, (_, g) => `<cwd>${g.replace(/\\\\/g, "/")}`);
17
+ }
18
+ normalizedStr = normalizedStr.replace(/@@ -\d+,\d+ \+\d+,\d+ @@/g, "@@ ... @@");
19
+ return normalizedStr;
20
+ };
21
+ exports.normalizeDiff = normalizeDiff;
@@ -0,0 +1,5 @@
1
+ export declare function normalizeDignostics(received: {
2
+ errors: Error[];
3
+ warnings: Error[];
4
+ }): string;
5
+ export declare function normalizeError(received: Error): string;
@@ -0,0 +1,51 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.normalizeDignostics = normalizeDignostics;
7
+ exports.normalizeError = normalizeError;
8
+ const pretty_format_1 = __importDefault(require("pretty-format"));
9
+ const ERROR_STACK_PATTERN = /(│.* at ).*/g;
10
+ const prettyFormatOptions = {
11
+ escapeRegex: false,
12
+ printFunctionName: false,
13
+ plugins: [
14
+ {
15
+ test(val) {
16
+ return typeof val === "string";
17
+ },
18
+ print(val) {
19
+ return `"${val
20
+ .replace(/\\/gm, "/")
21
+ .replace(/"/gm, '\\"')
22
+ .replace(/\r?\n/gm, "\\n")}"`;
23
+ }
24
+ }
25
+ ]
26
+ };
27
+ function cleanErrorStack(message) {
28
+ return message.replace(ERROR_STACK_PATTERN, "$1xxx");
29
+ }
30
+ function cleanError(err) {
31
+ const result = {};
32
+ for (const key of Object.getOwnPropertyNames(err)) {
33
+ result[key] = err[key];
34
+ }
35
+ if (result.message) {
36
+ result.message = cleanErrorStack(err.message);
37
+ }
38
+ if (result.stack) {
39
+ result.stack = cleanErrorStack(result.stack);
40
+ }
41
+ return result;
42
+ }
43
+ function normalizeDignostics(received) {
44
+ return (0, pretty_format_1.default)({
45
+ errors: received.errors.map(e => cleanError(e)),
46
+ warnings: received.warnings.map(e => cleanError(e))
47
+ }, prettyFormatOptions).trim();
48
+ }
49
+ function normalizeError(received) {
50
+ return (0, pretty_format_1.default)(cleanError(received), prettyFormatOptions).trim();
51
+ }
@@ -0,0 +1 @@
1
+ export declare const normalizePlaceholder: any;
@@ -0,0 +1,34 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.normalizePlaceholder = void 0;
7
+ const node_path_1 = __importDefault(require("node:path"));
8
+ const { createSnapshotSerializer } = require("path-serializer");
9
+ const placeholderSerializer = createSnapshotSerializer({
10
+ workspace: node_path_1.default.resolve(__dirname, "../../../../../"),
11
+ replace: [
12
+ {
13
+ match: node_path_1.default.resolve(__dirname, "../../../rspack"),
14
+ mark: "rspack"
15
+ },
16
+ {
17
+ match: node_path_1.default.resolve(__dirname, "../../"),
18
+ mark: "test_tools"
19
+ },
20
+ {
21
+ match: /:\d+:\d+-\d+:\d+/g,
22
+ mark: "line_col_range"
23
+ },
24
+ {
25
+ match: /:\d+:\d+/g,
26
+ mark: "line_col"
27
+ }
28
+ ],
29
+ features: {
30
+ addDoubleQuotes: false,
31
+ ansiDoubleQuotes: false
32
+ }
33
+ });
34
+ exports.normalizePlaceholder = placeholderSerializer.serialize;
@@ -0,0 +1,3 @@
1
+ export declare const normalizeStats: (stats: {
2
+ value: string;
3
+ }) => string;
@@ -0,0 +1,14 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.normalizeStats = void 0;
4
+ const normalizeStats = (stats) => {
5
+ return (stats.value
6
+ // CHANGE: Remove potential line break and "|" caused by long text
7
+ .replace(/((ERROR|WARNING)([\s\S](?!╭|├))*?)(\n {2}│ )/g, "$1")
8
+ // CHANGE: Update the regular expression to replace the 'Rspack' version string
9
+ .replace(/Rspack [^ )]+(\)?) compiled/g, "Rspack x.x.x$1 compiled")
10
+ .replace(/(\w)\\(\w)/g, "$1/$2")
11
+ .replace(/, additional resolving: X ms/g, "")
12
+ .replace(/Unexpected identifier '.+?'/g, "Unexpected identifier"));
13
+ };
14
+ exports.normalizeStats = normalizeStats;
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.toBeTypeOf = void 0;
3
+ exports.toBeTypeOf = toBeTypeOf;
4
4
  // @ts-nocheck
5
5
  function toBeTypeOf(received, expected) {
6
6
  const objType = typeof received;
@@ -10,4 +10,3 @@ function toBeTypeOf(received, expected) {
10
10
  : () => `${this.utils.matcherHint(".toBeTypeOf")}\n\nExpected value to be (using typeof):\n ${this.utils.printExpected(expected)}\nReceived:\n ${this.utils.printReceived(objType)}`;
11
11
  return { message, pass };
12
12
  }
13
- exports.toBeTypeOf = toBeTypeOf;
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.toEndWith = void 0;
3
+ exports.toEndWith = toEndWith;
4
4
  // @ts-nocheck
5
5
  function toEndWith(received, expected) {
6
6
  const pass = typeof received === "string" && received.endsWith(expected);
@@ -9,4 +9,3 @@ function toEndWith(received, expected) {
9
9
  : () => `${this.utils.matcherHint(".toEndWith")}\n\nExpected value to end with:\n ${this.utils.printExpected(expected)}\nReceived:\n ${this.utils.printReceived(received)}`;
10
10
  return { message, pass };
11
11
  }
12
- exports.toEndWith = toEndWith;
@@ -1,4 +1,3 @@
1
- /// <reference types="node" />
2
1
  import type { FileMatcherOptions } from "../../../jest";
3
2
  /**
4
3
  * Match given content against content of the specified file.