vitest 0.0.132 → 0.0.136
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/dist/cli.js +5 -5
- package/dist/{diff-647a0e09.js → diff-04ac7bc9.js} +2 -2
- package/dist/entry.js +81 -16
- package/dist/{externalize-2f63779d.js → externalize-b979f524.js} +2 -2
- package/dist/{global-a033a355.js → global-3d90eb55.js} +3 -3
- package/dist/index-0b823579.js +8588 -0
- package/dist/{index-e7a9a813.js → index-6397bdab.js} +4 -2
- package/dist/index.d.ts +134 -14
- package/dist/index.js +2 -2
- package/dist/jest-mock-30625866.js +1 -1
- package/dist/node.d.ts +115 -2
- package/dist/node.js +2 -2
- package/dist/{setup-fa2ed534.js → setup-6bff359f.js} +44 -20
- package/dist/vi-2509fe43.js +3462 -0
- package/dist/worker.js +25 -20
- package/package.json +4 -4
- package/dist/index-eb09e1f4.js +0 -8491
- package/dist/vi-d23b3fa3.js +0 -3461
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { g as getCurrentSuite, w as withTimeout, a as getDefaultHookTimeout, b as getState, s as setState, c as suite, t as test, d as describe, i as it, v as vitest, e as vi } from './vi-
|
|
1
|
+
import { g as getCurrentSuite, w as withTimeout, a as getDefaultHookTimeout, b as getState, s as setState, c as suite, t as test, d as describe, i as it, v as vitest, e as vi } from './vi-2509fe43.js';
|
|
2
2
|
import chai, { assert, should } from 'chai';
|
|
3
3
|
import { s as spies, i as isMockFunction, a as spyOn, f as fn } from './jest-mock-30625866.js';
|
|
4
4
|
|
|
@@ -12,6 +12,8 @@ const expect = (value, message) => {
|
|
|
12
12
|
setState({ assertionCalls: assertionCalls + 1 });
|
|
13
13
|
return chai.expect(value, message);
|
|
14
14
|
};
|
|
15
|
+
expect.getState = getState;
|
|
16
|
+
expect.setState = setState;
|
|
15
17
|
Object.assign(expect, chai.expect);
|
|
16
18
|
|
|
17
19
|
var index = /*#__PURE__*/Object.freeze({
|
|
@@ -37,4 +39,4 @@ var index = /*#__PURE__*/Object.freeze({
|
|
|
37
39
|
});
|
|
38
40
|
|
|
39
41
|
export { afterAll as a, beforeAll as b, beforeEach as c, afterEach as d, expect as e, index as i };
|
|
40
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
42
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXgtNjM5N2JkYWIuanMiLCJzb3VyY2VzIjpbIi4uL3NyYy9ydW50aW1lL2hvb2tzLnRzIiwiLi4vc3JjL2ludGVncmF0aW9ucy9jaGFpL2luZGV4LnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgU3VpdGVIb29rcyB9IGZyb20gJy4uL3R5cGVzJ1xuaW1wb3J0IHsgZ2V0RGVmYXVsdEhvb2tUaW1lb3V0LCB3aXRoVGltZW91dCB9IGZyb20gJy4vY29udGV4dCdcbmltcG9ydCB7IGdldEN1cnJlbnRTdWl0ZSB9IGZyb20gJy4vc3VpdGUnXG5cbi8vIHN1aXRlIGhvb2tzXG5leHBvcnQgY29uc3QgYmVmb3JlQWxsID0gKGZuOiBTdWl0ZUhvb2tzWydiZWZvcmVBbGwnXVswXSwgdGltZW91dD86IG51bWJlcikgPT4gZ2V0Q3VycmVudFN1aXRlKCkub24oJ2JlZm9yZUFsbCcsIHdpdGhUaW1lb3V0KGZuLCB0aW1lb3V0ID8/IGdldERlZmF1bHRIb29rVGltZW91dCgpKSlcbmV4cG9ydCBjb25zdCBhZnRlckFsbCA9IChmbjogU3VpdGVIb29rc1snYWZ0ZXJBbGwnXVswXSwgdGltZW91dD86IG51bWJlcikgPT4gZ2V0Q3VycmVudFN1aXRlKCkub24oJ2FmdGVyQWxsJywgd2l0aFRpbWVvdXQoZm4sIHRpbWVvdXQgPz8gZ2V0RGVmYXVsdEhvb2tUaW1lb3V0KCkpKVxuZXhwb3J0IGNvbnN0IGJlZm9yZUVhY2ggPSAoZm46IFN1aXRlSG9va3NbJ2JlZm9yZUVhY2gnXVswXSwgdGltZW91dD86IG51bWJlcikgPT4gZ2V0Q3VycmVudFN1aXRlKCkub24oJ2JlZm9yZUVhY2gnLCB3aXRoVGltZW91dChmbiwgdGltZW91dCA/PyBnZXREZWZhdWx0SG9va1RpbWVvdXQoKSkpXG5leHBvcnQgY29uc3QgYWZ0ZXJFYWNoID0gKGZuOiBTdWl0ZUhvb2tzWydhZnRlckVhY2gnXVswXSwgdGltZW91dD86IG51bWJlcikgPT4gZ2V0Q3VycmVudFN1aXRlKCkub24oJ2FmdGVyRWFjaCcsIHdpdGhUaW1lb3V0KGZuLCB0aW1lb3V0ID8/IGdldERlZmF1bHRIb29rVGltZW91dCgpKSlcbiIsImltcG9ydCBjaGFpIGZyb20gJ2NoYWknXG5pbXBvcnQgeyBnZXRTdGF0ZSwgc2V0U3RhdGUgfSBmcm9tICcuL2plc3QtZXhwZWN0J1xuXG5leHBvcnQgeyBhc3NlcnQsIHNob3VsZCB9IGZyb20gJ2NoYWknXG5cbmNvbnN0IGV4cGVjdCA9ICgodmFsdWU6IGFueSwgbWVzc2FnZT86IHN0cmluZyk6IENoYWkuQXNzZXJ0aW9uID0+IHtcbiAgY29uc3QgeyBhc3NlcnRpb25DYWxscyB9ID0gZ2V0U3RhdGUoKVxuICBzZXRTdGF0ZSh7IGFzc2VydGlvbkNhbGxzOiBhc3NlcnRpb25DYWxscyArIDEgfSlcbiAgcmV0dXJuIGNoYWkuZXhwZWN0KHZhbHVlLCBtZXNzYWdlKVxufSkgYXMgQ2hhaS5FeHBlY3RTdGF0aWNcbmV4cGVjdC5nZXRTdGF0ZSA9IGdldFN0YXRlXG5leHBlY3Quc2V0U3RhdGUgPSBzZXRTdGF0ZVxuXG5PYmplY3QuYXNzaWduKGV4cGVjdCwgY2hhaS5leHBlY3QpXG5cbmV4cG9ydCB7IGNoYWksIGV4cGVjdCB9XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7OztBQUVZLE1BQUMsU0FBUyxHQUFHLENBQUMsRUFBRSxFQUFFLE9BQU8sS0FBSyxlQUFlLEVBQUUsQ0FBQyxFQUFFLENBQUMsV0FBVyxFQUFFLFdBQVcsQ0FBQyxFQUFFLEVBQUUsT0FBTyxJQUFJLHFCQUFxQixFQUFFLENBQUMsRUFBRTtBQUNySCxNQUFDLFFBQVEsR0FBRyxDQUFDLEVBQUUsRUFBRSxPQUFPLEtBQUssZUFBZSxFQUFFLENBQUMsRUFBRSxDQUFDLFVBQVUsRUFBRSxXQUFXLENBQUMsRUFBRSxFQUFFLE9BQU8sSUFBSSxxQkFBcUIsRUFBRSxDQUFDLEVBQUU7QUFDbkgsTUFBQyxVQUFVLEdBQUcsQ0FBQyxFQUFFLEVBQUUsT0FBTyxLQUFLLGVBQWUsRUFBRSxDQUFDLEVBQUUsQ0FBQyxZQUFZLEVBQUUsV0FBVyxDQUFDLEVBQUUsRUFBRSxPQUFPLElBQUkscUJBQXFCLEVBQUUsQ0FBQyxFQUFFO0FBQ3ZILE1BQUMsU0FBUyxHQUFHLENBQUMsRUFBRSxFQUFFLE9BQU8sS0FBSyxlQUFlLEVBQUUsQ0FBQyxFQUFFLENBQUMsV0FBVyxFQUFFLFdBQVcsQ0FBQyxFQUFFLEVBQUUsT0FBTyxJQUFJLHFCQUFxQixFQUFFLENBQUM7O0FDRjFILE1BQUMsTUFBTSxHQUFHLENBQUMsS0FBSyxFQUFFLE9BQU8sS0FBSztBQUNuQyxFQUFFLE1BQU0sRUFBRSxjQUFjLEVBQUUsR0FBRyxRQUFRLEVBQUUsQ0FBQztBQUN4QyxFQUFFLFFBQVEsQ0FBQyxFQUFFLGNBQWMsRUFBRSxjQUFjLEdBQUcsQ0FBQyxFQUFFLENBQUMsQ0FBQztBQUNuRCxFQUFFLE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQyxLQUFLLEVBQUUsT0FBTyxDQUFDLENBQUM7QUFDckMsRUFBRTtBQUNGLE1BQU0sQ0FBQyxRQUFRLEdBQUcsUUFBUSxDQUFDO0FBQzNCLE1BQU0sQ0FBQyxRQUFRLEdBQUcsUUFBUSxDQUFDO0FBQzNCLE1BQU0sQ0FBQyxNQUFNLENBQUMsTUFBTSxFQUFFLElBQUksQ0FBQyxNQUFNLENBQUM7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OzsifQ==
|
package/dist/index.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { ViteDevServer, CommonServerOptions } from 'vite';
|
|
1
|
+
import { ViteDevServer, CommonServerOptions, TransformResult } from 'vite';
|
|
2
2
|
import { MessagePort } from 'worker_threads';
|
|
3
3
|
import { SpyImpl } from 'tinyspy';
|
|
4
4
|
export { Spy, SpyFn } from 'tinyspy';
|
|
@@ -385,10 +385,24 @@ declare class VerboseReporter extends DefaultReporter {
|
|
|
385
385
|
constructor();
|
|
386
386
|
}
|
|
387
387
|
|
|
388
|
+
declare class TapReporter implements Reporter {
|
|
389
|
+
protected ctx: Vitest;
|
|
390
|
+
onInit(ctx: Vitest): void;
|
|
391
|
+
protected logTasks(tasks: Task[], currentIdent: string): void;
|
|
392
|
+
onFinished(files?: File[]): Promise<void>;
|
|
393
|
+
}
|
|
394
|
+
|
|
395
|
+
declare class TapFlatReporter extends TapReporter {
|
|
396
|
+
onInit(ctx: Vitest): void;
|
|
397
|
+
onFinished(files?: File[]): Promise<void>;
|
|
398
|
+
}
|
|
399
|
+
|
|
388
400
|
declare const ReportersMap: {
|
|
389
401
|
default: typeof DefaultReporter;
|
|
390
402
|
verbose: typeof VerboseReporter;
|
|
391
403
|
dot: typeof DotReporter;
|
|
404
|
+
tap: typeof TapReporter;
|
|
405
|
+
'tap-flat': typeof TapFlatReporter;
|
|
392
406
|
};
|
|
393
407
|
declare type BuiltinReporters = keyof typeof ReportersMap;
|
|
394
408
|
|
|
@@ -442,6 +456,86 @@ interface ResolvedC8Options extends Required<C8Options> {
|
|
|
442
456
|
tempDirectory: string;
|
|
443
457
|
}
|
|
444
458
|
|
|
459
|
+
interface JSDOMOptions {
|
|
460
|
+
/**
|
|
461
|
+
* The html content for the test.
|
|
462
|
+
*
|
|
463
|
+
* @default '<!DOCTYPE html>'
|
|
464
|
+
*/
|
|
465
|
+
html?: string | Buffer | ArrayBufferLike;
|
|
466
|
+
/**
|
|
467
|
+
* referrer just affects the value read from document.referrer.
|
|
468
|
+
* It defaults to no referrer (which reflects as the empty string).
|
|
469
|
+
*/
|
|
470
|
+
referrer?: string;
|
|
471
|
+
/**
|
|
472
|
+
* userAgent affects the value read from navigator.userAgent, as well as the User-Agent header sent while fetching subresources.
|
|
473
|
+
*
|
|
474
|
+
* @default `Mozilla/5.0 (${process.platform}) AppleWebKit/537.36 (KHTML, like Gecko) jsdom/${jsdomVersion}`
|
|
475
|
+
*/
|
|
476
|
+
userAgent?: string;
|
|
477
|
+
/**
|
|
478
|
+
* url sets the value returned by window.location, document.URL, and document.documentURI,
|
|
479
|
+
* and affects things like resolution of relative URLs within the document
|
|
480
|
+
* and the same-origin restrictions and referrer used while fetching subresources.
|
|
481
|
+
*
|
|
482
|
+
* @default 'http://localhost:3000'.
|
|
483
|
+
*/
|
|
484
|
+
url?: string;
|
|
485
|
+
/**
|
|
486
|
+
* contentType affects the value read from document.contentType, and how the document is parsed: as HTML or as XML.
|
|
487
|
+
* Values that are not "text/html" or an XML mime type will throw.
|
|
488
|
+
*
|
|
489
|
+
* @default 'text/html'.
|
|
490
|
+
*/
|
|
491
|
+
contentType?: string;
|
|
492
|
+
/**
|
|
493
|
+
* The maximum size in code units for the separate storage areas used by localStorage and sessionStorage.
|
|
494
|
+
* Attempts to store data larger than this limit will cause a DOMException to be thrown. By default, it is set
|
|
495
|
+
* to 5,000,000 code units per origin, as inspired by the HTML specification.
|
|
496
|
+
*
|
|
497
|
+
* @default 5_000_000
|
|
498
|
+
*/
|
|
499
|
+
storageQuota?: number;
|
|
500
|
+
/**
|
|
501
|
+
* Enable console?
|
|
502
|
+
*
|
|
503
|
+
* @default false
|
|
504
|
+
*/
|
|
505
|
+
console?: boolean;
|
|
506
|
+
/**
|
|
507
|
+
* jsdom does not have the capability to render visual content, and will act like a headless browser by default.
|
|
508
|
+
* It provides hints to web pages through APIs such as document.hidden that their content is not visible.
|
|
509
|
+
*
|
|
510
|
+
* When the `pretendToBeVisual` option is set to `true`, jsdom will pretend that it is rendering and displaying
|
|
511
|
+
* content.
|
|
512
|
+
*
|
|
513
|
+
* @default true
|
|
514
|
+
*/
|
|
515
|
+
pretendToBeVisual?: boolean;
|
|
516
|
+
/**
|
|
517
|
+
* `includeNodeLocations` preserves the location info produced by the HTML parser,
|
|
518
|
+
* allowing you to retrieve it with the nodeLocation() method (described below).
|
|
519
|
+
*
|
|
520
|
+
* It defaults to false to give the best performance,
|
|
521
|
+
* and cannot be used with an XML content type since our XML parser does not support location info.
|
|
522
|
+
*
|
|
523
|
+
* @default false
|
|
524
|
+
*/
|
|
525
|
+
includeNodeLocations?: boolean | undefined;
|
|
526
|
+
/**
|
|
527
|
+
* @default 'dangerously'
|
|
528
|
+
*/
|
|
529
|
+
runScripts?: 'dangerously' | 'outside-only';
|
|
530
|
+
/**
|
|
531
|
+
* Enable CookieJar
|
|
532
|
+
*
|
|
533
|
+
* @default false
|
|
534
|
+
*/
|
|
535
|
+
cookieJar?: boolean;
|
|
536
|
+
resources?: 'usable' | any;
|
|
537
|
+
}
|
|
538
|
+
|
|
445
539
|
declare type Awaitable<T> = T | PromiseLike<T>;
|
|
446
540
|
declare type Nullable<T> = T | null | undefined;
|
|
447
541
|
declare type Arrayable<T> = T | Array<T>;
|
|
@@ -456,7 +550,7 @@ interface EnvironmentReturn {
|
|
|
456
550
|
}
|
|
457
551
|
interface Environment {
|
|
458
552
|
name: string;
|
|
459
|
-
setup(global: any): Awaitable<EnvironmentReturn>;
|
|
553
|
+
setup(global: any, options: Record<string, any>): Awaitable<EnvironmentReturn>;
|
|
460
554
|
}
|
|
461
555
|
interface UserConsoleLog {
|
|
462
556
|
content: string;
|
|
@@ -485,6 +579,11 @@ interface ErrorWithDiff extends Error {
|
|
|
485
579
|
expected?: any;
|
|
486
580
|
operator?: string;
|
|
487
581
|
}
|
|
582
|
+
interface ModuleGraphData {
|
|
583
|
+
graph: Record<string, string[]>;
|
|
584
|
+
externalized: string[];
|
|
585
|
+
inlined: string[];
|
|
586
|
+
}
|
|
488
587
|
|
|
489
588
|
declare type ChainableFunction<T extends string, Args extends any[], R = any> = {
|
|
490
589
|
(...args: Args): R;
|
|
@@ -613,6 +712,13 @@ interface SnapshotSummary {
|
|
|
613
712
|
|
|
614
713
|
declare type BuiltinEnvironment = 'node' | 'jsdom' | 'happy-dom';
|
|
615
714
|
declare type ApiConfig = Pick<CommonServerOptions, 'port' | 'strictPort' | 'host'>;
|
|
715
|
+
|
|
716
|
+
interface EnvironmentOptions {
|
|
717
|
+
/**
|
|
718
|
+
* jsdom options.
|
|
719
|
+
*/
|
|
720
|
+
jsdom?: JSDOMOptions;
|
|
721
|
+
}
|
|
616
722
|
interface InlineConfig {
|
|
617
723
|
/**
|
|
618
724
|
* Include globs for test files
|
|
@@ -674,7 +780,11 @@ interface InlineConfig {
|
|
|
674
780
|
*/
|
|
675
781
|
environment?: BuiltinEnvironment;
|
|
676
782
|
/**
|
|
677
|
-
*
|
|
783
|
+
* Environment options.
|
|
784
|
+
*/
|
|
785
|
+
environmentOptions?: EnvironmentOptions;
|
|
786
|
+
/**
|
|
787
|
+
* Update snapshot
|
|
678
788
|
*
|
|
679
789
|
* @default false
|
|
680
790
|
*/
|
|
@@ -687,6 +797,8 @@ interface InlineConfig {
|
|
|
687
797
|
watch?: boolean;
|
|
688
798
|
/**
|
|
689
799
|
* Project root
|
|
800
|
+
*
|
|
801
|
+
* @default process.cwd()
|
|
690
802
|
*/
|
|
691
803
|
root?: string;
|
|
692
804
|
/**
|
|
@@ -780,7 +892,13 @@ interface InlineConfig {
|
|
|
780
892
|
* Open Vitest UI
|
|
781
893
|
* @internal WIP
|
|
782
894
|
*/
|
|
783
|
-
|
|
895
|
+
ui?: boolean;
|
|
896
|
+
/**
|
|
897
|
+
* Base url for the UI
|
|
898
|
+
*
|
|
899
|
+
* @default '/__vitest__/'
|
|
900
|
+
*/
|
|
901
|
+
uiBase?: string;
|
|
784
902
|
}
|
|
785
903
|
interface UserConfig extends InlineConfig {
|
|
786
904
|
/**
|
|
@@ -866,11 +984,11 @@ interface MockResultThrow {
|
|
|
866
984
|
value: any;
|
|
867
985
|
}
|
|
868
986
|
declare type MockResult<T> = MockResultReturn<T> | MockResultThrow | MockResultIncomplete;
|
|
869
|
-
interface JestMockCompatContext<
|
|
870
|
-
calls:
|
|
871
|
-
instances:
|
|
987
|
+
interface JestMockCompatContext<TArgs, TReturns> {
|
|
988
|
+
calls: TArgs[];
|
|
989
|
+
instances: TReturns[];
|
|
872
990
|
invocationCallOrder: number[];
|
|
873
|
-
results: MockResult<
|
|
991
|
+
results: MockResult<TReturns>[];
|
|
874
992
|
}
|
|
875
993
|
declare type Procedure = (...args: any[]) => any;
|
|
876
994
|
declare type Methods<T> = {
|
|
@@ -1014,16 +1132,16 @@ declare class VitestUtils {
|
|
|
1014
1132
|
declare const vitest: VitestUtils;
|
|
1015
1133
|
declare const vi: VitestUtils;
|
|
1016
1134
|
|
|
1135
|
+
interface TransformResultWithSource extends TransformResult {
|
|
1136
|
+
source?: string;
|
|
1137
|
+
}
|
|
1017
1138
|
interface WebSocketHandlers {
|
|
1018
1139
|
getFiles(): File[];
|
|
1019
1140
|
getConfig(): ResolvedConfig;
|
|
1141
|
+
getModuleGraph(id: string): Promise<ModuleGraphData>;
|
|
1142
|
+
getTransformResult(id: string): Promise<TransformResultWithSource | undefined>;
|
|
1020
1143
|
readFile(id: string): Promise<string>;
|
|
1021
1144
|
writeFile(id: string, content: string): Promise<void>;
|
|
1022
|
-
getModuleGraph(id: string): Promise<{
|
|
1023
|
-
graph: Record<string, string[]>;
|
|
1024
|
-
externalized: string[];
|
|
1025
|
-
inlined: string[];
|
|
1026
|
-
}>;
|
|
1027
1145
|
rerun(files: string[]): Promise<void>;
|
|
1028
1146
|
}
|
|
1029
1147
|
interface WebSocketEvents extends Pick<Reporter, 'onCollected' | 'onTaskUpdate'> {
|
|
@@ -1054,6 +1172,8 @@ declare global {
|
|
|
1054
1172
|
anything(): Anything;
|
|
1055
1173
|
any(constructor: unknown): Any;
|
|
1056
1174
|
addSnapshotSerializer(plugin: Plugin): void;
|
|
1175
|
+
getState(): MatcherState;
|
|
1176
|
+
setState(state: Partial<MatcherState>): void;
|
|
1057
1177
|
not: AsymmetricMatchersContaining;
|
|
1058
1178
|
}
|
|
1059
1179
|
interface JestAssertions {
|
|
@@ -1120,4 +1240,4 @@ declare global {
|
|
|
1120
1240
|
}
|
|
1121
1241
|
}
|
|
1122
1242
|
|
|
1123
|
-
export { ApiConfig, ArgumentsType, Arrayable, Awaitable, BuiltinEnvironment, DoneCallback, EnhancedSpy, Environment, EnvironmentReturn, ErrorWithDiff, File, HookListener, InlineConfig, JestMockCompat, JestMockCompatContext, JestMockCompatFn, MaybeMocked, MaybeMockedConstructor, MaybeMockedDeep, MockWithArgs, MockedFunction, MockedFunctionDeep, MockedObject, MockedObjectDeep, ModuleCache, Nullable, ParsedStack, Position, Reporter, ResolvedConfig, RunMode, RuntimeContext, SnapshotData, SnapshotMatchOptions, SnapshotResult, SnapshotStateOptions, SnapshotSummary, SnapshotUpdateState, Suite, SuiteCollector, SuiteHooks, Task, TaskBase, TaskResult, TaskResultPack, TaskState, Test, TestCollector, TestFactory, TestFunction, UncheckedSnapshot, UserConfig, UserConsoleLog, WebSocketEvents, WebSocketHandlers, WorkerContext, WorkerRPC, afterAll, afterEach, beforeAll, beforeEach, describe, expect, fn, isMockFunction, it, spies, spyOn, suite, test, vi, vitest };
|
|
1243
|
+
export { ApiConfig, ArgumentsType, Arrayable, Awaitable, BuiltinEnvironment, DoneCallback, EnhancedSpy, Environment, EnvironmentOptions, EnvironmentReturn, ErrorWithDiff, File, HookListener, InlineConfig, JSDOMOptions, JestMockCompat, JestMockCompatContext, JestMockCompatFn, MaybeMocked, MaybeMockedConstructor, MaybeMockedDeep, MockWithArgs, MockedFunction, MockedFunctionDeep, MockedObject, MockedObjectDeep, ModuleCache, ModuleGraphData, Nullable, ParsedStack, Position, Reporter, ResolvedConfig, RunMode, RuntimeContext, SnapshotData, SnapshotMatchOptions, SnapshotResult, SnapshotStateOptions, SnapshotSummary, SnapshotUpdateState, Suite, SuiteCollector, SuiteHooks, Task, TaskBase, TaskResult, TaskResultPack, TaskState, Test, TestCollector, TestFactory, TestFunction, TransformResultWithSource, UncheckedSnapshot, UserConfig, UserConsoleLog, WebSocketEvents, WebSocketHandlers, WorkerContext, WorkerRPC, afterAll, afterEach, beforeAll, beforeEach, describe, expect, fn, isMockFunction, it, spies, spyOn, suite, test, vi, vitest };
|
package/dist/index.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
export { d as describe, i as it, c as suite, t as test, e as vi, v as vitest } from './vi-
|
|
2
|
-
export { a as afterAll, d as afterEach, b as beforeAll, c as beforeEach, e as expect } from './index-
|
|
1
|
+
export { d as describe, i as it, c as suite, t as test, e as vi, v as vitest } from './vi-2509fe43.js';
|
|
2
|
+
export { a as afterAll, d as afterEach, b as beforeAll, c as beforeEach, e as expect } from './index-6397bdab.js';
|
|
3
3
|
export { f as fn, i as isMockFunction, s as spies, a as spyOn } from './jest-mock-30625866.js';
|
|
4
4
|
export { assert, default as chai, should } from 'chai';
|
|
5
5
|
import './index-64aafe4b.js';
|
|
@@ -91,4 +91,4 @@ function fn(implementation) {
|
|
|
91
91
|
}
|
|
92
92
|
|
|
93
93
|
export { spyOn as a, fn as f, isMockFunction as i, spies as s };
|
|
94
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"jest-mock-30625866.js","sources":["../src/integrations/jest-mock.ts"],"sourcesContent":["import { util } from 'chai'\nimport type { SpyImpl } from 'tinyspy'\nimport * as tinyspy from 'tinyspy'\n\ninterface MockResultReturn<T> {\n  type: 'return'\n  value: T\n}\ninterface MockResultIncomplete {\n  type: 'incomplete'\n  value: undefined\n}\ninterface MockResultThrow {\n  type: 'throw'\n  value: any\n}\n\ntype MockResult<T> = MockResultReturn<T> | MockResultThrow | MockResultIncomplete\n\nexport interface JestMockCompatContext<T, Y> {\n  calls: Y[]\n  instances: T[]\n  // TODO: doesn't work\n  invocationCallOrder: number[]\n  results: MockResult<T>[]\n}\n\ntype Procedure = (...args: any[]) => any\n\ntype Methods<T> = {\n  [K in keyof T]: T[K] extends Procedure ? K : never\n}[keyof T] & string\ntype Properties<T> = {\n  [K in keyof T]: T[K] extends Procedure ? never : K\n}[keyof T] & string\ntype Classes<T> = {\n  [K in keyof T]: T[K] extends new (...args: any[]) => any ? K : never\n}[keyof T] & string\n\nexport interface JestMockCompat<TArgs extends any[] = any[], TReturns = any> {\n  getMockName(): string\n  mockName(n: string): this\n  mock: JestMockCompatContext<TArgs, TReturns>\n  mockClear(): this\n  mockReset(): this\n  mockRestore(): void\n  getMockImplementation(): ((...args: TArgs) => TReturns) | undefined\n  mockImplementation(fn: ((...args: TArgs) => TReturns) | (() => Promise<TReturns>)): this\n  mockImplementationOnce(fn: ((...args: TArgs) => TReturns) | (() => Promise<TReturns>)): this\n  mockReturnThis(): this\n  mockReturnValue(obj: TReturns): this\n  mockReturnValueOnce(obj: TReturns): this\n  mockResolvedValue(obj: Awaited<TReturns>): this\n  mockResolvedValueOnce(obj: Awaited<TReturns>): this\n  mockRejectedValue(obj: any): this\n  mockRejectedValueOnce(obj: any): this\n}\n\nexport interface JestMockCompatFn<TArgs extends any[] = any, TReturns = any> extends JestMockCompat<TArgs, TReturns> {\n  (...args: TArgs): TReturns\n}\n\nexport type MaybeMockedConstructor<T> = T extends new (\n  ...args: Array<any>\n) => infer R\n  ? JestMockCompatFn<ConstructorParameters<T>, R>\n  : T\nexport type MockedFunction<T extends Procedure> = MockWithArgs<T> & {\n  [K in keyof T]: T[K];\n}\nexport type MockedFunctionDeep<T extends Procedure> = MockWithArgs<T> & MockedObjectDeep<T>\nexport type MockedObject<T> = MaybeMockedConstructor<T> & {\n  [K in Methods<T>]: T[K] extends Procedure\n    ? MockedFunction<T[K]>\n    : T[K];\n} & {[K in Properties<T>]: T[K]}\nexport type MockedObjectDeep<T> = MaybeMockedConstructor<T> & {\n  [K in Methods<T>]: T[K] extends Procedure\n    ? MockedFunctionDeep<T[K]>\n    : T[K];\n} & {[K in Properties<T>]: MaybeMockedDeep<T[K]>}\n\nexport type MaybeMockedDeep<T> = T extends Procedure\n  ? MockedFunctionDeep<T>\n  : T extends object\n    ? MockedObjectDeep<T>\n    : T\n\nexport type MaybeMocked<T> = T extends Procedure\n  ? MockedFunction<T>\n  : T extends object\n    ? MockedObject<T>\n    : T\n\nexport type EnhancedSpy<TArgs extends any[] = any[], TReturns = any> = JestMockCompat<TArgs, TReturns> & SpyImpl<TArgs, TReturns>\n\nexport interface MockWithArgs<T extends Procedure>\n  extends JestMockCompatFn<Parameters<T>, ReturnType<T>> {\n  new (...args: T extends new (...args: any) => any ? ConstructorParameters<T> : never): T\n  (...args: Parameters<T>): ReturnType<T>\n}\n\nexport const spies = new Set<JestMockCompat>()\n\nexport function isMockFunction(fn: any): fn is EnhancedSpy {\n  return typeof fn === 'function'\n  && '__isSpy' in fn\n  && fn.__isSpy\n}\n\nexport function spyOn<T, S extends Properties<Required<T>>>(\n  obj: T,\n  methodName: S,\n  accesType: 'get',\n): JestMockCompat<[T[S]], void>\nexport function spyOn<T, G extends Properties<Required<T>>>(\n  obj: T,\n  methodName: G,\n  accesType: 'set',\n): JestMockCompat<[], T[G]>\nexport function spyOn<T, M extends Classes<Required<T>>>(\n  object: T,\n  method: M\n): Required<T>[M] extends new (...args: infer A) => infer R\n  ? JestMockCompat<A, R>\n  : never\nexport function spyOn<T, M extends Methods<Required<T>>>(\n  obj: T,\n  methodName: M,\n  mock?: T[M]\n): Required<T>[M] extends (...args: infer A) => infer R ? JestMockCompat<A, R> : never\nexport function spyOn<T, K extends keyof T>(\n  obj: T,\n  method: K,\n  accessType?: 'get' | 'set',\n): JestMockCompat {\n  const dictionary = {\n    get: 'getter',\n    set: 'setter',\n  } as const\n  const objMethod = accessType ? { [dictionary[accessType]]: method } : method\n\n  const stub = tinyspy.spyOn(obj, objMethod as any)\n\n  return enhanceSpy(stub) as JestMockCompat\n}\n\nfunction enhanceSpy<TArgs extends any[], TReturns>(\n  spy: SpyImpl<TArgs, TReturns>,\n): JestMockCompat<TArgs, TReturns> {\n  const stub = spy as unknown as EnhancedSpy<TArgs, TReturns>\n\n  let implementation: ((...args: TArgs) => TReturns) | undefined\n\n  const instances: any[] = []\n\n  const mockContext = {\n    get calls() {\n      return stub.calls\n    },\n    get instances() {\n      return instances\n    },\n    // not supported\n    get invocationCallOrder() {\n      return []\n    },\n    get results() {\n      return stub.results.map(([callType, value]) => {\n        const type = callType === 'error' ? 'throw' : 'return'\n        return { type, value }\n      })\n    },\n  }\n\n  let onceImplementations: ((...args: TArgs) => TReturns)[] = []\n\n  let name: string = (stub as any).name\n\n  stub.getMockName = () => name || 'vi.fn()'\n  stub.mockName = (n) => {\n    name = n\n    return stub\n  }\n\n  stub.mockClear = () => {\n    stub.reset()\n    return stub\n  }\n\n  stub.mockReset = () => {\n    stub.reset()\n    implementation = () => undefined as unknown as TReturns\n    onceImplementations = []\n    return stub\n  }\n\n  stub.mockRestore = () => {\n    stub.mockReset()\n    implementation = undefined\n    return stub\n  }\n\n  stub.getMockImplementation = () => implementation\n  stub.mockImplementation = (fn: (...args: TArgs) => TReturns) => {\n    implementation = fn\n    return stub\n  }\n\n  stub.mockImplementationOnce = (fn: (...args: TArgs) => TReturns) => {\n    onceImplementations.push(fn)\n    return stub\n  }\n\n  stub.mockReturnThis = () =>\n    stub.mockImplementation(function(this: TReturns) {\n      return this\n    })\n\n  stub.mockReturnValue = (val: TReturns) => stub.mockImplementation(() => val)\n  stub.mockReturnValueOnce = (val: TReturns) => stub.mockImplementationOnce(() => val)\n\n  stub.mockResolvedValue = (val: Awaited<TReturns>) =>\n    stub.mockImplementation(() => Promise.resolve(val as TReturns))\n\n  stub.mockResolvedValueOnce = (val: Awaited<TReturns>) =>\n    stub.mockImplementationOnce(() => Promise.resolve(val as TReturns))\n\n  stub.mockRejectedValue = (val: unknown) =>\n    stub.mockImplementation(() => Promise.reject(val))\n\n  stub.mockRejectedValueOnce = (val: unknown) =>\n    stub.mockImplementationOnce(() => Promise.reject(val))\n\n  util.addProperty(stub, 'mock', () => mockContext)\n\n  stub.willCall(function(this: unknown, ...args) {\n    instances.push(this)\n    const impl = onceImplementations.shift() || implementation || stub.getOriginal() || (() => {})\n    return impl.apply(this, args)\n  })\n\n  spies.add(stub)\n\n  return stub as any\n}\n\nexport function fn<TArgs extends any[] = any[], R = any>(): JestMockCompatFn<TArgs, R>\nexport function fn<TArgs extends any[] = any[], R = any>(\n  implementation: (...args: TArgs) => R\n): JestMockCompatFn<TArgs, R>\nexport function fn<TArgs extends any[] = any[], R = any>(\n  implementation?: (...args: TArgs) => R,\n): JestMockCompatFn<TArgs, R> {\n  return enhanceSpy(tinyspy.spyOn({ fn: implementation || (() => {}) }, 'fn')) as unknown as JestMockCompatFn\n}\n"],"names":[],"mappings":"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"}
|
|
94
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"jest-mock-30625866.js","sources":["../src/integrations/jest-mock.ts"],"sourcesContent":["import { util } from 'chai'\nimport type { SpyImpl } from 'tinyspy'\nimport * as tinyspy from 'tinyspy'\n\ninterface MockResultReturn<T> {\n  type: 'return'\n  value: T\n}\ninterface MockResultIncomplete {\n  type: 'incomplete'\n  value: undefined\n}\ninterface MockResultThrow {\n  type: 'throw'\n  value: any\n}\n\ntype MockResult<T> = MockResultReturn<T> | MockResultThrow | MockResultIncomplete\n\nexport interface JestMockCompatContext<TArgs, TReturns> {\n  calls: TArgs[]\n  instances: TReturns[]\n  // TODO: doesn't work\n  invocationCallOrder: number[]\n  results: MockResult<TReturns>[]\n}\n\ntype Procedure = (...args: any[]) => any\n\ntype Methods<T> = {\n  [K in keyof T]: T[K] extends Procedure ? K : never\n}[keyof T] & string\ntype Properties<T> = {\n  [K in keyof T]: T[K] extends Procedure ? never : K\n}[keyof T] & string\ntype Classes<T> = {\n  [K in keyof T]: T[K] extends new (...args: any[]) => any ? K : never\n}[keyof T] & string\n\nexport interface JestMockCompat<TArgs extends any[] = any[], TReturns = any> {\n  getMockName(): string\n  mockName(n: string): this\n  mock: JestMockCompatContext<TArgs, TReturns>\n  mockClear(): this\n  mockReset(): this\n  mockRestore(): void\n  getMockImplementation(): ((...args: TArgs) => TReturns) | undefined\n  mockImplementation(fn: ((...args: TArgs) => TReturns) | (() => Promise<TReturns>)): this\n  mockImplementationOnce(fn: ((...args: TArgs) => TReturns) | (() => Promise<TReturns>)): this\n  mockReturnThis(): this\n  mockReturnValue(obj: TReturns): this\n  mockReturnValueOnce(obj: TReturns): this\n  mockResolvedValue(obj: Awaited<TReturns>): this\n  mockResolvedValueOnce(obj: Awaited<TReturns>): this\n  mockRejectedValue(obj: any): this\n  mockRejectedValueOnce(obj: any): this\n}\n\nexport interface JestMockCompatFn<TArgs extends any[] = any, TReturns = any> extends JestMockCompat<TArgs, TReturns> {\n  (...args: TArgs): TReturns\n}\n\nexport type MaybeMockedConstructor<T> = T extends new (\n  ...args: Array<any>\n) => infer R\n  ? JestMockCompatFn<ConstructorParameters<T>, R>\n  : T\nexport type MockedFunction<T extends Procedure> = MockWithArgs<T> & {\n  [K in keyof T]: T[K];\n}\nexport type MockedFunctionDeep<T extends Procedure> = MockWithArgs<T> & MockedObjectDeep<T>\nexport type MockedObject<T> = MaybeMockedConstructor<T> & {\n  [K in Methods<T>]: T[K] extends Procedure\n    ? MockedFunction<T[K]>\n    : T[K];\n} & {[K in Properties<T>]: T[K]}\nexport type MockedObjectDeep<T> = MaybeMockedConstructor<T> & {\n  [K in Methods<T>]: T[K] extends Procedure\n    ? MockedFunctionDeep<T[K]>\n    : T[K];\n} & {[K in Properties<T>]: MaybeMockedDeep<T[K]>}\n\nexport type MaybeMockedDeep<T> = T extends Procedure\n  ? MockedFunctionDeep<T>\n  : T extends object\n    ? MockedObjectDeep<T>\n    : T\n\nexport type MaybeMocked<T> = T extends Procedure\n  ? MockedFunction<T>\n  : T extends object\n    ? MockedObject<T>\n    : T\n\nexport type EnhancedSpy<TArgs extends any[] = any[], TReturns = any> = JestMockCompat<TArgs, TReturns> & SpyImpl<TArgs, TReturns>\n\nexport interface MockWithArgs<T extends Procedure>\n  extends JestMockCompatFn<Parameters<T>, ReturnType<T>> {\n  new (...args: T extends new (...args: any) => any ? ConstructorParameters<T> : never): T\n  (...args: Parameters<T>): ReturnType<T>\n}\n\nexport const spies = new Set<JestMockCompat>()\n\nexport function isMockFunction(fn: any): fn is EnhancedSpy {\n  return typeof fn === 'function'\n  && '__isSpy' in fn\n  && fn.__isSpy\n}\n\nexport function spyOn<T, S extends Properties<Required<T>>>(\n  obj: T,\n  methodName: S,\n  accesType: 'get',\n): JestMockCompat<[T[S]], void>\nexport function spyOn<T, G extends Properties<Required<T>>>(\n  obj: T,\n  methodName: G,\n  accesType: 'set',\n): JestMockCompat<[], T[G]>\nexport function spyOn<T, M extends Classes<Required<T>>>(\n  object: T,\n  method: M\n): Required<T>[M] extends new (...args: infer A) => infer R\n  ? JestMockCompat<A, R>\n  : never\nexport function spyOn<T, M extends Methods<Required<T>>>(\n  obj: T,\n  methodName: M,\n  mock?: T[M]\n): Required<T>[M] extends (...args: infer A) => infer R ? JestMockCompat<A, R> : never\nexport function spyOn<T, K extends keyof T>(\n  obj: T,\n  method: K,\n  accessType?: 'get' | 'set',\n): JestMockCompat {\n  const dictionary = {\n    get: 'getter',\n    set: 'setter',\n  } as const\n  const objMethod = accessType ? { [dictionary[accessType]]: method } : method\n\n  const stub = tinyspy.spyOn(obj, objMethod as any)\n\n  return enhanceSpy(stub) as JestMockCompat\n}\n\nfunction enhanceSpy<TArgs extends any[], TReturns>(\n  spy: SpyImpl<TArgs, TReturns>,\n): JestMockCompat<TArgs, TReturns> {\n  const stub = spy as unknown as EnhancedSpy<TArgs, TReturns>\n\n  let implementation: ((...args: TArgs) => TReturns) | undefined\n\n  const instances: any[] = []\n\n  const mockContext = {\n    get calls() {\n      return stub.calls\n    },\n    get instances() {\n      return instances\n    },\n    // not supported\n    get invocationCallOrder() {\n      return []\n    },\n    get results() {\n      return stub.results.map(([callType, value]) => {\n        const type = callType === 'error' ? 'throw' : 'return'\n        return { type, value }\n      })\n    },\n  }\n\n  let onceImplementations: ((...args: TArgs) => TReturns)[] = []\n\n  let name: string = (stub as any).name\n\n  stub.getMockName = () => name || 'vi.fn()'\n  stub.mockName = (n) => {\n    name = n\n    return stub\n  }\n\n  stub.mockClear = () => {\n    stub.reset()\n    return stub\n  }\n\n  stub.mockReset = () => {\n    stub.reset()\n    implementation = () => undefined as unknown as TReturns\n    onceImplementations = []\n    return stub\n  }\n\n  stub.mockRestore = () => {\n    stub.mockReset()\n    implementation = undefined\n    return stub\n  }\n\n  stub.getMockImplementation = () => implementation\n  stub.mockImplementation = (fn: (...args: TArgs) => TReturns) => {\n    implementation = fn\n    return stub\n  }\n\n  stub.mockImplementationOnce = (fn: (...args: TArgs) => TReturns) => {\n    onceImplementations.push(fn)\n    return stub\n  }\n\n  stub.mockReturnThis = () =>\n    stub.mockImplementation(function(this: TReturns) {\n      return this\n    })\n\n  stub.mockReturnValue = (val: TReturns) => stub.mockImplementation(() => val)\n  stub.mockReturnValueOnce = (val: TReturns) => stub.mockImplementationOnce(() => val)\n\n  stub.mockResolvedValue = (val: Awaited<TReturns>) =>\n    stub.mockImplementation(() => Promise.resolve(val as TReturns))\n\n  stub.mockResolvedValueOnce = (val: Awaited<TReturns>) =>\n    stub.mockImplementationOnce(() => Promise.resolve(val as TReturns))\n\n  stub.mockRejectedValue = (val: unknown) =>\n    stub.mockImplementation(() => Promise.reject(val))\n\n  stub.mockRejectedValueOnce = (val: unknown) =>\n    stub.mockImplementationOnce(() => Promise.reject(val))\n\n  util.addProperty(stub, 'mock', () => mockContext)\n\n  stub.willCall(function(this: unknown, ...args) {\n    instances.push(this)\n    const impl = onceImplementations.shift() || implementation || stub.getOriginal() || (() => {})\n    return impl.apply(this, args)\n  })\n\n  spies.add(stub)\n\n  return stub as any\n}\n\nexport function fn<TArgs extends any[] = any[], R = any>(): JestMockCompatFn<TArgs, R>\nexport function fn<TArgs extends any[] = any[], R = any>(\n  implementation: (...args: TArgs) => R\n): JestMockCompatFn<TArgs, R>\nexport function fn<TArgs extends any[] = any[], R = any>(\n  implementation?: (...args: TArgs) => R,\n): JestMockCompatFn<TArgs, R> {\n  return enhanceSpy(tinyspy.spyOn({ fn: implementation || (() => {}) }, 'fn')) as unknown as JestMockCompatFn\n}\n"],"names":[],"mappings":"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"}
|
package/dist/node.d.ts
CHANGED
|
@@ -68,10 +68,24 @@ declare class VerboseReporter extends DefaultReporter {
|
|
|
68
68
|
constructor();
|
|
69
69
|
}
|
|
70
70
|
|
|
71
|
+
declare class TapReporter implements Reporter {
|
|
72
|
+
protected ctx: Vitest;
|
|
73
|
+
onInit(ctx: Vitest): void;
|
|
74
|
+
protected logTasks(tasks: Task[], currentIdent: string): void;
|
|
75
|
+
onFinished(files?: File[]): Promise<void>;
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
declare class TapFlatReporter extends TapReporter {
|
|
79
|
+
onInit(ctx: Vitest): void;
|
|
80
|
+
onFinished(files?: File[]): Promise<void>;
|
|
81
|
+
}
|
|
82
|
+
|
|
71
83
|
declare const ReportersMap: {
|
|
72
84
|
default: typeof DefaultReporter;
|
|
73
85
|
verbose: typeof VerboseReporter;
|
|
74
86
|
dot: typeof DotReporter;
|
|
87
|
+
tap: typeof TapReporter;
|
|
88
|
+
'tap-flat': typeof TapFlatReporter;
|
|
75
89
|
};
|
|
76
90
|
declare type BuiltinReporters = keyof typeof ReportersMap;
|
|
77
91
|
|
|
@@ -125,6 +139,86 @@ interface ResolvedC8Options extends Required<C8Options> {
|
|
|
125
139
|
tempDirectory: string;
|
|
126
140
|
}
|
|
127
141
|
|
|
142
|
+
interface JSDOMOptions {
|
|
143
|
+
/**
|
|
144
|
+
* The html content for the test.
|
|
145
|
+
*
|
|
146
|
+
* @default '<!DOCTYPE html>'
|
|
147
|
+
*/
|
|
148
|
+
html?: string | Buffer | ArrayBufferLike;
|
|
149
|
+
/**
|
|
150
|
+
* referrer just affects the value read from document.referrer.
|
|
151
|
+
* It defaults to no referrer (which reflects as the empty string).
|
|
152
|
+
*/
|
|
153
|
+
referrer?: string;
|
|
154
|
+
/**
|
|
155
|
+
* userAgent affects the value read from navigator.userAgent, as well as the User-Agent header sent while fetching subresources.
|
|
156
|
+
*
|
|
157
|
+
* @default `Mozilla/5.0 (${process.platform}) AppleWebKit/537.36 (KHTML, like Gecko) jsdom/${jsdomVersion}`
|
|
158
|
+
*/
|
|
159
|
+
userAgent?: string;
|
|
160
|
+
/**
|
|
161
|
+
* url sets the value returned by window.location, document.URL, and document.documentURI,
|
|
162
|
+
* and affects things like resolution of relative URLs within the document
|
|
163
|
+
* and the same-origin restrictions and referrer used while fetching subresources.
|
|
164
|
+
*
|
|
165
|
+
* @default 'http://localhost:3000'.
|
|
166
|
+
*/
|
|
167
|
+
url?: string;
|
|
168
|
+
/**
|
|
169
|
+
* contentType affects the value read from document.contentType, and how the document is parsed: as HTML or as XML.
|
|
170
|
+
* Values that are not "text/html" or an XML mime type will throw.
|
|
171
|
+
*
|
|
172
|
+
* @default 'text/html'.
|
|
173
|
+
*/
|
|
174
|
+
contentType?: string;
|
|
175
|
+
/**
|
|
176
|
+
* The maximum size in code units for the separate storage areas used by localStorage and sessionStorage.
|
|
177
|
+
* Attempts to store data larger than this limit will cause a DOMException to be thrown. By default, it is set
|
|
178
|
+
* to 5,000,000 code units per origin, as inspired by the HTML specification.
|
|
179
|
+
*
|
|
180
|
+
* @default 5_000_000
|
|
181
|
+
*/
|
|
182
|
+
storageQuota?: number;
|
|
183
|
+
/**
|
|
184
|
+
* Enable console?
|
|
185
|
+
*
|
|
186
|
+
* @default false
|
|
187
|
+
*/
|
|
188
|
+
console?: boolean;
|
|
189
|
+
/**
|
|
190
|
+
* jsdom does not have the capability to render visual content, and will act like a headless browser by default.
|
|
191
|
+
* It provides hints to web pages through APIs such as document.hidden that their content is not visible.
|
|
192
|
+
*
|
|
193
|
+
* When the `pretendToBeVisual` option is set to `true`, jsdom will pretend that it is rendering and displaying
|
|
194
|
+
* content.
|
|
195
|
+
*
|
|
196
|
+
* @default true
|
|
197
|
+
*/
|
|
198
|
+
pretendToBeVisual?: boolean;
|
|
199
|
+
/**
|
|
200
|
+
* `includeNodeLocations` preserves the location info produced by the HTML parser,
|
|
201
|
+
* allowing you to retrieve it with the nodeLocation() method (described below).
|
|
202
|
+
*
|
|
203
|
+
* It defaults to false to give the best performance,
|
|
204
|
+
* and cannot be used with an XML content type since our XML parser does not support location info.
|
|
205
|
+
*
|
|
206
|
+
* @default false
|
|
207
|
+
*/
|
|
208
|
+
includeNodeLocations?: boolean | undefined;
|
|
209
|
+
/**
|
|
210
|
+
* @default 'dangerously'
|
|
211
|
+
*/
|
|
212
|
+
runScripts?: 'dangerously' | 'outside-only';
|
|
213
|
+
/**
|
|
214
|
+
* Enable CookieJar
|
|
215
|
+
*
|
|
216
|
+
* @default false
|
|
217
|
+
*/
|
|
218
|
+
cookieJar?: boolean;
|
|
219
|
+
resources?: 'usable' | any;
|
|
220
|
+
}
|
|
221
|
+
|
|
128
222
|
declare type Awaitable<T> = T | PromiseLike<T>;
|
|
129
223
|
declare type Arrayable<T> = T | Array<T>;
|
|
130
224
|
declare type ArgumentsType<T> = T extends (...args: infer U) => any ? U : never;
|
|
@@ -326,6 +420,13 @@ interface SnapshotSummary {
|
|
|
326
420
|
|
|
327
421
|
declare type BuiltinEnvironment = 'node' | 'jsdom' | 'happy-dom';
|
|
328
422
|
declare type ApiConfig = Pick<CommonServerOptions, 'port' | 'strictPort' | 'host'>;
|
|
423
|
+
|
|
424
|
+
interface EnvironmentOptions {
|
|
425
|
+
/**
|
|
426
|
+
* jsdom options.
|
|
427
|
+
*/
|
|
428
|
+
jsdom?: JSDOMOptions;
|
|
429
|
+
}
|
|
329
430
|
interface InlineConfig {
|
|
330
431
|
/**
|
|
331
432
|
* Include globs for test files
|
|
@@ -387,7 +488,11 @@ interface InlineConfig {
|
|
|
387
488
|
*/
|
|
388
489
|
environment?: BuiltinEnvironment;
|
|
389
490
|
/**
|
|
390
|
-
*
|
|
491
|
+
* Environment options.
|
|
492
|
+
*/
|
|
493
|
+
environmentOptions?: EnvironmentOptions;
|
|
494
|
+
/**
|
|
495
|
+
* Update snapshot
|
|
391
496
|
*
|
|
392
497
|
* @default false
|
|
393
498
|
*/
|
|
@@ -400,6 +505,8 @@ interface InlineConfig {
|
|
|
400
505
|
watch?: boolean;
|
|
401
506
|
/**
|
|
402
507
|
* Project root
|
|
508
|
+
*
|
|
509
|
+
* @default process.cwd()
|
|
403
510
|
*/
|
|
404
511
|
root?: string;
|
|
405
512
|
/**
|
|
@@ -493,7 +600,13 @@ interface InlineConfig {
|
|
|
493
600
|
* Open Vitest UI
|
|
494
601
|
* @internal WIP
|
|
495
602
|
*/
|
|
496
|
-
|
|
603
|
+
ui?: boolean;
|
|
604
|
+
/**
|
|
605
|
+
* Base url for the UI
|
|
606
|
+
*
|
|
607
|
+
* @default '/__vitest__/'
|
|
608
|
+
*/
|
|
609
|
+
uiBase?: string;
|
|
497
610
|
}
|
|
498
611
|
interface UserConfig extends InlineConfig {
|
|
499
612
|
/**
|
package/dist/node.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
export { c as createVitest } from './index-
|
|
1
|
+
export { c as createVitest } from './index-0b823579.js';
|
|
2
2
|
import 'fs';
|
|
3
3
|
import './index-64aafe4b.js';
|
|
4
4
|
import 'url';
|
|
@@ -14,7 +14,7 @@ import 'events';
|
|
|
14
14
|
import './constants-d24b670d.js';
|
|
15
15
|
import './magic-string.es-94000aea.js';
|
|
16
16
|
import 'perf_hooks';
|
|
17
|
-
import './diff-
|
|
17
|
+
import './diff-04ac7bc9.js';
|
|
18
18
|
import './index-648e7ab2.js';
|
|
19
19
|
import './_commonjsHelpers-c9e3b764.js';
|
|
20
20
|
import 'assert';
|