@analogjs/vitest-angular 3.0.0-alpha.2 → 3.0.0-alpha.20
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 +9 -2
- package/_virtual/_@oxc-project_runtime@0.122.0/helpers/decorate.js +9 -0
- package/package.json +9 -8
- package/setup-serializers.d.ts +1 -0
- package/setup-serializers.js +13 -0
- package/setup-serializers.js.map +1 -0
- package/setup-snapshots.d.ts +1 -26
- package/setup-snapshots.js +10 -103
- 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/snapshot-serializers/angular-fixture.d.ts +2 -0
- package/src/lib/snapshot-serializers/angular-fixture.js +68 -0
- package/src/lib/snapshot-serializers/angular-fixture.js.map +1 -0
- package/src/lib/snapshot-serializers/html-comment.d.ts +2 -0
- package/src/lib/snapshot-serializers/html-comment.js +11 -0
- package/src/lib/snapshot-serializers/html-comment.js.map +1 -0
- package/src/lib/snapshot-serializers/index.d.ts +3 -0
- package/src/lib/snapshot-serializers/no-ng-attributes.d.ts +4 -0
- package/src/lib/snapshot-serializers/no-ng-attributes.js +62 -0
- package/src/lib/snapshot-serializers/no-ng-attributes.js.map +1 -0
- package/src/lib/tools/collection.json +2 -2
- package/src/lib/tools/index.d.ts +1 -0
- package/src/lib/tools/index.js +3 -0
- package/src/lib/tools/package.json +1 -5
- package/src/lib/tools/{src/schematics → schematics}/setup/files/src/test-setup.ts.template +1 -0
- package/src/lib/tools/schematics/setup/index.d.ts +3 -0
- package/src/lib/tools/schematics/setup/index.js +55 -0
- package/src/lib/tools/schematics/setup/index.js.map +1 -0
- package/src/lib/tools/schematics/utils/angular.d.ts +3 -0
- package/src/lib/tools/schematics/utils/angular.js +21 -0
- package/src/lib/tools/schematics/utils/angular.js.map +1 -0
- package/src/lib/tools/schematics/utils/dependencies.d.ts +6 -0
- package/src/lib/tools/schematics/utils/dependencies.js +39 -0
- package/src/lib/tools/schematics/utils/dependencies.js.map +1 -0
- package/src/lib/tools/schematics/utils/index.d.ts +4 -0
- package/src/lib/tools/schematics/utils/index.js +4 -0
- package/src/lib/tools/schematics/utils/versions.d.ts +7 -0
- package/src/lib/tools/schematics/utils/versions.js +18 -0
- package/src/lib/tools/schematics/utils/versions.js.map +1 -0
- package/src/lib/tools/schematics/utils/workspace.d.ts +15 -0
- package/src/lib/tools/schematics/utils/workspace.js +21 -0
- package/src/lib/tools/schematics/utils/workspace.js.map +1 -0
- package/src/lib/tools/src/index.d.ts +1 -1
- package/src/lib/tools/src/schematics/setup/index.d.ts +2 -2
- package/src/lib/tools/src/schematics/utils/angular.d.ts +1 -1
- package/src/lib/tools/src/schematics/utils/dependencies.d.ts +2 -2
- package/src/lib/tools/src/schematics/utils/index.d.ts +4 -4
- package/src/lib/tools/src/schematics/utils/versions.d.ts +1 -1
- package/src/lib/tools/src/schematics/utils/workspace.d.ts +8 -8
- package/src/lib/tools/src/test-global-setup.d.ts +1 -0
- package/src/test-setup.d.ts +3 -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 +0 -6
- package/src/lib/tools/src/index.js.map +0 -1
- package/src/lib/tools/src/schematics/setup/index.js +0 -80
- package/src/lib/tools/src/schematics/setup/index.js.map +0 -1
- package/src/lib/tools/src/schematics/utils/angular.js +0 -27
- package/src/lib/tools/src/schematics/utils/angular.js.map +0 -1
- package/src/lib/tools/src/schematics/utils/dependencies.js +0 -49
- package/src/lib/tools/src/schematics/utils/dependencies.js.map +0 -1
- package/src/lib/tools/src/schematics/utils/index.js +0 -8
- package/src/lib/tools/src/schematics/utils/index.js.map +0 -1
- package/src/lib/tools/src/schematics/utils/versions.js +0 -13
- package/src/lib/tools/src/schematics/utils/versions.js.map +0 -1
- package/src/lib/tools/src/schematics/utils/workspace.js +0 -24
- package/src/lib/tools/src/schematics/utils/workspace.js.map +0 -1
- /package/src/lib/tools/{src/schematics → schematics}/jsonc-parser.d.ts +0 -0
- /package/src/lib/tools/{src/schematics → schematics}/semver.d.ts +0 -0
- /package/src/lib/tools/{src/schematics → schematics}/setup/files/vite.config.mts.template +0 -0
- /package/src/lib/tools/{src/schematics → schematics}/setup/schema.d.ts +0 -0
- /package/src/lib/tools/{src/schematics → schematics}/setup/schema.json +0 -0
|
@@ -1,61 +1,51 @@
|
|
|
1
|
-
import { createBuilder
|
|
1
|
+
import { createBuilder } from "@angular-devkit/architect";
|
|
2
|
+
//#region packages/vitest-angular/src/lib/builders/test/vitest.impl.ts
|
|
2
3
|
async function vitestBuilder(options, context) {
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
process.on('SIGINT', processExit);
|
|
40
|
-
process.on('SIGTERM', processExit);
|
|
41
|
-
process.on('exit', processExit);
|
|
42
|
-
}
|
|
43
|
-
// vitest sets the exitCode = 1 when code coverage isn't met
|
|
44
|
-
hasErrors = (process.exitCode && process.exitCode !== 0);
|
|
45
|
-
return {
|
|
46
|
-
success: !hasErrors,
|
|
47
|
-
};
|
|
4
|
+
process.env["TEST"] = "true";
|
|
5
|
+
process.env["VITEST"] = "true";
|
|
6
|
+
const { startVitest } = await Function("return import(\"vitest/node\")")();
|
|
7
|
+
const projectConfig = await context.getProjectMetadata(context.target);
|
|
8
|
+
const { coverageArgs, ...extraArgs } = await getExtraArgs(options);
|
|
9
|
+
const watch = options.watch === true;
|
|
10
|
+
const ui = options.ui === true;
|
|
11
|
+
const coverageEnabled = options.coverage === true;
|
|
12
|
+
const update = options.update === true;
|
|
13
|
+
const config = {
|
|
14
|
+
root: `${projectConfig["root"] || "."}`,
|
|
15
|
+
watch,
|
|
16
|
+
ui,
|
|
17
|
+
config: options.configFile,
|
|
18
|
+
coverage: {
|
|
19
|
+
enabled: coverageEnabled,
|
|
20
|
+
...coverageArgs
|
|
21
|
+
},
|
|
22
|
+
update,
|
|
23
|
+
...extraArgs
|
|
24
|
+
};
|
|
25
|
+
const viteOverrides = { test: { watch } };
|
|
26
|
+
const server = await startVitest("test", options.testFiles ?? [], config, viteOverrides);
|
|
27
|
+
let hasErrors = false;
|
|
28
|
+
const processExit = () => {
|
|
29
|
+
server?.exit();
|
|
30
|
+
if (hasErrors) process.exit(1);
|
|
31
|
+
else process.exit(0);
|
|
32
|
+
};
|
|
33
|
+
if (options.watch) {
|
|
34
|
+
process.once("SIGINT", processExit);
|
|
35
|
+
process.once("SIGTERM", processExit);
|
|
36
|
+
process.once("exit", processExit);
|
|
37
|
+
}
|
|
38
|
+
hasErrors = process.exitCode && process.exitCode !== 0;
|
|
39
|
+
return { success: !hasErrors };
|
|
48
40
|
}
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
if (!schema.default.properties[key]) {
|
|
55
|
-
extraArgs[key] = options[key];
|
|
56
|
-
}
|
|
57
|
-
}
|
|
58
|
-
return extraArgs;
|
|
41
|
+
async function getExtraArgs(options) {
|
|
42
|
+
const schema = await import("./schema.json", { with: { type: "json" } });
|
|
43
|
+
const extraArgs = {};
|
|
44
|
+
for (const key of Object.keys(options)) if (!schema.default.properties[key]) extraArgs[key] = options[key];
|
|
45
|
+
return extraArgs;
|
|
59
46
|
}
|
|
60
|
-
|
|
61
|
-
//#
|
|
47
|
+
var vitest_impl_default = createBuilder(vitestBuilder);
|
|
48
|
+
//#endregion
|
|
49
|
+
export { vitest_impl_default as default };
|
|
50
|
+
|
|
51
|
+
//# sourceMappingURL=vitest.impl.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"vitest.impl.js","names":[],"sources":["../../../../../src/lib/builders/test/vitest.impl.ts"],"sourcesContent":["import {\n BuilderContext,\n BuilderOutput,\n createBuilder,\n} from '@angular-devkit/architect';\n\nimport { VitestSchema } from './schema';\n\nasync function vitestBuilder(\n options: VitestSchema,\n context: BuilderContext,\n): Promise<BuilderOutput> {\n process.env['TEST'] = 'true';\n process.env['VITEST'] = 'true';\n\n const { startVitest } = await (Function(\n 'return import(\"vitest/node\")',\n )() as Promise<typeof import('vitest/node')>);\n\n const projectConfig = await context.getProjectMetadata(\n context.target as unknown as string,\n );\n const { coverageArgs, ...extraArgs } = await getExtraArgs(options);\n const watch = options.watch === true;\n const ui = options.ui === true;\n const coverageEnabled = options.coverage === true;\n const update = options.update === true;\n const config = {\n root: `${projectConfig['root'] || '.'}`,\n watch,\n ui,\n config: options.configFile,\n coverage: {\n enabled: coverageEnabled,\n ...coverageArgs,\n },\n update,\n ...extraArgs,\n };\n const viteOverrides: any = {\n test: { watch },\n };\n\n const server = await startVitest(\n 'test',\n options.testFiles ?? [],\n config,\n viteOverrides,\n );\n\n let hasErrors = false;\n\n const processExit = () => {\n server?.exit();\n if (hasErrors) {\n process.exit(1);\n } else {\n process.exit(0);\n }\n };\n\n // .once() prevents listener stacking across repeated Nx executor runs\n // that share the same host process (avoids MaxListenersExceededWarning).\n if (options.watch) {\n process.once('SIGINT', processExit);\n process.once('SIGTERM', processExit);\n process.once('exit', processExit);\n }\n\n // vitest sets the exitCode = 1 when code coverage isn't met\n hasErrors = (process.exitCode && process.exitCode !== 0) as boolean;\n\n return {\n success: !hasErrors,\n };\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\nexport default createBuilder(vitestBuilder) as any;\n"],"mappings":";;AAQA,eAAe,cACb,SACA,SACwB;AACxB,SAAQ,IAAI,UAAU;AACtB,SAAQ,IAAI,YAAY;CAExB,MAAM,EAAE,gBAAgB,MAAO,SAC7B,iCACD,EAAE;CAEH,MAAM,gBAAgB,MAAM,QAAQ,mBAClC,QAAQ,OACT;CACD,MAAM,EAAE,cAAc,GAAG,cAAc,MAAM,aAAa,QAAQ;CAClE,MAAM,QAAQ,QAAQ,UAAU;CAChC,MAAM,KAAK,QAAQ,OAAO;CAC1B,MAAM,kBAAkB,QAAQ,aAAa;CAC7C,MAAM,SAAS,QAAQ,WAAW;CAClC,MAAM,SAAS;EACb,MAAM,GAAG,cAAc,WAAW;EAClC;EACA;EACA,QAAQ,QAAQ;EAChB,UAAU;GACR,SAAS;GACT,GAAG;GACJ;EACD;EACA,GAAG;EACJ;CACD,MAAM,gBAAqB,EACzB,MAAM,EAAE,OAAO,EAChB;CAED,MAAM,SAAS,MAAM,YACnB,QACA,QAAQ,aAAa,EAAE,EACvB,QACA,cACD;CAED,IAAI,YAAY;CAEhB,MAAM,oBAAoB;AACxB,UAAQ,MAAM;AACd,MAAI,UACF,SAAQ,KAAK,EAAE;MAEf,SAAQ,KAAK,EAAE;;AAMnB,KAAI,QAAQ,OAAO;AACjB,UAAQ,KAAK,UAAU,YAAY;AACnC,UAAQ,KAAK,WAAW,YAAY;AACpC,UAAQ,KAAK,QAAQ,YAAY;;AAInC,aAAa,QAAQ,YAAY,QAAQ,aAAa;AAEtD,QAAO,EACL,SAAS,CAAC,WACX;;AAGH,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;;AAGT,IAAA,sBAAe,cAAc,cAAc"}
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
//#region packages/vitest-angular/src/lib/snapshot-serializers/angular-fixture.ts
|
|
2
|
+
/**
|
|
3
|
+
* Check if is an Angular fixture
|
|
4
|
+
*
|
|
5
|
+
* @param val Angular fixture
|
|
6
|
+
* @returns boolean who check if is an angular fixture
|
|
7
|
+
*/
|
|
8
|
+
function isAngularFixture(val) {
|
|
9
|
+
if (typeof val !== "object") return false;
|
|
10
|
+
if (val["componentRef"] || val["componentInstance"]) return true;
|
|
11
|
+
if (val["componentType"]) return true;
|
|
12
|
+
return JSON.stringify(Object.keys(val)) === JSON.stringify([
|
|
13
|
+
"componentRef",
|
|
14
|
+
"ngZone",
|
|
15
|
+
"effectRunner",
|
|
16
|
+
"_autoDetect",
|
|
17
|
+
"_isStable",
|
|
18
|
+
"_isDestroyed",
|
|
19
|
+
"_resolve",
|
|
20
|
+
"_promise",
|
|
21
|
+
"_onUnstableSubscription",
|
|
22
|
+
"_onStableSubscription",
|
|
23
|
+
"_onMicrotaskEmptySubscription",
|
|
24
|
+
"_onErrorSubscription",
|
|
25
|
+
"changeDetectorRef",
|
|
26
|
+
"elementRef",
|
|
27
|
+
"debugElement",
|
|
28
|
+
"componentInstance",
|
|
29
|
+
"nativeElement"
|
|
30
|
+
]) || JSON.stringify(Object.keys(val)) === JSON.stringify([
|
|
31
|
+
"location",
|
|
32
|
+
"_rootLView",
|
|
33
|
+
"_tNode",
|
|
34
|
+
"previousInputValues",
|
|
35
|
+
"instance",
|
|
36
|
+
"changeDetectorRef",
|
|
37
|
+
"hostView",
|
|
38
|
+
"componentType"
|
|
39
|
+
]);
|
|
40
|
+
}
|
|
41
|
+
/**
|
|
42
|
+
* Serialize Angular fixture for Vitest
|
|
43
|
+
*
|
|
44
|
+
* @param fixture Angular Fixture Component
|
|
45
|
+
* @returns HTML Child Node
|
|
46
|
+
*/
|
|
47
|
+
function fixtureVitestSerializer(fixture) {
|
|
48
|
+
const componentType = fixture && fixture.componentType ? fixture.componentType : fixture.componentRef.componentType;
|
|
49
|
+
let inputsData = "";
|
|
50
|
+
const selector = Reflect.getOwnPropertyDescriptor(componentType, "__annotations__")?.value[0]?.selector ?? componentType.ɵcmp?.selectors[0]?.[0];
|
|
51
|
+
if (componentType && componentType.propDecorators) inputsData = Object.entries(componentType.propDecorators).map(([key, value]) => `${key}="${value}"`).join("");
|
|
52
|
+
const divElement = fixture && fixture.nativeElement ? fixture.nativeElement : fixture.location.nativeElement;
|
|
53
|
+
return new DOMParser().parseFromString(`<${selector} ${inputsData}>${divElement.innerHTML}</${selector}>`, "text/html").body.childNodes[0];
|
|
54
|
+
}
|
|
55
|
+
function createAngularFixtureSnapshotSerializer() {
|
|
56
|
+
return {
|
|
57
|
+
serialize(val, config, indentation, depth, refs, printer) {
|
|
58
|
+
return printer(fixtureVitestSerializer(val), config, indentation, depth, refs);
|
|
59
|
+
},
|
|
60
|
+
test(val) {
|
|
61
|
+
return val && isAngularFixture(val);
|
|
62
|
+
}
|
|
63
|
+
};
|
|
64
|
+
}
|
|
65
|
+
//#endregion
|
|
66
|
+
export { createAngularFixtureSnapshotSerializer };
|
|
67
|
+
|
|
68
|
+
//# sourceMappingURL=angular-fixture.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"angular-fixture.js","names":[],"sources":["../../../../src/lib/snapshot-serializers/angular-fixture.ts"],"sourcesContent":["import type { ComponentFixture } from '@angular/core/testing';\nimport type { SnapshotSerializer } from 'vitest';\n\n/**\n * Check if is an Angular fixture\n *\n * @param val Angular fixture\n * @returns boolean who check if is an angular fixture\n */\nfunction isAngularFixture(val: any): boolean {\n if (typeof val !== 'object') {\n return false;\n }\n\n if (val['componentRef'] || val['componentInstance']) {\n return true;\n }\n\n if (val['componentType']) {\n return true;\n }\n\n // * Angular fixture keys in Fixture component Object\n const fixtureKeys = [\n 'componentRef',\n 'ngZone',\n 'effectRunner',\n '_autoDetect',\n '_isStable',\n '_isDestroyed',\n '_resolve',\n '_promise',\n '_onUnstableSubscription',\n '_onStableSubscription',\n '_onMicrotaskEmptySubscription',\n '_onErrorSubscription',\n 'changeDetectorRef',\n 'elementRef',\n 'debugElement',\n 'componentInstance',\n 'nativeElement',\n ];\n\n // * Angular fixture keys in Fixture componentRef Object\n const fixtureComponentRefKeys = [\n 'location',\n '_rootLView',\n '_tNode',\n 'previousInputValues',\n 'instance',\n 'changeDetectorRef',\n 'hostView',\n 'componentType',\n ];\n\n return (\n JSON.stringify(Object.keys(val)) === JSON.stringify(fixtureKeys) ||\n JSON.stringify(Object.keys(val)) === JSON.stringify(fixtureComponentRefKeys)\n );\n}\n\n/**\n * Serialize Angular fixture for Vitest\n *\n * @param fixture Angular Fixture Component\n * @returns HTML Child Node\n */\nfunction fixtureVitestSerializer(fixture: any) {\n // * Get Component meta data\n const componentType = (\n fixture && fixture.componentType\n ? fixture.componentType\n : fixture.componentRef.componentType\n ) as any;\n\n let inputsData = '';\n\n const selector =\n Reflect.getOwnPropertyDescriptor(componentType, '__annotations__')?.value[0]\n ?.selector ?? componentType.ɵcmp?.selectors[0]?.[0];\n\n if (componentType && componentType.propDecorators) {\n inputsData = Object.entries(componentType.propDecorators)\n .map(([key, value]) => `${key}=\"${value}\"`)\n .join('');\n }\n\n // * Get DOM Elements\n const divElement =\n fixture && fixture.nativeElement\n ? fixture.nativeElement\n : fixture.location.nativeElement;\n\n // * Convert string data to HTML data\n const doc = new DOMParser().parseFromString(\n `<${selector} ${inputsData}>${divElement.innerHTML}</${selector}>`,\n 'text/html',\n );\n\n return doc.body.childNodes[0];\n}\n\nexport function createAngularFixtureSnapshotSerializer(): SnapshotSerializer {\n return {\n serialize(val, config, indentation, depth, refs, printer) {\n return printer(\n fixtureVitestSerializer(val),\n config,\n indentation,\n depth,\n refs,\n );\n },\n test(val) {\n return val && isAngularFixture(val);\n },\n };\n}\n"],"mappings":";;;;;;;AASA,SAAS,iBAAiB,KAAmB;AAC3C,KAAI,OAAO,QAAQ,SACjB,QAAO;AAGT,KAAI,IAAI,mBAAmB,IAAI,qBAC7B,QAAO;AAGT,KAAI,IAAI,iBACN,QAAO;AAoCT,QACE,KAAK,UAAU,OAAO,KAAK,IAAI,CAAC,KAAK,KAAK,UAjCxB;EAClB;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACD,CAeiE,IAChE,KAAK,UAAU,OAAO,KAAK,IAAI,CAAC,KAAK,KAAK,UAbZ;EAC9B;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACD,CAI6E;;;;;;;;AAUhF,SAAS,wBAAwB,SAAc;CAE7C,MAAM,gBACJ,WAAW,QAAQ,gBACf,QAAQ,gBACR,QAAQ,aAAa;CAG3B,IAAI,aAAa;CAEjB,MAAM,WACJ,QAAQ,yBAAyB,eAAe,kBAAkB,EAAE,MAAM,IACtE,YAAY,cAAc,MAAM,UAAU,KAAK;AAErD,KAAI,iBAAiB,cAAc,eACjC,cAAa,OAAO,QAAQ,cAAc,eAAe,CACtD,KAAK,CAAC,KAAK,WAAW,GAAG,IAAI,IAAI,MAAM,GAAG,CAC1C,KAAK,GAAG;CAIb,MAAM,aACJ,WAAW,QAAQ,gBACf,QAAQ,gBACR,QAAQ,SAAS;AAQvB,QALY,IAAI,WAAW,CAAC,gBAC1B,IAAI,SAAS,GAAG,WAAW,GAAG,WAAW,UAAU,IAAI,SAAS,IAChE,YACD,CAEU,KAAK,WAAW;;AAG7B,SAAgB,yCAA6D;AAC3E,QAAO;EACL,UAAU,KAAK,QAAQ,aAAa,OAAO,MAAM,SAAS;AACxD,UAAO,QACL,wBAAwB,IAAI,EAC5B,QACA,aACA,OACA,KACD;;EAEH,KAAK,KAAK;AACR,UAAO,OAAO,iBAAiB,IAAI;;EAEtC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
//#region packages/vitest-angular/src/lib/snapshot-serializers/html-comment.ts
|
|
2
|
+
function createHtmlCommentSnapshotSerializer() {
|
|
3
|
+
return {
|
|
4
|
+
serialize: () => "",
|
|
5
|
+
test: (val) => typeof Comment !== "undefined" && val instanceof Comment
|
|
6
|
+
};
|
|
7
|
+
}
|
|
8
|
+
//#endregion
|
|
9
|
+
export { createHtmlCommentSnapshotSerializer };
|
|
10
|
+
|
|
11
|
+
//# sourceMappingURL=html-comment.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"html-comment.js","names":[],"sources":["../../../../src/lib/snapshot-serializers/html-comment.ts"],"sourcesContent":["import { type SnapshotSerializer } from 'vitest';\n\nexport function createHtmlCommentSnapshotSerializer(): SnapshotSerializer {\n return {\n serialize: () => '',\n test: (val: any): boolean =>\n typeof Comment !== 'undefined' && val instanceof Comment,\n };\n}\n"],"mappings":";AAEA,SAAgB,sCAA0D;AACxE,QAAO;EACL,iBAAiB;EACjB,OAAO,QACL,OAAO,YAAY,eAAe,eAAe;EACpD"}
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
//#region packages/vitest-angular/src/lib/snapshot-serializers/no-ng-attributes.ts
|
|
2
|
+
var CLEANED_ELEMENT_MARKER = "__analogSnapshotCleaned__";
|
|
3
|
+
var attributesToRemovePatterns = [
|
|
4
|
+
"ng-reflect",
|
|
5
|
+
"_nghost",
|
|
6
|
+
"_ngcontent",
|
|
7
|
+
"ng-version"
|
|
8
|
+
];
|
|
9
|
+
var attributesToClean = {
|
|
10
|
+
class: [/^(?:mat|cdk|ng).*-\w*\d+-\d+$/, /^ng-star-inserted$/],
|
|
11
|
+
id: [/^(?:mat|cdk|ng).*-\d+$/],
|
|
12
|
+
for: [/^(?:mat|cdk|ng).*-\d+$/],
|
|
13
|
+
"aria-owns": [/^(?:mat|cdk|ng).*-\d+$/],
|
|
14
|
+
"aria-labelledby": [/^(?:mat|cdk|ng).*-\d+$/],
|
|
15
|
+
"aria-controls": [/^(?:mat|cdk|ng).*-\d+$/]
|
|
16
|
+
};
|
|
17
|
+
var hasAttributesToRemove = (attribute) => attributesToRemovePatterns.some((removePattern) => attribute.name.startsWith(removePattern));
|
|
18
|
+
var hasAttributesToClean = (attribute) => Object.prototype.hasOwnProperty.call(attributesToClean, attribute.name);
|
|
19
|
+
var attributeNeedsCleaning = (attribute) => hasAttributesToClean(attribute) && attribute.value.split(" ").some((attrValue) => attributesToClean[attribute.name].some((attributeCleanRegex) => attributeCleanRegex.test(attrValue)));
|
|
20
|
+
var shouldSerializeElement = (node) => {
|
|
21
|
+
if (node.parentElement?.tagName === "BODY" && node.hasAttribute("id")) return true;
|
|
22
|
+
return Array.from(node.attributes).some((attribute) => hasAttributesToRemove(attribute) || attributeNeedsCleaning(attribute));
|
|
23
|
+
};
|
|
24
|
+
function cleanAngularElementAttributes(node) {
|
|
25
|
+
const nodeCopy = node.cloneNode(true);
|
|
26
|
+
Object.defineProperty(nodeCopy, CLEANED_ELEMENT_MARKER, {
|
|
27
|
+
configurable: true,
|
|
28
|
+
value: true
|
|
29
|
+
});
|
|
30
|
+
if (node.parentElement?.tagName === "BODY") nodeCopy.removeAttribute("id");
|
|
31
|
+
Array.from(nodeCopy.attributes).forEach((attribute) => {
|
|
32
|
+
if (hasAttributesToRemove(attribute)) {
|
|
33
|
+
nodeCopy.removeAttribute(attribute.name);
|
|
34
|
+
return;
|
|
35
|
+
}
|
|
36
|
+
if (hasAttributesToClean(attribute)) {
|
|
37
|
+
const cleanedValue = attribute.value.split(" ").filter((attrValue) => !attributesToClean[attribute.name].some((attributeCleanRegex) => attributeCleanRegex.test(attrValue))).join(" ");
|
|
38
|
+
if (cleanedValue === "") {
|
|
39
|
+
nodeCopy.removeAttribute(attribute.name);
|
|
40
|
+
return;
|
|
41
|
+
}
|
|
42
|
+
nodeCopy.setAttribute(attribute.name, cleanedValue);
|
|
43
|
+
}
|
|
44
|
+
});
|
|
45
|
+
return nodeCopy;
|
|
46
|
+
}
|
|
47
|
+
function createNoNgAttributesSnapshotSerializer() {
|
|
48
|
+
return {
|
|
49
|
+
serialize(val, config, indentation, depth, refs, printer) {
|
|
50
|
+
const cleanedNode = cleanAngularElementAttributes(val);
|
|
51
|
+
if (shouldSerializeElement(cleanedNode)) throw new Error(`NoNgAttributes serializer did not stabilize for <${cleanedNode.tagName.toLowerCase()}>`);
|
|
52
|
+
return printer(cleanedNode, config, indentation, depth, refs);
|
|
53
|
+
},
|
|
54
|
+
test(val) {
|
|
55
|
+
return typeof Element !== "undefined" && val instanceof Element && !val[CLEANED_ELEMENT_MARKER] && shouldSerializeElement(val);
|
|
56
|
+
}
|
|
57
|
+
};
|
|
58
|
+
}
|
|
59
|
+
//#endregion
|
|
60
|
+
export { createNoNgAttributesSnapshotSerializer };
|
|
61
|
+
|
|
62
|
+
//# sourceMappingURL=no-ng-attributes.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"no-ng-attributes.js","names":[],"sources":["../../../../src/lib/snapshot-serializers/no-ng-attributes.ts"],"sourcesContent":["import { type SnapshotSerializer } from 'vitest';\n\nconst CLEANED_ELEMENT_MARKER = '__analogSnapshotCleaned__';\n\nexport const attributesToRemovePatterns = [\n 'ng-reflect',\n '_nghost',\n '_ngcontent',\n 'ng-version',\n];\n\nexport const attributesToClean: Record<string, RegExp[]> = {\n class: [/^(?:mat|cdk|ng).*-\\w*\\d+-\\d+$/, /^ng-star-inserted$/],\n id: [/^(?:mat|cdk|ng).*-\\d+$/],\n for: [/^(?:mat|cdk|ng).*-\\d+$/],\n 'aria-owns': [/^(?:mat|cdk|ng).*-\\d+$/],\n 'aria-labelledby': [/^(?:mat|cdk|ng).*-\\d+$/],\n 'aria-controls': [/^(?:mat|cdk|ng).*-\\d+$/],\n};\n\nconst hasAttributesToRemove = (attribute: Attr): boolean =>\n attributesToRemovePatterns.some((removePattern) =>\n attribute.name.startsWith(removePattern),\n );\n\nconst hasAttributesToClean = (attribute: Attr): boolean =>\n Object.prototype.hasOwnProperty.call(attributesToClean, attribute.name);\n\nconst attributeNeedsCleaning = (attribute: Attr): boolean =>\n hasAttributesToClean(attribute) &&\n attribute.value\n .split(' ')\n .some((attrValue) =>\n attributesToClean[attribute.name].some((attributeCleanRegex) =>\n attributeCleanRegex.test(attrValue),\n ),\n );\n\nconst shouldSerializeElement = (node: Element): boolean => {\n if (node.parentElement?.tagName === 'BODY' && node.hasAttribute('id')) {\n return true;\n }\n\n return Array.from(node.attributes).some(\n (attribute) =>\n hasAttributesToRemove(attribute) || attributeNeedsCleaning(attribute),\n );\n};\n\nfunction cleanAngularElementAttributes(node: Element): Element {\n const nodeCopy = node.cloneNode(true) as Element;\n\n Object.defineProperty(nodeCopy, CLEANED_ELEMENT_MARKER, {\n configurable: true,\n value: true,\n });\n\n if (node.parentElement?.tagName === 'BODY') {\n nodeCopy.removeAttribute('id');\n }\n\n Array.from(nodeCopy.attributes).forEach((attribute) => {\n if (hasAttributesToRemove(attribute)) {\n nodeCopy.removeAttribute(attribute.name);\n return;\n }\n\n if (hasAttributesToClean(attribute)) {\n const cleanedValue = attribute.value\n .split(' ')\n .filter(\n (attrValue) =>\n !attributesToClean[attribute.name].some((attributeCleanRegex) =>\n attributeCleanRegex.test(attrValue),\n ),\n )\n .join(' ');\n\n if (cleanedValue === '') {\n nodeCopy.removeAttribute(attribute.name);\n return;\n }\n\n nodeCopy.setAttribute(attribute.name, cleanedValue);\n }\n });\n\n return nodeCopy;\n}\n\nexport function createNoNgAttributesSnapshotSerializer(): SnapshotSerializer {\n return {\n serialize(val, config, indentation, depth, refs, printer): string {\n const cleanedNode = cleanAngularElementAttributes(val);\n\n if (shouldSerializeElement(cleanedNode)) {\n throw new Error(\n `NoNgAttributes serializer did not stabilize for <${cleanedNode.tagName.toLowerCase()}>`,\n );\n }\n\n return printer(cleanedNode, config, indentation, depth, refs);\n },\n test(val): boolean {\n const matches =\n typeof Element !== 'undefined' &&\n val instanceof Element &&\n !(val as Element & Record<string, unknown>)[CLEANED_ELEMENT_MARKER] &&\n shouldSerializeElement(val);\n\n return matches;\n },\n };\n}\n"],"mappings":";AAEA,IAAM,yBAAyB;AAE/B,IAAa,6BAA6B;CACxC;CACA;CACA;CACA;CACD;AAED,IAAa,oBAA8C;CACzD,OAAO,CAAC,iCAAiC,qBAAqB;CAC9D,IAAI,CAAC,yBAAyB;CAC9B,KAAK,CAAC,yBAAyB;CAC/B,aAAa,CAAC,yBAAyB;CACvC,mBAAmB,CAAC,yBAAyB;CAC7C,iBAAiB,CAAC,yBAAyB;CAC5C;AAED,IAAM,yBAAyB,cAC7B,2BAA2B,MAAM,kBAC/B,UAAU,KAAK,WAAW,cAAc,CACzC;AAEH,IAAM,wBAAwB,cAC5B,OAAO,UAAU,eAAe,KAAK,mBAAmB,UAAU,KAAK;AAEzE,IAAM,0BAA0B,cAC9B,qBAAqB,UAAU,IAC/B,UAAU,MACP,MAAM,IAAI,CACV,MAAM,cACL,kBAAkB,UAAU,MAAM,MAAM,wBACtC,oBAAoB,KAAK,UAAU,CACpC,CACF;AAEL,IAAM,0BAA0B,SAA2B;AACzD,KAAI,KAAK,eAAe,YAAY,UAAU,KAAK,aAAa,KAAK,CACnE,QAAO;AAGT,QAAO,MAAM,KAAK,KAAK,WAAW,CAAC,MAChC,cACC,sBAAsB,UAAU,IAAI,uBAAuB,UAAU,CACxE;;AAGH,SAAS,8BAA8B,MAAwB;CAC7D,MAAM,WAAW,KAAK,UAAU,KAAK;AAErC,QAAO,eAAe,UAAU,wBAAwB;EACtD,cAAc;EACd,OAAO;EACR,CAAC;AAEF,KAAI,KAAK,eAAe,YAAY,OAClC,UAAS,gBAAgB,KAAK;AAGhC,OAAM,KAAK,SAAS,WAAW,CAAC,SAAS,cAAc;AACrD,MAAI,sBAAsB,UAAU,EAAE;AACpC,YAAS,gBAAgB,UAAU,KAAK;AACxC;;AAGF,MAAI,qBAAqB,UAAU,EAAE;GACnC,MAAM,eAAe,UAAU,MAC5B,MAAM,IAAI,CACV,QACE,cACC,CAAC,kBAAkB,UAAU,MAAM,MAAM,wBACvC,oBAAoB,KAAK,UAAU,CACpC,CACJ,CACA,KAAK,IAAI;AAEZ,OAAI,iBAAiB,IAAI;AACvB,aAAS,gBAAgB,UAAU,KAAK;AACxC;;AAGF,YAAS,aAAa,UAAU,MAAM,aAAa;;GAErD;AAEF,QAAO;;AAGT,SAAgB,yCAA6D;AAC3E,QAAO;EACL,UAAU,KAAK,QAAQ,aAAa,OAAO,MAAM,SAAiB;GAChE,MAAM,cAAc,8BAA8B,IAAI;AAEtD,OAAI,uBAAuB,YAAY,CACrC,OAAM,IAAI,MACR,oDAAoD,YAAY,QAAQ,aAAa,CAAC,GACvF;AAGH,UAAO,QAAQ,aAAa,QAAQ,aAAa,OAAO,KAAK;;EAE/D,KAAK,KAAc;AAOjB,UALE,OAAO,YAAY,eACnB,eAAe,WACf,CAAE,IAA0C,2BAC5C,uBAAuB,IAAI;;EAIhC"}
|
|
@@ -3,8 +3,8 @@
|
|
|
3
3
|
"schematics": {
|
|
4
4
|
"setup": {
|
|
5
5
|
"description": "Configure Vitest for an Angular project",
|
|
6
|
-
"factory": "./
|
|
7
|
-
"schema": "./
|
|
6
|
+
"factory": "./schematics/setup/index#setupSchematic",
|
|
7
|
+
"schema": "./schematics/setup/schema.json"
|
|
8
8
|
}
|
|
9
9
|
}
|
|
10
10
|
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { setupSchematic } from "./schematics/setup/index";
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
<% if (majorAngularVersion > 20) { %>
|
|
2
2
|
import '@angular/compiler';
|
|
3
3
|
import '@analogjs/vitest-angular/setup-snapshots';
|
|
4
|
+
import '@analogjs/vitest-angular/setup-serializers';
|
|
4
5
|
import { setupTestBed } from '@analogjs/vitest-angular/setup-testbed';
|
|
5
6
|
|
|
6
7
|
<% if (browserMode) { %>
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
const require_angular = require("../utils/angular.js");
|
|
2
|
+
const require_workspace = require("../utils/workspace.js");
|
|
3
|
+
const require_dependencies = require("../utils/dependencies.js");
|
|
4
|
+
require("../utils/index.js");
|
|
5
|
+
let _angular_devkit_schematics = require("@angular-devkit/schematics");
|
|
6
|
+
let _angular_devkit_schematics_tasks = require("@angular-devkit/schematics/tasks");
|
|
7
|
+
let jsonc_parser = require("jsonc-parser");
|
|
8
|
+
//#region packages/vitest-angular-tools/src/schematics/setup/index.ts
|
|
9
|
+
function updateTsConfigSpec(tree, projectRoot) {
|
|
10
|
+
const tsConfigPath = projectRoot ? `${projectRoot}/tsconfig.spec.json` : "tsconfig.spec.json";
|
|
11
|
+
if (!tree.exists(tsConfigPath)) return;
|
|
12
|
+
const tsConfigContent = tree.read(tsConfigPath);
|
|
13
|
+
if (!tsConfigContent) return;
|
|
14
|
+
const tsConfig = (0, jsonc_parser.parse)(tsConfigContent.toString("utf-8"));
|
|
15
|
+
tsConfig.compilerOptions = tsConfig.compilerOptions || {};
|
|
16
|
+
delete tsConfig.compilerOptions.module;
|
|
17
|
+
tsConfig.compilerOptions.target = "es2022";
|
|
18
|
+
const filteredTypes = (tsConfig.compilerOptions.types || ["node"]).filter((t) => t !== "jest" && t !== "jasmine");
|
|
19
|
+
if (!filteredTypes.includes("vitest/globals")) filteredTypes.push("vitest/globals");
|
|
20
|
+
tsConfig.compilerOptions.types = filteredTypes;
|
|
21
|
+
tsConfig.files = ["src/test-setup.ts"];
|
|
22
|
+
tree.overwrite(tsConfigPath, JSON.stringify(tsConfig, null, 2) + "\n");
|
|
23
|
+
}
|
|
24
|
+
function updateAngularJson(tree, projectName) {
|
|
25
|
+
const workspace = require_workspace.getWorkspace(tree);
|
|
26
|
+
const project = workspace.projects[projectName];
|
|
27
|
+
if (!project.architect) project.architect = {};
|
|
28
|
+
project.architect["test"] = { builder: "@analogjs/vitest-angular:test" };
|
|
29
|
+
tree.overwrite("angular.json", JSON.stringify(workspace, null, 2) + "\n");
|
|
30
|
+
}
|
|
31
|
+
function generateFiles(projectRoot, majorAngularVersion, isNx, browserMode) {
|
|
32
|
+
return (0, _angular_devkit_schematics.mergeWith)((0, _angular_devkit_schematics.apply)((0, _angular_devkit_schematics.url)("./files"), [(0, _angular_devkit_schematics.applyTemplates)({
|
|
33
|
+
majorAngularVersion,
|
|
34
|
+
isNx,
|
|
35
|
+
browserMode
|
|
36
|
+
}), (0, _angular_devkit_schematics.move)(projectRoot)]));
|
|
37
|
+
}
|
|
38
|
+
function setupSchematic(options) {
|
|
39
|
+
return (tree, context) => {
|
|
40
|
+
const angularVersion = require_angular.getAngularVersion(tree);
|
|
41
|
+
const majorAngularVersion = require_angular.getMajorAngularVersion(angularVersion);
|
|
42
|
+
const projectRoot = require_workspace.getProject(require_workspace.getWorkspace(tree), options.project).root || "";
|
|
43
|
+
const isNx = require_workspace.isNxWorkspace(tree);
|
|
44
|
+
const browserMode = options.browserMode ?? false;
|
|
45
|
+
require_dependencies.addDevDependencies(tree, angularVersion, { browserMode });
|
|
46
|
+
updateTsConfigSpec(tree, projectRoot);
|
|
47
|
+
updateAngularJson(tree, options.project);
|
|
48
|
+
context.addTask(new _angular_devkit_schematics_tasks.NodePackageInstallTask());
|
|
49
|
+
return (0, _angular_devkit_schematics.chain)([generateFiles(projectRoot, majorAngularVersion, isNx, browserMode)]);
|
|
50
|
+
};
|
|
51
|
+
}
|
|
52
|
+
//#endregion
|
|
53
|
+
exports.setupSchematic = setupSchematic;
|
|
54
|
+
|
|
55
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","names":[],"sources":["../../../../../../../vitest-angular-tools/src/schematics/setup/index.ts"],"sourcesContent":["import {\n Rule,\n Tree,\n apply,\n url,\n applyTemplates,\n move,\n chain,\n mergeWith,\n SchematicContext,\n} from '@angular-devkit/schematics';\nimport { NodePackageInstallTask } from '@angular-devkit/schematics/tasks';\nimport { parse } from 'jsonc-parser';\nimport {\n getAngularVersion,\n getMajorAngularVersion,\n getWorkspace,\n getProject,\n addDevDependencies,\n isNxWorkspace,\n} from '../utils';\nimport { Schema } from './schema';\n\nfunction updateTsConfigSpec(tree: Tree, projectRoot: string): void {\n const tsConfigPath = projectRoot\n ? `${projectRoot}/tsconfig.spec.json`\n : 'tsconfig.spec.json';\n\n if (!tree.exists(tsConfigPath)) {\n return;\n }\n\n const tsConfigContent = tree.read(tsConfigPath);\n if (!tsConfigContent) {\n return;\n }\n\n const tsConfig = parse(tsConfigContent.toString('utf-8')) as Record<\n string,\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n any\n >;\n\n tsConfig.compilerOptions = tsConfig.compilerOptions || {};\n\n // Remove module (let Vite handle it)\n delete tsConfig.compilerOptions.module;\n\n // Set target to es2022\n tsConfig.compilerOptions.target = 'es2022';\n\n // Update types: remove jest, add vitest/globals\n const types: string[] = tsConfig.compilerOptions.types || ['node'];\n const filteredTypes = types.filter(\n (t: string) => t !== 'jest' && t !== 'jasmine',\n );\n if (!filteredTypes.includes('vitest/globals')) {\n filteredTypes.push('vitest/globals');\n }\n tsConfig.compilerOptions.types = filteredTypes;\n\n // Set files to include test-setup.ts\n tsConfig.files = ['src/test-setup.ts'];\n\n tree.overwrite(tsConfigPath, JSON.stringify(tsConfig, null, 2) + '\\n');\n}\n\nfunction updateAngularJson(tree: Tree, projectName: string): void {\n const workspace = getWorkspace(tree);\n const project = workspace.projects[projectName];\n\n if (!project.architect) {\n project.architect = {};\n }\n\n project.architect['test'] = {\n builder: '@analogjs/vitest-angular:test',\n };\n\n tree.overwrite('angular.json', JSON.stringify(workspace, null, 2) + '\\n');\n}\n\nfunction generateFiles(\n projectRoot: string,\n majorAngularVersion: number,\n isNx: boolean,\n browserMode: boolean,\n): Rule {\n return mergeWith(\n apply(url('./files'), [\n applyTemplates({\n majorAngularVersion,\n isNx,\n browserMode,\n }),\n move(projectRoot),\n ]),\n );\n}\n\nexport function setupSchematic(options: Schema): Rule {\n return (tree: Tree, context: SchematicContext) => {\n const angularVersion = getAngularVersion(tree);\n const majorAngularVersion = getMajorAngularVersion(angularVersion);\n\n const workspace = getWorkspace(tree);\n const project = getProject(workspace, options.project);\n const projectRoot = project.root || '';\n const isNx = isNxWorkspace(tree);\n\n const browserMode = options.browserMode ?? false;\n\n // Add devDependencies\n addDevDependencies(tree, angularVersion, { browserMode });\n\n // Update tsconfig.spec.json (if exists)\n updateTsConfigSpec(tree, projectRoot);\n\n // Update angular.json test target\n updateAngularJson(tree, options.project);\n\n // Schedule package install\n context.addTask(new NodePackageInstallTask());\n\n // Generate files\n return chain([\n generateFiles(projectRoot, majorAngularVersion, isNx, browserMode),\n ]);\n };\n}\n"],"mappings":";;;;;;;;AAuBA,SAAS,mBAAmB,MAAY,aAA2B;CACjE,MAAM,eAAe,cACjB,GAAG,YAAY,uBACf;AAEJ,KAAI,CAAC,KAAK,OAAO,aAAa,CAC5B;CAGF,MAAM,kBAAkB,KAAK,KAAK,aAAa;AAC/C,KAAI,CAAC,gBACH;CAGF,MAAM,YAAA,GAAA,aAAA,OAAiB,gBAAgB,SAAS,QAAQ,CAAC;AAMzD,UAAS,kBAAkB,SAAS,mBAAmB,EAAE;AAGzD,QAAO,SAAS,gBAAgB;AAGhC,UAAS,gBAAgB,SAAS;CAIlC,MAAM,iBADkB,SAAS,gBAAgB,SAAS,CAAC,OAAO,EACtC,QACzB,MAAc,MAAM,UAAU,MAAM,UACtC;AACD,KAAI,CAAC,cAAc,SAAS,iBAAiB,CAC3C,eAAc,KAAK,iBAAiB;AAEtC,UAAS,gBAAgB,QAAQ;AAGjC,UAAS,QAAQ,CAAC,oBAAoB;AAEtC,MAAK,UAAU,cAAc,KAAK,UAAU,UAAU,MAAM,EAAE,GAAG,KAAK;;AAGxE,SAAS,kBAAkB,MAAY,aAA2B;CAChE,MAAM,YAAY,kBAAA,aAAa,KAAK;CACpC,MAAM,UAAU,UAAU,SAAS;AAEnC,KAAI,CAAC,QAAQ,UACX,SAAQ,YAAY,EAAE;AAGxB,SAAQ,UAAU,UAAU,EAC1B,SAAS,iCACV;AAED,MAAK,UAAU,gBAAgB,KAAK,UAAU,WAAW,MAAM,EAAE,GAAG,KAAK;;AAG3E,SAAS,cACP,aACA,qBACA,MACA,aACM;AACN,SAAA,GAAA,2BAAA,YAAA,GAAA,2BAAA,QAAA,GAAA,2BAAA,KACY,UAAU,EAAE,EAAA,GAAA,2BAAA,gBACL;EACb;EACA;EACA;EACD,CAAC,GAAA,GAAA,2BAAA,MACG,YAAY,CAClB,CAAC,CACH;;AAGH,SAAgB,eAAe,SAAuB;AACpD,SAAQ,MAAY,YAA8B;EAChD,MAAM,iBAAiB,gBAAA,kBAAkB,KAAK;EAC9C,MAAM,sBAAsB,gBAAA,uBAAuB,eAAe;EAIlE,MAAM,cADU,kBAAA,WADE,kBAAA,aAAa,KAAK,EACE,QAAQ,QAAQ,CAC1B,QAAQ;EACpC,MAAM,OAAO,kBAAA,cAAc,KAAK;EAEhC,MAAM,cAAc,QAAQ,eAAe;AAG3C,uBAAA,mBAAmB,MAAM,gBAAgB,EAAE,aAAa,CAAC;AAGzD,qBAAmB,MAAM,YAAY;AAGrC,oBAAkB,MAAM,QAAQ,QAAQ;AAGxC,UAAQ,QAAQ,IAAI,iCAAA,wBAAwB,CAAC;AAG7C,UAAA,GAAA,2BAAA,OAAa,CACX,cAAc,aAAa,qBAAqB,MAAM,YAAY,CACnE,CAAC"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
let _angular_devkit_schematics = require("@angular-devkit/schematics");
|
|
2
|
+
let semver = require("semver");
|
|
3
|
+
//#region packages/vitest-angular-tools/src/schematics/utils/angular.ts
|
|
4
|
+
function getAngularVersion(tree) {
|
|
5
|
+
const packageJson = tree.read("package.json");
|
|
6
|
+
if (!packageJson) throw new _angular_devkit_schematics.SchematicsException("Could not find package.json");
|
|
7
|
+
const pkg = JSON.parse(packageJson.toString("utf-8"));
|
|
8
|
+
const angularVersion = pkg.dependencies?.["@angular/core"] || pkg.devDependencies?.["@angular/core"];
|
|
9
|
+
if (!angularVersion) throw new _angular_devkit_schematics.SchematicsException("Could not find @angular/core in package.json");
|
|
10
|
+
return angularVersion;
|
|
11
|
+
}
|
|
12
|
+
function getMajorAngularVersion(angularVersion) {
|
|
13
|
+
const coerced = (0, semver.coerce)(angularVersion);
|
|
14
|
+
if (!coerced) throw new _angular_devkit_schematics.SchematicsException(`Could not parse Angular version: ${angularVersion}`);
|
|
15
|
+
return (0, semver.major)(coerced);
|
|
16
|
+
}
|
|
17
|
+
//#endregion
|
|
18
|
+
exports.getAngularVersion = getAngularVersion;
|
|
19
|
+
exports.getMajorAngularVersion = getMajorAngularVersion;
|
|
20
|
+
|
|
21
|
+
//# sourceMappingURL=angular.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"angular.js","names":[],"sources":["../../../../../../../vitest-angular-tools/src/schematics/utils/angular.ts"],"sourcesContent":["import { Tree, SchematicsException } from '@angular-devkit/schematics';\nimport { coerce, major } from 'semver';\n\nexport function getAngularVersion(tree: Tree): string {\n const packageJson = tree.read('package.json');\n if (!packageJson) {\n throw new SchematicsException('Could not find package.json');\n }\n\n const pkg = JSON.parse(packageJson.toString('utf-8'));\n const angularVersion =\n pkg.dependencies?.['@angular/core'] ||\n pkg.devDependencies?.['@angular/core'];\n\n if (!angularVersion) {\n throw new SchematicsException(\n 'Could not find @angular/core in package.json',\n );\n }\n\n return angularVersion;\n}\n\nexport function getMajorAngularVersion(angularVersion: string): number {\n const coerced = coerce(angularVersion);\n if (!coerced) {\n throw new SchematicsException(\n `Could not parse Angular version: ${angularVersion}`,\n );\n }\n return major(coerced);\n}\n"],"mappings":";;;AAGA,SAAgB,kBAAkB,MAAoB;CACpD,MAAM,cAAc,KAAK,KAAK,eAAe;AAC7C,KAAI,CAAC,YACH,OAAM,IAAI,2BAAA,oBAAoB,8BAA8B;CAG9D,MAAM,MAAM,KAAK,MAAM,YAAY,SAAS,QAAQ,CAAC;CACrD,MAAM,iBACJ,IAAI,eAAe,oBACnB,IAAI,kBAAkB;AAExB,KAAI,CAAC,eACH,OAAM,IAAI,2BAAA,oBACR,+CACD;AAGH,QAAO;;AAGT,SAAgB,uBAAuB,gBAAgC;CACrE,MAAM,WAAA,GAAA,OAAA,QAAiB,eAAe;AACtC,KAAI,CAAC,QACH,OAAM,IAAI,2BAAA,oBACR,oCAAoC,iBACrC;AAEH,SAAA,GAAA,OAAA,OAAa,QAAQ"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { Tree } from "@angular-devkit/schematics";
|
|
2
|
+
export interface DependencyOptions {
|
|
3
|
+
browserMode?: boolean;
|
|
4
|
+
}
|
|
5
|
+
export declare function getDevDependencies(angularVersion: string, options?: DependencyOptions): Record<string, string>;
|
|
6
|
+
export declare function addDevDependencies(tree: Tree, angularVersion: string, options?: DependencyOptions): void;
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
const require_versions = require("./versions.js");
|
|
2
|
+
let _angular_devkit_schematics = require("@angular-devkit/schematics");
|
|
3
|
+
let semver = require("semver");
|
|
4
|
+
//#region packages/vitest-angular-tools/src/schematics/utils/dependencies.ts
|
|
5
|
+
function getDevDependencies(angularVersion, options = {}) {
|
|
6
|
+
if ((0, semver.lt)(angularVersion.replace(/[~^]/, ""), "17.0.0")) throw new _angular_devkit_schematics.SchematicsException("Angular v17.0.0 or newer is required.");
|
|
7
|
+
const deps = {
|
|
8
|
+
"@analogjs/vite-plugin-angular": require_versions.ANALOG_JS_VITE_PLUGIN_ANGULAR,
|
|
9
|
+
vite: require_versions.VITE,
|
|
10
|
+
vitest: require_versions.VITEST_V4,
|
|
11
|
+
"vite-tsconfig-paths": require_versions.VITE_TSCONFIG_PATHS
|
|
12
|
+
};
|
|
13
|
+
if (options.browserMode) {
|
|
14
|
+
deps["@vitest/browser-playwright"] = require_versions.VITEST_BROWSER_PLAYWRIGHT;
|
|
15
|
+
deps["playwright"] = require_versions.PLAYWRIGHT;
|
|
16
|
+
} else deps["jsdom"] = require_versions.JSDOM;
|
|
17
|
+
return deps;
|
|
18
|
+
}
|
|
19
|
+
function addDevDependencies(tree, angularVersion, options = {}) {
|
|
20
|
+
const packageJsonPath = "package.json";
|
|
21
|
+
const packageJson = tree.read(packageJsonPath);
|
|
22
|
+
if (!packageJson) throw new _angular_devkit_schematics.SchematicsException("Could not find package.json");
|
|
23
|
+
const pkg = JSON.parse(packageJson.toString("utf-8"));
|
|
24
|
+
const devDeps = getDevDependencies(angularVersion, options);
|
|
25
|
+
pkg.devDependencies = pkg.devDependencies || {};
|
|
26
|
+
Object.entries(devDeps).forEach(([name, version]) => {
|
|
27
|
+
pkg.devDependencies[name] = version;
|
|
28
|
+
});
|
|
29
|
+
pkg.devDependencies = Object.keys(pkg.devDependencies).sort().reduce((acc, key) => {
|
|
30
|
+
acc[key] = pkg.devDependencies[key];
|
|
31
|
+
return acc;
|
|
32
|
+
}, {});
|
|
33
|
+
tree.overwrite(packageJsonPath, JSON.stringify(pkg, null, 2) + "\n");
|
|
34
|
+
}
|
|
35
|
+
//#endregion
|
|
36
|
+
exports.addDevDependencies = addDevDependencies;
|
|
37
|
+
exports.getDevDependencies = getDevDependencies;
|
|
38
|
+
|
|
39
|
+
//# sourceMappingURL=dependencies.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dependencies.js","names":[],"sources":["../../../../../../../vitest-angular-tools/src/schematics/utils/dependencies.ts"],"sourcesContent":["import { Tree, SchematicsException } from '@angular-devkit/schematics';\nimport { lt } from 'semver';\nimport {\n ANALOG_JS_VITE_PLUGIN_ANGULAR,\n JSDOM,\n PLAYWRIGHT,\n VITE,\n VITE_TSCONFIG_PATHS,\n VITEST_BROWSER_PLAYWRIGHT,\n VITEST_V4,\n} from './versions';\n\nexport interface DependencyOptions {\n browserMode?: boolean;\n}\n\nexport function getDevDependencies(\n angularVersion: string,\n options: DependencyOptions = {},\n): Record<string, string> {\n const escapedVersion = angularVersion.replace(/[~^]/, '');\n\n if (lt(escapedVersion, '17.0.0')) {\n throw new SchematicsException('Angular v17.0.0 or newer is required.');\n }\n\n const deps: Record<string, string> = {\n '@analogjs/vite-plugin-angular': ANALOG_JS_VITE_PLUGIN_ANGULAR,\n vite: VITE,\n vitest: VITEST_V4,\n 'vite-tsconfig-paths': VITE_TSCONFIG_PATHS,\n };\n\n if (options.browserMode) {\n deps['@vitest/browser-playwright'] = VITEST_BROWSER_PLAYWRIGHT;\n deps['playwright'] = PLAYWRIGHT;\n } else {\n deps['jsdom'] = JSDOM;\n }\n\n return deps;\n}\n\nexport function addDevDependencies(\n tree: Tree,\n angularVersion: string,\n options: DependencyOptions = {},\n): void {\n const packageJsonPath = 'package.json';\n const packageJson = tree.read(packageJsonPath);\n if (!packageJson) {\n throw new SchematicsException('Could not find package.json');\n }\n\n const pkg = JSON.parse(packageJson.toString('utf-8'));\n const devDeps = getDevDependencies(angularVersion, options);\n\n pkg.devDependencies = pkg.devDependencies || {};\n Object.entries(devDeps).forEach(([name, version]) => {\n pkg.devDependencies[name] = version;\n });\n\n // Sort devDependencies alphabetically\n pkg.devDependencies = Object.keys(pkg.devDependencies)\n .sort()\n .reduce((acc: Record<string, string>, key) => {\n acc[key] = pkg.devDependencies[key];\n return acc;\n }, {});\n\n tree.overwrite(packageJsonPath, JSON.stringify(pkg, null, 2) + '\\n');\n}\n"],"mappings":";;;;AAgBA,SAAgB,mBACd,gBACA,UAA6B,EAAE,EACP;AAGxB,MAAA,GAAA,OAAA,IAFuB,eAAe,QAAQ,QAAQ,GAAG,EAElC,SAAS,CAC9B,OAAM,IAAI,2BAAA,oBAAoB,wCAAwC;CAGxE,MAAM,OAA+B;EACnC,iCAAiC,iBAAA;EACjC,MAAM,iBAAA;EACN,QAAQ,iBAAA;EACR,uBAAuB,iBAAA;EACxB;AAED,KAAI,QAAQ,aAAa;AACvB,OAAK,gCAAgC,iBAAA;AACrC,OAAK,gBAAgB,iBAAA;OAErB,MAAK,WAAW,iBAAA;AAGlB,QAAO;;AAGT,SAAgB,mBACd,MACA,gBACA,UAA6B,EAAE,EACzB;CACN,MAAM,kBAAkB;CACxB,MAAM,cAAc,KAAK,KAAK,gBAAgB;AAC9C,KAAI,CAAC,YACH,OAAM,IAAI,2BAAA,oBAAoB,8BAA8B;CAG9D,MAAM,MAAM,KAAK,MAAM,YAAY,SAAS,QAAQ,CAAC;CACrD,MAAM,UAAU,mBAAmB,gBAAgB,QAAQ;AAE3D,KAAI,kBAAkB,IAAI,mBAAmB,EAAE;AAC/C,QAAO,QAAQ,QAAQ,CAAC,SAAS,CAAC,MAAM,aAAa;AACnD,MAAI,gBAAgB,QAAQ;GAC5B;AAGF,KAAI,kBAAkB,OAAO,KAAK,IAAI,gBAAgB,CACnD,MAAM,CACN,QAAQ,KAA6B,QAAQ;AAC5C,MAAI,OAAO,IAAI,gBAAgB;AAC/B,SAAO;IACN,EAAE,CAAC;AAER,MAAK,UAAU,iBAAiB,KAAK,UAAU,KAAK,MAAM,EAAE,GAAG,KAAK"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export declare const ANALOG_JS_VITE_PLUGIN_ANGULAR = "^3.0.0-alpha.20";
|
|
2
|
+
export declare const JSDOM = "^22.0.0";
|
|
3
|
+
export declare const VITE_TSCONFIG_PATHS = "^4.2.0";
|
|
4
|
+
export declare const VITE = "^7.0.0";
|
|
5
|
+
export declare const VITEST_V4 = "^4.0.0";
|
|
6
|
+
export declare const VITEST_BROWSER_PLAYWRIGHT = "^4.0.0";
|
|
7
|
+
export declare const PLAYWRIGHT = "^1.54.0";
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
//#region packages/vitest-angular-tools/src/schematics/utils/versions.ts
|
|
2
|
+
var ANALOG_JS_VITE_PLUGIN_ANGULAR = "^3.0.0-alpha.20";
|
|
3
|
+
var JSDOM = "^22.0.0";
|
|
4
|
+
var VITE_TSCONFIG_PATHS = "^4.2.0";
|
|
5
|
+
var VITE = "^7.0.0";
|
|
6
|
+
var VITEST_V4 = "^4.0.0";
|
|
7
|
+
var VITEST_BROWSER_PLAYWRIGHT = "^4.0.0";
|
|
8
|
+
var PLAYWRIGHT = "^1.54.0";
|
|
9
|
+
//#endregion
|
|
10
|
+
exports.ANALOG_JS_VITE_PLUGIN_ANGULAR = ANALOG_JS_VITE_PLUGIN_ANGULAR;
|
|
11
|
+
exports.JSDOM = JSDOM;
|
|
12
|
+
exports.PLAYWRIGHT = PLAYWRIGHT;
|
|
13
|
+
exports.VITE = VITE;
|
|
14
|
+
exports.VITEST_BROWSER_PLAYWRIGHT = VITEST_BROWSER_PLAYWRIGHT;
|
|
15
|
+
exports.VITEST_V4 = VITEST_V4;
|
|
16
|
+
exports.VITE_TSCONFIG_PATHS = VITE_TSCONFIG_PATHS;
|
|
17
|
+
|
|
18
|
+
//# sourceMappingURL=versions.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"versions.js","names":[],"sources":["../../../../../../../vitest-angular-tools/src/schematics/utils/versions.ts"],"sourcesContent":["// Version constants (Angular 20+)\nexport const ANALOG_JS_VITE_PLUGIN_ANGULAR = '^3.0.0-alpha.20';\nexport const JSDOM = '^22.0.0';\nexport const VITE_TSCONFIG_PATHS = '^4.2.0';\nexport const VITE = '^7.0.0';\nexport const VITEST_V4 = '^4.0.0';\n\n// Browser mode dependencies\nexport const VITEST_BROWSER_PLAYWRIGHT = '^4.0.0';\nexport const PLAYWRIGHT = '^1.54.0';\n"],"mappings":";AACA,IAAa,gCAAgC;AAC7C,IAAa,QAAQ;AACrB,IAAa,sBAAsB;AACnC,IAAa,OAAO;AACpB,IAAa,YAAY;AAGzB,IAAa,4BAA4B;AACzC,IAAa,aAAa"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { Tree } from "@angular-devkit/schematics";
|
|
2
|
+
export declare function isNxWorkspace(tree: Tree): boolean;
|
|
3
|
+
export interface WorkspaceProject {
|
|
4
|
+
root: string;
|
|
5
|
+
sourceRoot?: string;
|
|
6
|
+
architect?: Record<string, {
|
|
7
|
+
builder?: string;
|
|
8
|
+
options?: Record<string, unknown>;
|
|
9
|
+
}>;
|
|
10
|
+
}
|
|
11
|
+
export interface WorkspaceSchema {
|
|
12
|
+
projects: Record<string, WorkspaceProject>;
|
|
13
|
+
}
|
|
14
|
+
export declare function getWorkspace(tree: Tree): WorkspaceSchema;
|
|
15
|
+
export declare function getProject(workspace: WorkspaceSchema, projectName: string): WorkspaceProject;
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
let _angular_devkit_schematics = require("@angular-devkit/schematics");
|
|
2
|
+
//#region packages/vitest-angular-tools/src/schematics/utils/workspace.ts
|
|
3
|
+
function isNxWorkspace(tree) {
|
|
4
|
+
return tree.exists("/nx.json");
|
|
5
|
+
}
|
|
6
|
+
function getWorkspace(tree) {
|
|
7
|
+
const workspaceFile = tree.read("angular.json");
|
|
8
|
+
if (!workspaceFile) throw new _angular_devkit_schematics.SchematicsException("Could not find angular.json");
|
|
9
|
+
return JSON.parse(workspaceFile.toString("utf-8"));
|
|
10
|
+
}
|
|
11
|
+
function getProject(workspace, projectName) {
|
|
12
|
+
const project = workspace.projects[projectName];
|
|
13
|
+
if (!project) throw new _angular_devkit_schematics.SchematicsException(`Project "${projectName}" not found in angular.json`);
|
|
14
|
+
return project;
|
|
15
|
+
}
|
|
16
|
+
//#endregion
|
|
17
|
+
exports.getProject = getProject;
|
|
18
|
+
exports.getWorkspace = getWorkspace;
|
|
19
|
+
exports.isNxWorkspace = isNxWorkspace;
|
|
20
|
+
|
|
21
|
+
//# sourceMappingURL=workspace.js.map
|