@analogjs/vitest-angular 3.0.0-alpha.1 → 3.0.0-alpha.11
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/README.md +2 -2
- package/_virtual/_@oxc-project_runtime@0.120.0/helpers/decorate.js +9 -0
- package/package.json +8 -8
- package/setup-snapshots.d.ts +18 -18
- package/setup-snapshots.js +71 -95
- package/setup-snapshots.js.map +1 -0
- package/setup-testbed.d.ts +12 -5
- package/setup-testbed.js +23 -24
- package/setup-testbed.js.map +1 -0
- package/setup-zone.d.ts +6 -5
- package/setup-zone.js +90 -105
- package/setup-zone.js.map +1 -0
- package/src/index.d.ts +2 -2
- package/src/index.js +3 -4
- package/src/lib/builders/build/devkit.d.ts +2 -2
- package/src/lib/builders/build/devkit.js +23 -17
- package/src/lib/builders/build/devkit.js.map +1 -0
- package/src/lib/builders/build/plugins/angular-memory-plugin.d.ts +13 -20
- package/src/lib/builders/build/plugins/angular-memory-plugin.js +51 -77
- package/src/lib/builders/build/plugins/angular-memory-plugin.js.map +1 -0
- package/src/lib/builders/build/plugins/downlevel-plugin.d.ts +10 -0
- package/src/lib/builders/build/plugins/downlevel-plugin.js +24 -0
- package/src/lib/builders/build/plugins/downlevel-plugin.js.map +1 -0
- package/src/lib/builders/build/schema.js +53 -0
- package/src/lib/builders/build/schema.js.map +1 -0
- package/src/lib/builders/build/schema.json +44 -44
- package/src/lib/builders/build/utils.d.ts +3 -3
- package/src/lib/builders/build/vitest.impl.d.ts +5 -5
- package/src/lib/builders/build/vitest.impl.js +154 -190
- package/src/lib/builders/build/vitest.impl.js.map +1 -0
- package/src/lib/builders/test/schema.js +51 -0
- package/src/lib/builders/test/schema.js.map +1 -0
- package/src/lib/builders/test/schema.json +44 -44
- package/src/lib/builders/test/vitest.impl.d.ts +1 -1
- package/src/lib/builders/test/vitest.impl.js +48 -58
- package/src/lib/builders/test/vitest.impl.js.map +1 -0
- package/src/lib/tools/package.json +1 -5
- package/src/lib/tools/src/index.d.ts +1 -1
- package/src/lib/tools/src/index.js +3 -6
- package/src/lib/tools/src/schematics/setup/index.d.ts +2 -2
- package/src/lib/tools/src/schematics/setup/index.js +46 -71
- package/src/lib/tools/src/schematics/setup/index.js.map +1 -1
- package/src/lib/tools/src/schematics/utils/angular.d.ts +1 -1
- package/src/lib/tools/src/schematics/utils/angular.js +16 -22
- package/src/lib/tools/src/schematics/utils/angular.js.map +1 -1
- package/src/lib/tools/src/schematics/utils/dependencies.d.ts +2 -2
- package/src/lib/tools/src/schematics/utils/dependencies.js +34 -44
- package/src/lib/tools/src/schematics/utils/dependencies.js.map +1 -1
- package/src/lib/tools/src/schematics/utils/index.d.ts +4 -4
- package/src/lib/tools/src/schematics/utils/index.js +4 -8
- package/src/lib/tools/src/schematics/utils/versions.d.ts +1 -1
- package/src/lib/tools/src/schematics/utils/versions.js +17 -12
- package/src/lib/tools/src/schematics/utils/versions.js.map +1 -1
- package/src/lib/tools/src/schematics/utils/workspace.d.ts +8 -8
- package/src/lib/tools/src/schematics/utils/workspace.js +14 -17
- package/src/lib/tools/src/schematics/utils/workspace.js.map +1 -1
- package/src/lib/tools/src/test-global-setup.d.ts +1 -0
- package/src/lib/builders/build/plugins/esbuild-downlevel-plugin.d.ts +0 -7
- package/src/lib/builders/build/plugins/esbuild-downlevel-plugin.js +0 -23
- package/src/lib/builders/build/utils.js +0 -1
- package/src/lib/tools/src/index.js.map +0 -1
- package/src/lib/tools/src/schematics/utils/index.js.map +0 -1
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
var schema_default = {
|
|
2
|
+
$schema: "http://json-schema.org/draft-07/schema",
|
|
3
|
+
title: "Vitest schema for Test Facade.",
|
|
4
|
+
description: "Vitest target options",
|
|
5
|
+
type: "object",
|
|
6
|
+
properties: {
|
|
7
|
+
"configFile": {
|
|
8
|
+
"type": "string",
|
|
9
|
+
"description": "The path to the local vitest config",
|
|
10
|
+
"x-completion-type": "file",
|
|
11
|
+
"x-completion-glob": "@vitest.config@(.js|.ts|.mts)",
|
|
12
|
+
"aliases": ["config"]
|
|
13
|
+
},
|
|
14
|
+
"include": {
|
|
15
|
+
"type": "array",
|
|
16
|
+
"items": { "type": "string" },
|
|
17
|
+
"default": ["src/**/*.spec.ts"],
|
|
18
|
+
"description": "Globs of files to include, relative to project root."
|
|
19
|
+
},
|
|
20
|
+
"exclude": {
|
|
21
|
+
"type": "array",
|
|
22
|
+
"items": { "type": "string" },
|
|
23
|
+
"default": [
|
|
24
|
+
"node_modules",
|
|
25
|
+
"dist",
|
|
26
|
+
".idea",
|
|
27
|
+
".git",
|
|
28
|
+
".cache"
|
|
29
|
+
],
|
|
30
|
+
"description": "Globs of files to exclude, relative to the project root."
|
|
31
|
+
},
|
|
32
|
+
"setupFile": {
|
|
33
|
+
"type": "string",
|
|
34
|
+
"description": "The path to the setup file.",
|
|
35
|
+
"default": "src/test-setup.ts"
|
|
36
|
+
},
|
|
37
|
+
"tsConfig": {
|
|
38
|
+
"type": "string",
|
|
39
|
+
"description": "The relative path to the TypeScript configuration file for running tests.",
|
|
40
|
+
"default": "tsconfig.spec.json"
|
|
41
|
+
},
|
|
42
|
+
"watch": {
|
|
43
|
+
"type": "boolean",
|
|
44
|
+
"default": false,
|
|
45
|
+
"description": "Run the tests in watch mode"
|
|
46
|
+
}
|
|
47
|
+
},
|
|
48
|
+
additionalProperties: true
|
|
49
|
+
};
|
|
50
|
+
//#endregion
|
|
51
|
+
export { schema_default as default };
|
|
52
|
+
|
|
53
|
+
//# sourceMappingURL=schema.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"schema.js","names":[],"sources":["../../../../../../../packages/vitest-angular/src/lib/builders/build/schema.json"],"sourcesContent":["{\n \"$schema\": \"http://json-schema.org/draft-07/schema\",\n \"title\": \"Vitest schema for Test Facade.\",\n \"description\": \"Vitest target options\",\n \"type\": \"object\",\n \"properties\": {\n \"configFile\": {\n \"type\": \"string\",\n \"description\": \"The path to the local vitest config\",\n \"x-completion-type\": \"file\",\n \"x-completion-glob\": \"@vitest.config@(.js|.ts|.mts)\",\n \"aliases\": [\"config\"]\n },\n \"include\": {\n \"type\": \"array\",\n \"items\": {\n \"type\": \"string\"\n },\n \"default\": [\"src/**/*.spec.ts\"],\n \"description\": \"Globs of files to include, relative to project root.\"\n },\n \"exclude\": {\n \"type\": \"array\",\n \"items\": {\n \"type\": \"string\"\n },\n \"default\": [\"node_modules\", \"dist\", \".idea\", \".git\", \".cache\"],\n \"description\": \"Globs of files to exclude, relative to the project root.\"\n },\n \"setupFile\": {\n \"type\": \"string\",\n \"description\": \"The path to the setup file.\",\n \"default\": \"src/test-setup.ts\"\n },\n \"tsConfig\": {\n \"type\": \"string\",\n \"description\": \"The relative path to the TypeScript configuration file for running tests.\",\n \"default\": \"tsconfig.spec.json\"\n },\n \"watch\": {\n \"type\": \"boolean\",\n \"default\": false,\n \"description\": \"Run the tests in watch mode\"\n }\n },\n \"additionalProperties\": true\n}\n"],"mappings":""}
|
|
@@ -1,47 +1,47 @@
|
|
|
1
1
|
{
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
},
|
|
14
|
-
"include": {
|
|
15
|
-
"type": "array",
|
|
16
|
-
"items": {
|
|
17
|
-
"type": "string"
|
|
18
|
-
},
|
|
19
|
-
"default": ["src/**/*.spec.ts"],
|
|
20
|
-
"description": "Globs of files to include, relative to project root."
|
|
21
|
-
},
|
|
22
|
-
"exclude": {
|
|
23
|
-
"type": "array",
|
|
24
|
-
"items": {
|
|
25
|
-
"type": "string"
|
|
26
|
-
},
|
|
27
|
-
"default": ["node_modules", "dist", ".idea", ".git", ".cache"],
|
|
28
|
-
"description": "Globs of files to exclude, relative to the project root."
|
|
29
|
-
},
|
|
30
|
-
"setupFile": {
|
|
31
|
-
"type": "string",
|
|
32
|
-
"description": "The path to the setup file.",
|
|
33
|
-
"default": "src/test-setup.ts"
|
|
34
|
-
},
|
|
35
|
-
"tsConfig": {
|
|
36
|
-
"type": "string",
|
|
37
|
-
"description": "The relative path to the TypeScript configuration file for running tests.",
|
|
38
|
-
"default": "tsconfig.spec.json"
|
|
39
|
-
},
|
|
40
|
-
"watch": {
|
|
41
|
-
"type": "boolean",
|
|
42
|
-
"default": false,
|
|
43
|
-
"description": "Run the tests in watch mode"
|
|
44
|
-
}
|
|
2
|
+
"$schema": "http://json-schema.org/draft-07/schema",
|
|
3
|
+
"title": "Vitest schema for Test Facade.",
|
|
4
|
+
"description": "Vitest target options",
|
|
5
|
+
"type": "object",
|
|
6
|
+
"properties": {
|
|
7
|
+
"configFile": {
|
|
8
|
+
"type": "string",
|
|
9
|
+
"description": "The path to the local vitest config",
|
|
10
|
+
"x-completion-type": "file",
|
|
11
|
+
"x-completion-glob": "@vitest.config@(.js|.ts|.mts)",
|
|
12
|
+
"aliases": ["config"]
|
|
45
13
|
},
|
|
46
|
-
"
|
|
14
|
+
"include": {
|
|
15
|
+
"type": "array",
|
|
16
|
+
"items": {
|
|
17
|
+
"type": "string"
|
|
18
|
+
},
|
|
19
|
+
"default": ["src/**/*.spec.ts"],
|
|
20
|
+
"description": "Globs of files to include, relative to project root."
|
|
21
|
+
},
|
|
22
|
+
"exclude": {
|
|
23
|
+
"type": "array",
|
|
24
|
+
"items": {
|
|
25
|
+
"type": "string"
|
|
26
|
+
},
|
|
27
|
+
"default": ["node_modules", "dist", ".idea", ".git", ".cache"],
|
|
28
|
+
"description": "Globs of files to exclude, relative to the project root."
|
|
29
|
+
},
|
|
30
|
+
"setupFile": {
|
|
31
|
+
"type": "string",
|
|
32
|
+
"description": "The path to the setup file.",
|
|
33
|
+
"default": "src/test-setup.ts"
|
|
34
|
+
},
|
|
35
|
+
"tsConfig": {
|
|
36
|
+
"type": "string",
|
|
37
|
+
"description": "The relative path to the TypeScript configuration file for running tests.",
|
|
38
|
+
"default": "tsconfig.spec.json"
|
|
39
|
+
},
|
|
40
|
+
"watch": {
|
|
41
|
+
"type": "boolean",
|
|
42
|
+
"default": false,
|
|
43
|
+
"description": "Run the tests in watch mode"
|
|
44
|
+
}
|
|
45
|
+
},
|
|
46
|
+
"additionalProperties": true
|
|
47
47
|
}
|
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
import { VitestSchema } from
|
|
1
|
+
import { VitestSchema } from "./schema";
|
|
2
2
|
export declare enum ResultKind {
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
3
|
+
Failure = 0,
|
|
4
|
+
Full = 1,
|
|
5
|
+
Incremental = 2,
|
|
6
|
+
ComponentUpdate = 3
|
|
7
7
|
}
|
|
8
8
|
export declare function getExtraArgs(options: VitestSchema): Promise<Record<string, any>>;
|
|
9
9
|
declare const _default: unknown;
|
|
@@ -1,197 +1,161 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import
|
|
3
|
-
import {
|
|
4
|
-
import {
|
|
5
|
-
import {
|
|
6
|
-
import
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
1
|
+
import { createAngularMemoryPlugin } from "./plugins/angular-memory-plugin.js";
|
|
2
|
+
import { downlevelPlugin } from "./plugins/downlevel-plugin.js";
|
|
3
|
+
import { getBuildApplicationFunction } from "./devkit.js";
|
|
4
|
+
import { createBuilder } from "@angular-devkit/architect";
|
|
5
|
+
import { createRequire } from "node:module";
|
|
6
|
+
import * as path from "path";
|
|
7
|
+
import { globSync } from "tinyglobby";
|
|
8
|
+
//#region packages/vitest-angular/src/lib/builders/build/vitest.impl.ts
|
|
9
|
+
var _require = createRequire(import.meta.url);
|
|
10
|
+
var ResultKind = /* @__PURE__ */ function(ResultKind) {
|
|
11
|
+
ResultKind[ResultKind["Failure"] = 0] = "Failure";
|
|
12
|
+
ResultKind[ResultKind["Full"] = 1] = "Full";
|
|
13
|
+
ResultKind[ResultKind["Incremental"] = 2] = "Incremental";
|
|
14
|
+
ResultKind[ResultKind["ComponentUpdate"] = 3] = "ComponentUpdate";
|
|
15
|
+
return ResultKind;
|
|
16
|
+
}({});
|
|
17
|
+
process.env["VITE_CJS_IGNORE_WARNING"] = "true";
|
|
15
18
|
async function* vitestApplicationBuilder(options, context) {
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
}
|
|
95
|
-
else {
|
|
96
|
-
Object.keys(buildOutput.files).forEach((key) => {
|
|
97
|
-
outputFiles.set(key, buildOutput.files[key]);
|
|
98
|
-
});
|
|
99
|
-
}
|
|
100
|
-
}
|
|
101
|
-
if (options.watch) {
|
|
102
|
-
if (!server) {
|
|
103
|
-
server = await startVitest('test', [], config, viteConfig);
|
|
104
|
-
}
|
|
105
|
-
else {
|
|
106
|
-
await server.start([]);
|
|
107
|
-
}
|
|
108
|
-
yield { success: true };
|
|
109
|
-
}
|
|
110
|
-
else {
|
|
111
|
-
server = await startVitest('test', [], config, viteConfig);
|
|
112
|
-
const success = server?.state.getCountOfFailedTests() === 0;
|
|
113
|
-
yield { success };
|
|
114
|
-
}
|
|
115
|
-
}
|
|
116
|
-
yield { success: true };
|
|
19
|
+
process.env["TEST"] = "true";
|
|
20
|
+
process.env["VITEST"] = "true";
|
|
21
|
+
const { buildApplicationInternal, angularVersion } = await getBuildApplicationFunction();
|
|
22
|
+
const { startVitest } = await Function("return import(\"vitest/node\")")();
|
|
23
|
+
const projectConfig = await context.getProjectMetadata(context.target);
|
|
24
|
+
const extraArgs = await getExtraArgs(options);
|
|
25
|
+
const workspaceRoot = context.workspaceRoot;
|
|
26
|
+
const projectRoot = projectConfig["root"];
|
|
27
|
+
const setupFile = path.relative(projectRoot, options.setupFile);
|
|
28
|
+
const config = {
|
|
29
|
+
root: `${projectRoot || "."}`,
|
|
30
|
+
watch: options.watch === true,
|
|
31
|
+
config: options.configFile,
|
|
32
|
+
setupFiles: [setupFile],
|
|
33
|
+
globals: true,
|
|
34
|
+
pool: "vmThreads",
|
|
35
|
+
reporters: ["default"],
|
|
36
|
+
environment: "jsdom",
|
|
37
|
+
exclude: options?.exclude || [],
|
|
38
|
+
...extraArgs
|
|
39
|
+
};
|
|
40
|
+
const includes = findIncludes({
|
|
41
|
+
workspaceRoot,
|
|
42
|
+
projectRoot,
|
|
43
|
+
include: options.include,
|
|
44
|
+
exclude: options.exclude || []
|
|
45
|
+
});
|
|
46
|
+
const entryPoints = generateEntryPoints({
|
|
47
|
+
projectRoot,
|
|
48
|
+
testFiles: [path.relative(workspaceRoot, options.setupFile), ...includes.map((inc) => path.relative(workspaceRoot, inc))],
|
|
49
|
+
context,
|
|
50
|
+
angularVersion
|
|
51
|
+
});
|
|
52
|
+
const outputFiles = /* @__PURE__ */ new Map();
|
|
53
|
+
const viteConfig = { plugins: [await createAngularMemoryPlugin({
|
|
54
|
+
angularVersion,
|
|
55
|
+
workspaceRoot,
|
|
56
|
+
outputFiles
|
|
57
|
+
}), downlevelPlugin()] };
|
|
58
|
+
let server;
|
|
59
|
+
for await (const buildOutput of buildApplicationInternal({
|
|
60
|
+
aot: false,
|
|
61
|
+
index: false,
|
|
62
|
+
progress: false,
|
|
63
|
+
prerender: false,
|
|
64
|
+
optimization: false,
|
|
65
|
+
outputPath: `.angular/.vitest/${projectConfig["name"]}`,
|
|
66
|
+
outExtension: "mjs",
|
|
67
|
+
outputHashing: 2,
|
|
68
|
+
tsConfig: path.relative(workspaceRoot, options.tsConfig),
|
|
69
|
+
watch: options.watch === true,
|
|
70
|
+
entryPoints,
|
|
71
|
+
allowedCommonJsDependencies: ["@analogjs/vitest-angular/setup-zone"],
|
|
72
|
+
sourceMap: {
|
|
73
|
+
scripts: true,
|
|
74
|
+
styles: false,
|
|
75
|
+
vendor: false
|
|
76
|
+
}
|
|
77
|
+
}, context)) {
|
|
78
|
+
if (buildOutput.kind === ResultKind.Failure) return { success: false };
|
|
79
|
+
else if (buildOutput.kind === ResultKind.Incremental || buildOutput.kind === ResultKind.Full) if (buildOutput.kind === ResultKind.Full) {
|
|
80
|
+
outputFiles.clear();
|
|
81
|
+
Object.keys(buildOutput.files).forEach((key) => {
|
|
82
|
+
outputFiles.set(key, buildOutput.files[key]);
|
|
83
|
+
});
|
|
84
|
+
} else Object.keys(buildOutput.files).forEach((key) => {
|
|
85
|
+
outputFiles.set(key, buildOutput.files[key]);
|
|
86
|
+
});
|
|
87
|
+
if (options.watch) {
|
|
88
|
+
if (!server) server = await startVitest("test", [], config, viteConfig);
|
|
89
|
+
else await server.start([]);
|
|
90
|
+
yield { success: true };
|
|
91
|
+
} else {
|
|
92
|
+
server = await startVitest("test", [], config, viteConfig);
|
|
93
|
+
yield { success: server?.state.getCountOfFailedTests() === 0 };
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
yield { success: true };
|
|
117
97
|
}
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
if (!schema.default.properties[key]) {
|
|
124
|
-
extraArgs[key] = options[key];
|
|
125
|
-
}
|
|
126
|
-
}
|
|
127
|
-
return extraArgs;
|
|
98
|
+
async function getExtraArgs(options) {
|
|
99
|
+
const schema = await import("./schema.json", { with: { type: "json" } });
|
|
100
|
+
const extraArgs = {};
|
|
101
|
+
for (const key of Object.keys(options)) if (!schema.default.properties[key]) extraArgs[key] = options[key];
|
|
102
|
+
return extraArgs;
|
|
128
103
|
}
|
|
129
104
|
/**
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
105
|
+
* Finds test files to include in the Vitest run using tinyglobby pattern matching.
|
|
106
|
+
*
|
|
107
|
+
* This function:
|
|
108
|
+
* 1. Normalizes the project root path to ensure consistent path separators
|
|
109
|
+
* 2. Constructs glob patterns by prepending the project root to each include pattern
|
|
110
|
+
* 3. Uses globSync from tinyglobby to find all files matching the patterns while respecting exclusions
|
|
111
|
+
*
|
|
112
|
+
* @param options Configuration object containing workspace and project paths, include/exclude patterns
|
|
113
|
+
* @returns Array of absolute file paths that match the include patterns
|
|
114
|
+
*
|
|
115
|
+
* Sample output paths:
|
|
116
|
+
* - /workspace/apps/my-app/src/app/app.component.spec.ts
|
|
117
|
+
* - /workspace/apps/my-app/src/app/services/data.service.spec.ts
|
|
118
|
+
* - /workspace/apps/my-app/src/app/components/header/header.component.test.ts
|
|
119
|
+
* - /workspace/apps/my-app/src/app/utils/helpers.spec.ts
|
|
120
|
+
*
|
|
121
|
+
* tinyglobby vs fast-glob comparison:
|
|
122
|
+
* - Both support the same glob patterns and ignore functionality
|
|
123
|
+
* - Both are fast and efficient for file matching
|
|
124
|
+
* - tinyglobby is a lighter alternative with similar API
|
|
125
|
+
* - tinyglobby's globSync returns absolute paths by default when absolute: true is set
|
|
126
|
+
* - tinyglobby has fewer dependencies and smaller bundle size
|
|
127
|
+
*
|
|
128
|
+
* globSync options explained:
|
|
129
|
+
* - dot: true - Includes files/directories that start with a dot (e.g., .env.test)
|
|
130
|
+
* - absolute: true - Returns absolute file paths instead of relative paths
|
|
131
|
+
* - ignore: options.exclude - Excludes files matching the exclude patterns
|
|
132
|
+
*/
|
|
158
133
|
function findIncludes(options) {
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
// Use globSync from tinyglobby to find all files matching the patterns
|
|
167
|
-
// Returns absolute file paths that match the include patterns while respecting exclusions
|
|
168
|
-
return globSync(globs, {
|
|
169
|
-
dot: true, // Include files/directories starting with dot (e.g., .env.test)
|
|
170
|
-
absolute: true, // Return absolute file paths
|
|
171
|
-
ignore: options.exclude, // Exclude files matching these patterns
|
|
172
|
-
});
|
|
134
|
+
const { normalizePath } = _require("vite");
|
|
135
|
+
const projectRoot = normalizePath(path.resolve(options.workspaceRoot, options.projectRoot));
|
|
136
|
+
return globSync([...options.include.map((glob) => `${projectRoot}/${glob}`)], {
|
|
137
|
+
dot: true,
|
|
138
|
+
absolute: true,
|
|
139
|
+
ignore: options.exclude
|
|
140
|
+
});
|
|
173
141
|
}
|
|
174
|
-
function generateEntryPoints({ projectRoot, testFiles, context, angularVersion
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
while (seen.has(uniqueName)) {
|
|
189
|
-
uniqueName = `${relativePath}-${suffix}`;
|
|
190
|
-
++suffix;
|
|
191
|
-
}
|
|
192
|
-
seen.add(uniqueName);
|
|
193
|
-
return [uniqueName, testFile];
|
|
194
|
-
}));
|
|
142
|
+
function generateEntryPoints({ projectRoot, testFiles, context, angularVersion }) {
|
|
143
|
+
if (angularVersion < 19) return testFiles;
|
|
144
|
+
const seen = /* @__PURE__ */ new Set();
|
|
145
|
+
return new Map(Array.from(testFiles, (testFile) => {
|
|
146
|
+
const relativePath = path.relative(testFile.startsWith(projectRoot) ? projectRoot : context.workspaceRoot, testFile).replace(/^[./]+/, "_").replace(/\//g, "-");
|
|
147
|
+
let uniqueName = `spec-${path.basename(relativePath, path.extname(relativePath))}`;
|
|
148
|
+
let suffix = 2;
|
|
149
|
+
while (seen.has(uniqueName)) {
|
|
150
|
+
uniqueName = `${relativePath}-${suffix}`;
|
|
151
|
+
++suffix;
|
|
152
|
+
}
|
|
153
|
+
seen.add(uniqueName);
|
|
154
|
+
return [uniqueName, testFile];
|
|
155
|
+
}));
|
|
195
156
|
}
|
|
196
|
-
|
|
197
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"vitest.impl.js","sourceRoot":"","sources":["../../../../../../../packages/vitest-angular/src/lib/builders/build/vitest.impl.ts"],"names":[],"mappings":"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","sourcesContent":["import { createBuilder } from '@angular-devkit/architect';\nimport * as path from 'path';\nimport type { Vitest } from 'vitest/node';\nimport type { Plugin, UserConfig } from 'vite';\nimport type { TestUserConfig as VitestConfig } from 'vitest/node';\nimport { globSync } from 'tinyglobby';\n\nimport { VitestSchema } from './schema';\nimport { createAngularMemoryPlugin } from './plugins/angular-memory-plugin';\nimport { esbuildDownlevelPlugin } from './plugins/esbuild-downlevel-plugin';\nimport { getBuildApplicationFunction } from './devkit';\n\nexport enum ResultKind {\n  Failure,\n  Full,\n  Incremental,\n  ComponentUpdate,\n}\n\nprocess.env['VITE_CJS_IGNORE_WARNING'] = 'true';\n\nasync function* vitestApplicationBuilder(\n  options: VitestSchema,\n  context: any,\n): AsyncIterable<{ success: boolean }> {\n  process.env['TEST'] = 'true';\n  process.env['VITEST'] = 'true';\n\n  const { buildApplicationInternal, angularVersion } =\n    await getBuildApplicationFunction();\n  const { startVitest } = await (Function(\n    'return import(\"vitest/node\")',\n  )() as Promise<typeof import('vitest/node')>);\n\n  const projectConfig = await context.getProjectMetadata(context.target);\n  const extraArgs = await getExtraArgs(options);\n  const workspaceRoot = context.workspaceRoot;\n  const projectRoot = projectConfig['root'];\n  const setupFile = path.relative(projectRoot, options.setupFile);\n\n  const config: VitestConfig = {\n    root: `${projectRoot || '.'}`,\n    watch: options.watch === true,\n    config: options.configFile,\n    setupFiles: [setupFile],\n    globals: true,\n    pool: 'vmThreads',\n    reporters: ['default'],\n    environment: 'jsdom',\n    exclude: options?.exclude || [],\n    ...extraArgs,\n  };\n\n  const includes: string[] = findIncludes({\n    workspaceRoot,\n    projectRoot,\n    include: options.include,\n    exclude: options.exclude || [],\n  });\n\n  const testFiles = [\n    path.relative(workspaceRoot, options.setupFile),\n    ...includes.map((inc) => path.relative(workspaceRoot, inc)),\n  ];\n\n  const entryPoints = generateEntryPoints({\n    projectRoot: projectRoot,\n    testFiles,\n    context,\n    angularVersion,\n  });\n\n  const outputFiles = new Map();\n\n  const viteConfig: any = {\n    plugins: [\n      (await createAngularMemoryPlugin({\n        angularVersion,\n        workspaceRoot,\n        outputFiles,\n      })) as Plugin,\n      await esbuildDownlevelPlugin(),\n    ],\n  };\n\n  let server: Vitest | undefined;\n  for await (const buildOutput of buildApplicationInternal(\n    {\n      aot: false,\n      index: false,\n      progress: false,\n      prerender: false,\n      optimization: false,\n      outputPath: `.angular/.vitest/${projectConfig['name']}`,\n      outExtension: 'mjs',\n      outputHashing: 2, // None\n      tsConfig: path.relative(workspaceRoot, options.tsConfig),\n      watch: options.watch === true,\n      entryPoints,\n      allowedCommonJsDependencies: ['@analogjs/vitest-angular/setup-zone'],\n      sourceMap: {\n        scripts: true,\n        styles: false,\n        vendor: false,\n      },\n    },\n    context,\n  )) {\n    if (buildOutput.kind === ResultKind.Failure) {\n      return { success: false };\n    } else if (\n      buildOutput.kind === ResultKind.Incremental ||\n      buildOutput.kind === ResultKind.Full\n    ) {\n      if (buildOutput.kind === ResultKind.Full) {\n        outputFiles.clear();\n        Object.keys(buildOutput.files).forEach((key) => {\n          outputFiles.set(key, buildOutput.files[key]);\n        });\n      } else {\n        Object.keys(buildOutput.files).forEach((key) => {\n          outputFiles.set(key, buildOutput.files[key]);\n        });\n      }\n    }\n\n    if (options.watch) {\n      if (!server) {\n        server = await startVitest('test', [], config, viteConfig);\n      } else {\n        await server.start([]);\n      }\n\n      yield { success: true };\n    } else {\n      server = await startVitest('test', [], config, viteConfig);\n\n      const success = server?.state.getCountOfFailedTests() === 0;\n\n      yield { success };\n    }\n  }\n\n  yield { success: true };\n}\n\nexport async function getExtraArgs(\n  options: VitestSchema,\n): Promise<Record<string, any>> {\n  // support passing extra args to Vitest CLI\n  const schema = await import('./schema.json', { with: { type: 'json' } });\n  const extraArgs: Record<string, any> = {};\n  for (const key of Object.keys(options)) {\n    if (!(schema as any).default.properties[key]) {\n      extraArgs[key] = (options as any)[key];\n    }\n  }\n\n  return extraArgs;\n}\n\n/**\n * Finds test files to include in the Vitest run using tinyglobby pattern matching.\n *\n * This function:\n * 1. Normalizes the project root path to ensure consistent path separators\n * 2. Constructs glob patterns by prepending the project root to each include pattern\n * 3. Uses globSync from tinyglobby to find all files matching the patterns while respecting exclusions\n *\n * @param options Configuration object containing workspace and project paths, include/exclude patterns\n * @returns Array of absolute file paths that match the include patterns\n *\n * Sample output paths:\n * - /workspace/apps/my-app/src/app/app.component.spec.ts\n * - /workspace/apps/my-app/src/app/services/data.service.spec.ts\n * - /workspace/apps/my-app/src/app/components/header/header.component.test.ts\n * - /workspace/apps/my-app/src/app/utils/helpers.spec.ts\n *\n * tinyglobby vs fast-glob comparison:\n * - Both support the same glob patterns and ignore functionality\n * - Both are fast and efficient for file matching\n * - tinyglobby is a lighter alternative with similar API\n * - tinyglobby's globSync returns absolute paths by default when absolute: true is set\n * - tinyglobby has fewer dependencies and smaller bundle size\n *\n * globSync options explained:\n * - dot: true - Includes files/directories that start with a dot (e.g., .env.test)\n * - absolute: true - Returns absolute file paths instead of relative paths\n * - ignore: options.exclude - Excludes files matching the exclude patterns\n */\nfunction findIncludes(options: {\n  workspaceRoot: string;\n  projectRoot: string;\n  include: string[];\n  exclude: string[];\n}) {\n  const { normalizePath } = require('vite');\n\n  // Normalize project root path to ensure consistent path separators across platforms\n  const projectRoot = normalizePath(\n    path.resolve(options.workspaceRoot, options.projectRoot),\n  );\n\n  // Construct glob patterns by prepending project root to each include pattern\n  // Example: if include=['**/*.spec.ts'] and projectRoot='/workspace/apps/my-app'\n  // Result: ['/workspace/apps/my-app/**/*.spec.ts']\n  const globs = [...options.include.map((glob) => `${projectRoot}/${glob}`)];\n\n  // Use globSync from tinyglobby to find all files matching the patterns\n  // Returns absolute file paths that match the include patterns while respecting exclusions\n  return globSync(globs, {\n    dot: true, // Include files/directories starting with dot (e.g., .env.test)\n    absolute: true, // Return absolute file paths\n    ignore: options.exclude, // Exclude files matching these patterns\n  });\n}\n\nfunction generateEntryPoints({\n  projectRoot,\n  testFiles,\n  context,\n  angularVersion,\n}: {\n  projectRoot: string;\n  testFiles: string[];\n  context: any;\n  angularVersion: number;\n}) {\n  if (angularVersion < 19) {\n    return testFiles;\n  }\n\n  const seen = new Set();\n\n  return new Map(\n    Array.from(testFiles, (testFile) => {\n      const relativePath = path\n        .relative(\n          testFile.startsWith(projectRoot)\n            ? projectRoot\n            : context.workspaceRoot,\n          testFile,\n        )\n        .replace(/^[./]+/, '_')\n        .replace(/\\//g, '-');\n\n      let uniqueName = `spec-${path.basename(\n        relativePath,\n        path.extname(relativePath),\n      )}`;\n      let suffix = 2;\n      while (seen.has(uniqueName)) {\n        uniqueName = `${relativePath}-${suffix}`;\n        ++suffix;\n      }\n      seen.add(uniqueName);\n\n      return [uniqueName, testFile];\n    }),\n  );\n}\n\nexport default createBuilder(vitestApplicationBuilder) as unknown;\n"]}
|
|
157
|
+
var vitest_impl_default = createBuilder(vitestApplicationBuilder);
|
|
158
|
+
//#endregion
|
|
159
|
+
export { vitest_impl_default as default };
|
|
160
|
+
|
|
161
|
+
//# sourceMappingURL=vitest.impl.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"vitest.impl.js","names":[],"sources":["../../../../../../../packages/vitest-angular/src/lib/builders/build/vitest.impl.ts"],"sourcesContent":["import { createBuilder } from '@angular-devkit/architect';\nimport { createRequire } from 'node:module';\nimport * as path from 'path';\nimport type { Vitest } from 'vitest/node';\nimport type { Plugin, UserConfig } from 'vite';\nimport type { TestUserConfig as VitestConfig } from 'vitest/node';\nimport { globSync } from 'tinyglobby';\n\nimport { VitestSchema } from './schema';\nimport { createAngularMemoryPlugin } from './plugins/angular-memory-plugin';\nimport { downlevelPlugin } from './plugins/downlevel-plugin';\nimport { getBuildApplicationFunction } from './devkit';\n\nconst _require = createRequire(import.meta.url);\n\nexport enum ResultKind {\n Failure,\n Full,\n Incremental,\n ComponentUpdate,\n}\n\nprocess.env['VITE_CJS_IGNORE_WARNING'] = 'true';\n\nasync function* vitestApplicationBuilder(\n options: VitestSchema,\n context: any,\n): AsyncIterable<{ success: boolean }> {\n process.env['TEST'] = 'true';\n process.env['VITEST'] = 'true';\n\n const { buildApplicationInternal, angularVersion } =\n await getBuildApplicationFunction();\n const { startVitest } = await (Function(\n 'return import(\"vitest/node\")',\n )() as Promise<typeof import('vitest/node')>);\n\n const projectConfig = await context.getProjectMetadata(context.target);\n const extraArgs = await getExtraArgs(options);\n const workspaceRoot = context.workspaceRoot;\n const projectRoot = projectConfig['root'];\n const setupFile = path.relative(projectRoot, options.setupFile);\n\n const config: VitestConfig = {\n root: `${projectRoot || '.'}`,\n watch: options.watch === true,\n config: options.configFile,\n setupFiles: [setupFile],\n globals: true,\n pool: 'vmThreads',\n reporters: ['default'],\n environment: 'jsdom',\n exclude: options?.exclude || [],\n ...extraArgs,\n };\n\n const includes: string[] = findIncludes({\n workspaceRoot,\n projectRoot,\n include: options.include,\n exclude: options.exclude || [],\n });\n\n const testFiles = [\n path.relative(workspaceRoot, options.setupFile),\n ...includes.map((inc) => path.relative(workspaceRoot, inc)),\n ];\n\n const entryPoints = generateEntryPoints({\n projectRoot: projectRoot,\n testFiles,\n context,\n angularVersion,\n });\n\n const outputFiles = new Map();\n\n const viteConfig: any = {\n plugins: [\n (await createAngularMemoryPlugin({\n angularVersion,\n workspaceRoot,\n outputFiles,\n })) as Plugin,\n downlevelPlugin(),\n ],\n };\n\n let server: Vitest | undefined;\n for await (const buildOutput of buildApplicationInternal(\n {\n aot: false,\n index: false,\n progress: false,\n prerender: false,\n optimization: false,\n outputPath: `.angular/.vitest/${projectConfig['name']}`,\n outExtension: 'mjs',\n outputHashing: 2, // None\n tsConfig: path.relative(workspaceRoot, options.tsConfig),\n watch: options.watch === true,\n entryPoints,\n allowedCommonJsDependencies: ['@analogjs/vitest-angular/setup-zone'],\n sourceMap: {\n scripts: true,\n styles: false,\n vendor: false,\n },\n },\n context,\n )) {\n if (buildOutput.kind === ResultKind.Failure) {\n return { success: false };\n } else if (\n buildOutput.kind === ResultKind.Incremental ||\n buildOutput.kind === ResultKind.Full\n ) {\n if (buildOutput.kind === ResultKind.Full) {\n outputFiles.clear();\n Object.keys(buildOutput.files).forEach((key) => {\n outputFiles.set(key, buildOutput.files[key]);\n });\n } else {\n Object.keys(buildOutput.files).forEach((key) => {\n outputFiles.set(key, buildOutput.files[key]);\n });\n }\n }\n\n if (options.watch) {\n if (!server) {\n server = await startVitest('test', [], config, viteConfig);\n } else {\n await server.start([]);\n }\n\n yield { success: true };\n } else {\n server = await startVitest('test', [], config, viteConfig);\n\n const success = server?.state.getCountOfFailedTests() === 0;\n\n yield { success };\n }\n }\n\n yield { success: true };\n}\n\nexport async function getExtraArgs(\n options: VitestSchema,\n): Promise<Record<string, any>> {\n // support passing extra args to Vitest CLI\n const schema = await import('./schema.json', { with: { type: 'json' } });\n const extraArgs: Record<string, any> = {};\n for (const key of Object.keys(options)) {\n if (!(schema as any).default.properties[key]) {\n extraArgs[key] = (options as any)[key];\n }\n }\n\n return extraArgs;\n}\n\n/**\n * Finds test files to include in the Vitest run using tinyglobby pattern matching.\n *\n * This function:\n * 1. Normalizes the project root path to ensure consistent path separators\n * 2. Constructs glob patterns by prepending the project root to each include pattern\n * 3. Uses globSync from tinyglobby to find all files matching the patterns while respecting exclusions\n *\n * @param options Configuration object containing workspace and project paths, include/exclude patterns\n * @returns Array of absolute file paths that match the include patterns\n *\n * Sample output paths:\n * - /workspace/apps/my-app/src/app/app.component.spec.ts\n * - /workspace/apps/my-app/src/app/services/data.service.spec.ts\n * - /workspace/apps/my-app/src/app/components/header/header.component.test.ts\n * - /workspace/apps/my-app/src/app/utils/helpers.spec.ts\n *\n * tinyglobby vs fast-glob comparison:\n * - Both support the same glob patterns and ignore functionality\n * - Both are fast and efficient for file matching\n * - tinyglobby is a lighter alternative with similar API\n * - tinyglobby's globSync returns absolute paths by default when absolute: true is set\n * - tinyglobby has fewer dependencies and smaller bundle size\n *\n * globSync options explained:\n * - dot: true - Includes files/directories that start with a dot (e.g., .env.test)\n * - absolute: true - Returns absolute file paths instead of relative paths\n * - ignore: options.exclude - Excludes files matching the exclude patterns\n */\nfunction findIncludes(options: {\n workspaceRoot: string;\n projectRoot: string;\n include: string[];\n exclude: string[];\n}) {\n const { normalizePath } = _require('vite');\n\n // Normalize project root path to ensure consistent path separators across platforms\n const projectRoot = normalizePath(\n path.resolve(options.workspaceRoot, options.projectRoot),\n );\n\n // Construct glob patterns by prepending project root to each include pattern\n // Example: if include=['**/*.spec.ts'] and projectRoot='/workspace/apps/my-app'\n // Result: ['/workspace/apps/my-app/**/*.spec.ts']\n const globs = [...options.include.map((glob) => `${projectRoot}/${glob}`)];\n\n // Use globSync from tinyglobby to find all files matching the patterns\n // Returns absolute file paths that match the include patterns while respecting exclusions\n return globSync(globs, {\n dot: true, // Include files/directories starting with dot (e.g., .env.test)\n absolute: true, // Return absolute file paths\n ignore: options.exclude, // Exclude files matching these patterns\n });\n}\n\nfunction generateEntryPoints({\n projectRoot,\n testFiles,\n context,\n angularVersion,\n}: {\n projectRoot: string;\n testFiles: string[];\n context: any;\n angularVersion: number;\n}) {\n if (angularVersion < 19) {\n return testFiles;\n }\n\n const seen = new Set();\n\n return new Map(\n Array.from(testFiles, (testFile) => {\n const relativePath = path\n .relative(\n testFile.startsWith(projectRoot)\n ? projectRoot\n : context.workspaceRoot,\n testFile,\n )\n .replace(/^[./]+/, '_')\n .replace(/\\//g, '-');\n\n let uniqueName = `spec-${path.basename(\n relativePath,\n path.extname(relativePath),\n )}`;\n let suffix = 2;\n while (seen.has(uniqueName)) {\n uniqueName = `${relativePath}-${suffix}`;\n ++suffix;\n }\n seen.add(uniqueName);\n\n return [uniqueName, testFile];\n }),\n );\n}\n\nexport default createBuilder(vitestApplicationBuilder) as unknown;\n"],"mappings":";;;;;;;;AAaA,IAAM,WAAW,cAAc,OAAO,KAAK,IAAI;AAE/C,IAAY,aAAL,yBAAA,YAAA;AACL,YAAA,WAAA,aAAA,KAAA;AACA,YAAA,WAAA,UAAA,KAAA;AACA,YAAA,WAAA,iBAAA,KAAA;AACA,YAAA,WAAA,qBAAA,KAAA;;KACD;AAED,QAAQ,IAAI,6BAA6B;AAEzC,gBAAgB,yBACd,SACA,SACqC;AACrC,SAAQ,IAAI,UAAU;AACtB,SAAQ,IAAI,YAAY;CAExB,MAAM,EAAE,0BAA0B,mBAChC,MAAM,6BAA6B;CACrC,MAAM,EAAE,gBAAgB,MAAO,SAC7B,iCACD,EAAE;CAEH,MAAM,gBAAgB,MAAM,QAAQ,mBAAmB,QAAQ,OAAO;CACtE,MAAM,YAAY,MAAM,aAAa,QAAQ;CAC7C,MAAM,gBAAgB,QAAQ;CAC9B,MAAM,cAAc,cAAc;CAClC,MAAM,YAAY,KAAK,SAAS,aAAa,QAAQ,UAAU;CAE/D,MAAM,SAAuB;EAC3B,MAAM,GAAG,eAAe;EACxB,OAAO,QAAQ,UAAU;EACzB,QAAQ,QAAQ;EAChB,YAAY,CAAC,UAAU;EACvB,SAAS;EACT,MAAM;EACN,WAAW,CAAC,UAAU;EACtB,aAAa;EACb,SAAS,SAAS,WAAW,EAAE;EAC/B,GAAG;EACJ;CAED,MAAM,WAAqB,aAAa;EACtC;EACA;EACA,SAAS,QAAQ;EACjB,SAAS,QAAQ,WAAW,EAAE;EAC/B,CAAC;CAOF,MAAM,cAAc,oBAAoB;EACzB;EACb,WAPgB,CAChB,KAAK,SAAS,eAAe,QAAQ,UAAU,EAC/C,GAAG,SAAS,KAAK,QAAQ,KAAK,SAAS,eAAe,IAAI,CAAC,CAC5D;EAKC;EACA;EACD,CAAC;CAEF,MAAM,8BAAc,IAAI,KAAK;CAE7B,MAAM,aAAkB,EACtB,SAAS,CACN,MAAM,0BAA0B;EAC/B;EACA;EACA;EACD,CAAC,EACF,iBAAiB,CAClB,EACF;CAED,IAAI;AACJ,YAAW,MAAM,eAAe,yBAC9B;EACE,KAAK;EACL,OAAO;EACP,UAAU;EACV,WAAW;EACX,cAAc;EACd,YAAY,oBAAoB,cAAc;EAC9C,cAAc;EACd,eAAe;EACf,UAAU,KAAK,SAAS,eAAe,QAAQ,SAAS;EACxD,OAAO,QAAQ,UAAU;EACzB;EACA,6BAA6B,CAAC,sCAAsC;EACpE,WAAW;GACT,SAAS;GACT,QAAQ;GACR,QAAQ;GACT;EACF,EACD,QACD,EAAE;AACD,MAAI,YAAY,SAAS,WAAW,QAClC,QAAO,EAAE,SAAS,OAAO;WAEzB,YAAY,SAAS,WAAW,eAChC,YAAY,SAAS,WAAW,KAEhC,KAAI,YAAY,SAAS,WAAW,MAAM;AACxC,eAAY,OAAO;AACnB,UAAO,KAAK,YAAY,MAAM,CAAC,SAAS,QAAQ;AAC9C,gBAAY,IAAI,KAAK,YAAY,MAAM,KAAK;KAC5C;QAEF,QAAO,KAAK,YAAY,MAAM,CAAC,SAAS,QAAQ;AAC9C,eAAY,IAAI,KAAK,YAAY,MAAM,KAAK;IAC5C;AAIN,MAAI,QAAQ,OAAO;AACjB,OAAI,CAAC,OACH,UAAS,MAAM,YAAY,QAAQ,EAAE,EAAE,QAAQ,WAAW;OAE1D,OAAM,OAAO,MAAM,EAAE,CAAC;AAGxB,SAAM,EAAE,SAAS,MAAM;SAClB;AACL,YAAS,MAAM,YAAY,QAAQ,EAAE,EAAE,QAAQ,WAAW;AAI1D,SAAM,EAAE,SAFQ,QAAQ,MAAM,uBAAuB,KAAK,GAEzC;;;AAIrB,OAAM,EAAE,SAAS,MAAM;;AAGzB,eAAsB,aACpB,SAC8B;CAE9B,MAAM,SAAS,MAAM,OAAO,iBAAiB,EAAE,MAAM,EAAE,MAAM,QAAQ,EAAE;CACvE,MAAM,YAAiC,EAAE;AACzC,MAAK,MAAM,OAAO,OAAO,KAAK,QAAQ,CACpC,KAAI,CAAE,OAAe,QAAQ,WAAW,KACtC,WAAU,OAAQ,QAAgB;AAItC,QAAO;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAgCT,SAAS,aAAa,SAKnB;CACD,MAAM,EAAE,kBAAkB,SAAS,OAAO;CAG1C,MAAM,cAAc,cAClB,KAAK,QAAQ,QAAQ,eAAe,QAAQ,YAAY,CACzD;AASD,QAAO,SAJO,CAAC,GAAG,QAAQ,QAAQ,KAAK,SAAS,GAAG,YAAY,GAAG,OAAO,CAAC,EAInD;EACrB,KAAK;EACL,UAAU;EACV,QAAQ,QAAQ;EACjB,CAAC;;AAGJ,SAAS,oBAAoB,EAC3B,aACA,WACA,SACA,kBAMC;AACD,KAAI,iBAAiB,GACnB,QAAO;CAGT,MAAM,uBAAO,IAAI,KAAK;AAEtB,QAAO,IAAI,IACT,MAAM,KAAK,YAAY,aAAa;EAClC,MAAM,eAAe,KAClB,SACC,SAAS,WAAW,YAAY,GAC5B,cACA,QAAQ,eACZ,SACD,CACA,QAAQ,UAAU,IAAI,CACtB,QAAQ,OAAO,IAAI;EAEtB,IAAI,aAAa,QAAQ,KAAK,SAC5B,cACA,KAAK,QAAQ,aAAa,CAC3B;EACD,IAAI,SAAS;AACb,SAAO,KAAK,IAAI,WAAW,EAAE;AAC3B,gBAAa,GAAG,aAAa,GAAG;AAChC,KAAE;;AAEJ,OAAK,IAAI,WAAW;AAEpB,SAAO,CAAC,YAAY,SAAS;GAC7B,CACH;;AAGH,IAAA,sBAAe,cAAc,yBAAyB"}
|