vitest 0.0.131 → 0.0.135
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/{constants-5b9c0d41.js → constants-d24b670d.js} +2 -2
- package/dist/{diff-aa2146ff.js → diff-04ac7bc9.js} +3 -3
- package/dist/entry.js +169 -44
- package/dist/{externalize-2f63779d.js → externalize-b979f524.js} +2 -2
- package/dist/{global-4d67a585.js → global-3d90eb55.js} +5 -5
- package/dist/{index-6f5d03b2.js → index-6397bdab.js} +4 -2
- package/dist/index-64aafe4b.js +396 -0
- package/dist/index-9e44ed60.js +8544 -0
- package/dist/index.d.ts +152 -36
- package/dist/index.js +3 -3
- package/dist/jest-mock-30625866.js +1 -1
- package/dist/node.d.ts +103 -1
- package/dist/node.js +4 -4
- package/dist/{setup-b212370d.js → setup-a9c8349a.js} +46 -22
- package/dist/vi-2509fe43.js +3462 -0
- package/dist/worker.js +34 -26
- package/package.json +9 -9
- package/dist/index-98403570.js +0 -8480
- package/dist/index-9fdde2e8.js +0 -367
- package/dist/vi-8ac1afa2.js +0 -3461
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';
|
|
@@ -187,6 +187,8 @@ declare type MatcherState = {
|
|
|
187
187
|
declare type SyncExpectationResult = {
|
|
188
188
|
pass: boolean;
|
|
189
189
|
message: () => string;
|
|
190
|
+
actual?: any;
|
|
191
|
+
expected?: any;
|
|
190
192
|
};
|
|
191
193
|
declare type AsyncExpectationResult = Promise<SyncExpectationResult>;
|
|
192
194
|
declare type ExpectationResult = SyncExpectationResult | AsyncExpectationResult;
|
|
@@ -383,10 +385,18 @@ declare class VerboseReporter extends DefaultReporter {
|
|
|
383
385
|
constructor();
|
|
384
386
|
}
|
|
385
387
|
|
|
388
|
+
declare class TapReporter implements Reporter {
|
|
389
|
+
private ctx;
|
|
390
|
+
onInit(ctx: Vitest): void;
|
|
391
|
+
logTasks(tasks: Task[], currentIdent: string): void;
|
|
392
|
+
onFinished(files?: File[]): Promise<void>;
|
|
393
|
+
}
|
|
394
|
+
|
|
386
395
|
declare const ReportersMap: {
|
|
387
396
|
default: typeof DefaultReporter;
|
|
388
397
|
verbose: typeof VerboseReporter;
|
|
389
398
|
dot: typeof DotReporter;
|
|
399
|
+
tap: typeof TapReporter;
|
|
390
400
|
};
|
|
391
401
|
declare type BuiltinReporters = keyof typeof ReportersMap;
|
|
392
402
|
|
|
@@ -440,6 +450,86 @@ interface ResolvedC8Options extends Required<C8Options> {
|
|
|
440
450
|
tempDirectory: string;
|
|
441
451
|
}
|
|
442
452
|
|
|
453
|
+
interface JSDOMOptions {
|
|
454
|
+
/**
|
|
455
|
+
* The html content for the test.
|
|
456
|
+
*
|
|
457
|
+
* @default '<!DOCTYPE html>'
|
|
458
|
+
*/
|
|
459
|
+
html?: string | Buffer | ArrayBufferLike;
|
|
460
|
+
/**
|
|
461
|
+
* referrer just affects the value read from document.referrer.
|
|
462
|
+
* It defaults to no referrer (which reflects as the empty string).
|
|
463
|
+
*/
|
|
464
|
+
referrer?: string;
|
|
465
|
+
/**
|
|
466
|
+
* userAgent affects the value read from navigator.userAgent, as well as the User-Agent header sent while fetching subresources.
|
|
467
|
+
*
|
|
468
|
+
* @default `Mozilla/5.0 (${process.platform}) AppleWebKit/537.36 (KHTML, like Gecko) jsdom/${jsdomVersion}`
|
|
469
|
+
*/
|
|
470
|
+
userAgent?: string;
|
|
471
|
+
/**
|
|
472
|
+
* url sets the value returned by window.location, document.URL, and document.documentURI,
|
|
473
|
+
* and affects things like resolution of relative URLs within the document
|
|
474
|
+
* and the same-origin restrictions and referrer used while fetching subresources.
|
|
475
|
+
*
|
|
476
|
+
* @default 'http://localhost:3000'.
|
|
477
|
+
*/
|
|
478
|
+
url?: string;
|
|
479
|
+
/**
|
|
480
|
+
* contentType affects the value read from document.contentType, and how the document is parsed: as HTML or as XML.
|
|
481
|
+
* Values that are not "text/html" or an XML mime type will throw.
|
|
482
|
+
*
|
|
483
|
+
* @default 'text/html'.
|
|
484
|
+
*/
|
|
485
|
+
contentType?: string;
|
|
486
|
+
/**
|
|
487
|
+
* The maximum size in code units for the separate storage areas used by localStorage and sessionStorage.
|
|
488
|
+
* Attempts to store data larger than this limit will cause a DOMException to be thrown. By default, it is set
|
|
489
|
+
* to 5,000,000 code units per origin, as inspired by the HTML specification.
|
|
490
|
+
*
|
|
491
|
+
* @default 5_000_000
|
|
492
|
+
*/
|
|
493
|
+
storageQuota?: number;
|
|
494
|
+
/**
|
|
495
|
+
* Enable console?
|
|
496
|
+
*
|
|
497
|
+
* @default false
|
|
498
|
+
*/
|
|
499
|
+
console?: boolean;
|
|
500
|
+
/**
|
|
501
|
+
* jsdom does not have the capability to render visual content, and will act like a headless browser by default.
|
|
502
|
+
* It provides hints to web pages through APIs such as document.hidden that their content is not visible.
|
|
503
|
+
*
|
|
504
|
+
* When the `pretendToBeVisual` option is set to `true`, jsdom will pretend that it is rendering and displaying
|
|
505
|
+
* content.
|
|
506
|
+
*
|
|
507
|
+
* @default true
|
|
508
|
+
*/
|
|
509
|
+
pretendToBeVisual?: boolean;
|
|
510
|
+
/**
|
|
511
|
+
* `includeNodeLocations` preserves the location info produced by the HTML parser,
|
|
512
|
+
* allowing you to retrieve it with the nodeLocation() method (described below).
|
|
513
|
+
*
|
|
514
|
+
* It defaults to false to give the best performance,
|
|
515
|
+
* and cannot be used with an XML content type since our XML parser does not support location info.
|
|
516
|
+
*
|
|
517
|
+
* @default false
|
|
518
|
+
*/
|
|
519
|
+
includeNodeLocations?: boolean | undefined;
|
|
520
|
+
/**
|
|
521
|
+
* @default 'dangerously'
|
|
522
|
+
*/
|
|
523
|
+
runScripts?: 'dangerously' | 'outside-only';
|
|
524
|
+
/**
|
|
525
|
+
* Enable CookieJar
|
|
526
|
+
*
|
|
527
|
+
* @default false
|
|
528
|
+
*/
|
|
529
|
+
cookieJar?: boolean;
|
|
530
|
+
resources?: 'usable' | any;
|
|
531
|
+
}
|
|
532
|
+
|
|
443
533
|
declare type Awaitable<T> = T | PromiseLike<T>;
|
|
444
534
|
declare type Nullable<T> = T | null | undefined;
|
|
445
535
|
declare type Arrayable<T> = T | Array<T>;
|
|
@@ -454,7 +544,7 @@ interface EnvironmentReturn {
|
|
|
454
544
|
}
|
|
455
545
|
interface Environment {
|
|
456
546
|
name: string;
|
|
457
|
-
setup(global: any): Awaitable<EnvironmentReturn>;
|
|
547
|
+
setup(global: any, options: Record<string, any>): Awaitable<EnvironmentReturn>;
|
|
458
548
|
}
|
|
459
549
|
interface UserConsoleLog {
|
|
460
550
|
content: string;
|
|
@@ -483,6 +573,11 @@ interface ErrorWithDiff extends Error {
|
|
|
483
573
|
expected?: any;
|
|
484
574
|
operator?: string;
|
|
485
575
|
}
|
|
576
|
+
interface ModuleGraphData {
|
|
577
|
+
graph: Record<string, string[]>;
|
|
578
|
+
externalized: string[];
|
|
579
|
+
inlined: string[];
|
|
580
|
+
}
|
|
486
581
|
|
|
487
582
|
declare type ChainableFunction<T extends string, Args extends any[], R = any> = {
|
|
488
583
|
(...args: Args): R;
|
|
@@ -611,6 +706,13 @@ interface SnapshotSummary {
|
|
|
611
706
|
|
|
612
707
|
declare type BuiltinEnvironment = 'node' | 'jsdom' | 'happy-dom';
|
|
613
708
|
declare type ApiConfig = Pick<CommonServerOptions, 'port' | 'strictPort' | 'host'>;
|
|
709
|
+
|
|
710
|
+
interface EnvironmentOptions {
|
|
711
|
+
/**
|
|
712
|
+
* jsdom options.
|
|
713
|
+
*/
|
|
714
|
+
jsdom?: JSDOMOptions;
|
|
715
|
+
}
|
|
614
716
|
interface InlineConfig {
|
|
615
717
|
/**
|
|
616
718
|
* Include globs for test files
|
|
@@ -672,7 +774,11 @@ interface InlineConfig {
|
|
|
672
774
|
*/
|
|
673
775
|
environment?: BuiltinEnvironment;
|
|
674
776
|
/**
|
|
675
|
-
*
|
|
777
|
+
* Environment options.
|
|
778
|
+
*/
|
|
779
|
+
environmentOptions?: EnvironmentOptions;
|
|
780
|
+
/**
|
|
781
|
+
* Update snapshot
|
|
676
782
|
*
|
|
677
783
|
* @default false
|
|
678
784
|
*/
|
|
@@ -685,6 +791,8 @@ interface InlineConfig {
|
|
|
685
791
|
watch?: boolean;
|
|
686
792
|
/**
|
|
687
793
|
* Project root
|
|
794
|
+
*
|
|
795
|
+
* @default process.cwd()
|
|
688
796
|
*/
|
|
689
797
|
root?: string;
|
|
690
798
|
/**
|
|
@@ -809,6 +917,7 @@ interface UserConfig extends InlineConfig {
|
|
|
809
917
|
related?: string[] | string;
|
|
810
918
|
}
|
|
811
919
|
interface ResolvedConfig extends Omit<Required<UserConfig>, 'config' | 'filters' | 'coverage' | 'testNamePattern' | 'related' | 'api'> {
|
|
920
|
+
base?: string;
|
|
812
921
|
config?: string;
|
|
813
922
|
filters?: string[];
|
|
814
923
|
testNamePattern?: RegExp;
|
|
@@ -863,12 +972,22 @@ interface MockResultThrow {
|
|
|
863
972
|
value: any;
|
|
864
973
|
}
|
|
865
974
|
declare type MockResult<T> = MockResultReturn<T> | MockResultThrow | MockResultIncomplete;
|
|
866
|
-
interface JestMockCompatContext<
|
|
867
|
-
calls:
|
|
868
|
-
instances:
|
|
975
|
+
interface JestMockCompatContext<TArgs, TReturns> {
|
|
976
|
+
calls: TArgs[];
|
|
977
|
+
instances: TReturns[];
|
|
869
978
|
invocationCallOrder: number[];
|
|
870
|
-
results: MockResult<
|
|
979
|
+
results: MockResult<TReturns>[];
|
|
871
980
|
}
|
|
981
|
+
declare type Procedure = (...args: any[]) => any;
|
|
982
|
+
declare type Methods<T> = {
|
|
983
|
+
[K in keyof T]: T[K] extends Procedure ? K : never;
|
|
984
|
+
}[keyof T] & string;
|
|
985
|
+
declare type Properties<T> = {
|
|
986
|
+
[K in keyof T]: T[K] extends Procedure ? never : K;
|
|
987
|
+
}[keyof T] & string;
|
|
988
|
+
declare type Classes<T> = {
|
|
989
|
+
[K in keyof T]: T[K] extends new (...args: any[]) => any ? K : never;
|
|
990
|
+
}[keyof T] & string;
|
|
872
991
|
interface JestMockCompat<TArgs extends any[] = any[], TReturns = any> {
|
|
873
992
|
getMockName(): string;
|
|
874
993
|
mockName(n: string): this;
|
|
@@ -890,41 +1009,34 @@ interface JestMockCompat<TArgs extends any[] = any[], TReturns = any> {
|
|
|
890
1009
|
interface JestMockCompatFn<TArgs extends any[] = any, TReturns = any> extends JestMockCompat<TArgs, TReturns> {
|
|
891
1010
|
(...args: TArgs): TReturns;
|
|
892
1011
|
}
|
|
893
|
-
declare type
|
|
894
|
-
declare type
|
|
895
|
-
[K in keyof T]: T[K] extends MockableFunction ? K : never;
|
|
896
|
-
}[keyof T];
|
|
897
|
-
declare type PropertyKeysOf<T> = {
|
|
898
|
-
[K in keyof T]: T[K] extends MockableFunction ? never : K;
|
|
899
|
-
}[keyof T];
|
|
900
|
-
declare type ArgumentsOf<T> = T extends (...args: infer A) => any ? A : never;
|
|
901
|
-
declare type ConstructorArgumentsOf<T> = T extends new (...args: infer A) => any ? A : never;
|
|
902
|
-
declare type MaybeMockedConstructor<T> = T extends new (...args: Array<any>) => infer R ? JestMockCompatFn<ConstructorArgumentsOf<T>, R> : T;
|
|
903
|
-
declare type MockedFunction<T extends MockableFunction> = MockWithArgs<T> & {
|
|
1012
|
+
declare type MaybeMockedConstructor<T> = T extends new (...args: Array<any>) => infer R ? JestMockCompatFn<ConstructorParameters<T>, R> : T;
|
|
1013
|
+
declare type MockedFunction<T extends Procedure> = MockWithArgs<T> & {
|
|
904
1014
|
[K in keyof T]: T[K];
|
|
905
1015
|
};
|
|
906
|
-
declare type MockedFunctionDeep<T extends
|
|
1016
|
+
declare type MockedFunctionDeep<T extends Procedure> = MockWithArgs<T> & MockedObjectDeep<T>;
|
|
907
1017
|
declare type MockedObject<T> = MaybeMockedConstructor<T> & {
|
|
908
|
-
[K in
|
|
1018
|
+
[K in Methods<T>]: T[K] extends Procedure ? MockedFunction<T[K]> : T[K];
|
|
909
1019
|
} & {
|
|
910
|
-
[K in
|
|
1020
|
+
[K in Properties<T>]: T[K];
|
|
911
1021
|
};
|
|
912
1022
|
declare type MockedObjectDeep<T> = MaybeMockedConstructor<T> & {
|
|
913
|
-
[K in
|
|
1023
|
+
[K in Methods<T>]: T[K] extends Procedure ? MockedFunctionDeep<T[K]> : T[K];
|
|
914
1024
|
} & {
|
|
915
|
-
[K in
|
|
1025
|
+
[K in Properties<T>]: MaybeMockedDeep<T[K]>;
|
|
916
1026
|
};
|
|
917
|
-
declare type MaybeMockedDeep<T> = T extends
|
|
918
|
-
declare type MaybeMocked<T> = T extends
|
|
1027
|
+
declare type MaybeMockedDeep<T> = T extends Procedure ? MockedFunctionDeep<T> : T extends object ? MockedObjectDeep<T> : T;
|
|
1028
|
+
declare type MaybeMocked<T> = T extends Procedure ? MockedFunction<T> : T extends object ? MockedObject<T> : T;
|
|
919
1029
|
declare type EnhancedSpy<TArgs extends any[] = any[], TReturns = any> = JestMockCompat<TArgs, TReturns> & SpyImpl<TArgs, TReturns>;
|
|
920
|
-
interface MockWithArgs<T extends
|
|
921
|
-
new (...args:
|
|
922
|
-
(...args:
|
|
1030
|
+
interface MockWithArgs<T extends Procedure> extends JestMockCompatFn<Parameters<T>, ReturnType<T>> {
|
|
1031
|
+
new (...args: T extends new (...args: any) => any ? ConstructorParameters<T> : never): T;
|
|
1032
|
+
(...args: Parameters<T>): ReturnType<T>;
|
|
923
1033
|
}
|
|
924
1034
|
declare const spies: Set<JestMockCompat<any[], any>>;
|
|
925
1035
|
declare function isMockFunction(fn: any): fn is EnhancedSpy;
|
|
926
|
-
declare function spyOn<T,
|
|
927
|
-
declare
|
|
1036
|
+
declare function spyOn<T, S extends Properties<Required<T>>>(obj: T, methodName: S, accesType: 'get'): JestMockCompat<[T[S]], void>;
|
|
1037
|
+
declare function spyOn<T, G extends Properties<Required<T>>>(obj: T, methodName: G, accesType: 'set'): JestMockCompat<[], T[G]>;
|
|
1038
|
+
declare function spyOn<T, M extends Classes<Required<T>>>(object: T, method: M): Required<T>[M] extends new (...args: infer A) => infer R ? JestMockCompat<A, R> : never;
|
|
1039
|
+
declare function spyOn<T, M extends Methods<Required<T>>>(obj: T, methodName: M, mock?: T[M]): Required<T>[M] extends (...args: infer A) => infer R ? JestMockCompat<A, R> : never;
|
|
928
1040
|
declare function fn<TArgs extends any[] = any[], R = any>(): JestMockCompatFn<TArgs, R>;
|
|
929
1041
|
declare function fn<TArgs extends any[] = any[], R = any>(implementation: (...args: TArgs) => R): JestMockCompatFn<TArgs, R>;
|
|
930
1042
|
|
|
@@ -1008,16 +1120,16 @@ declare class VitestUtils {
|
|
|
1008
1120
|
declare const vitest: VitestUtils;
|
|
1009
1121
|
declare const vi: VitestUtils;
|
|
1010
1122
|
|
|
1123
|
+
interface TransformResultWithSource extends TransformResult {
|
|
1124
|
+
source?: string;
|
|
1125
|
+
}
|
|
1011
1126
|
interface WebSocketHandlers {
|
|
1012
1127
|
getFiles(): File[];
|
|
1013
1128
|
getConfig(): ResolvedConfig;
|
|
1129
|
+
getModuleGraph(id: string): Promise<ModuleGraphData>;
|
|
1130
|
+
getTransformResult(id: string): Promise<TransformResultWithSource | undefined>;
|
|
1014
1131
|
readFile(id: string): Promise<string>;
|
|
1015
1132
|
writeFile(id: string, content: string): Promise<void>;
|
|
1016
|
-
getModuleGraph(id: string): Promise<{
|
|
1017
|
-
graph: Record<string, string[]>;
|
|
1018
|
-
externalized: string[];
|
|
1019
|
-
inlined: string[];
|
|
1020
|
-
}>;
|
|
1021
1133
|
rerun(files: string[]): Promise<void>;
|
|
1022
1134
|
}
|
|
1023
1135
|
interface WebSocketEvents extends Pick<Reporter, 'onCollected' | 'onTaskUpdate'> {
|
|
@@ -1048,10 +1160,14 @@ declare global {
|
|
|
1048
1160
|
anything(): Anything;
|
|
1049
1161
|
any(constructor: unknown): Any;
|
|
1050
1162
|
addSnapshotSerializer(plugin: Plugin): void;
|
|
1163
|
+
getState(): MatcherState;
|
|
1164
|
+
setState(state: Partial<MatcherState>): void;
|
|
1051
1165
|
not: AsymmetricMatchersContaining;
|
|
1052
1166
|
}
|
|
1053
1167
|
interface JestAssertions {
|
|
1168
|
+
toMatchSnapshot(snapshot: object, message?: string): void;
|
|
1054
1169
|
toMatchSnapshot(message?: string): void;
|
|
1170
|
+
toMatchInlineSnapshot(properties: object, snapshot?: string, message?: string): void;
|
|
1055
1171
|
toMatchInlineSnapshot(snapshot?: string, message?: string): void;
|
|
1056
1172
|
toThrowErrorMatchingSnapshot(message?: string): void;
|
|
1057
1173
|
toThrowErrorMatchingInlineSnapshot(snapshot?: string, message?: string): void;
|
|
@@ -1112,4 +1228,4 @@ declare global {
|
|
|
1112
1228
|
}
|
|
1113
1229
|
}
|
|
1114
1230
|
|
|
1115
|
-
export { ApiConfig,
|
|
1231
|
+
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,8 +1,8 @@
|
|
|
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
|
-
import './index-
|
|
5
|
+
import './index-64aafe4b.js';
|
|
6
6
|
import 'url';
|
|
7
7
|
import 'tty';
|
|
8
8
|
import 'local-pkg';
|
|
@@ -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\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 MockableFunction = (...args: Array<any>) => any\nexport type MethodKeysOf<T> = {\n  [K in keyof T]: T[K] extends MockableFunction ? K : never;\n}[keyof T]\nexport type PropertyKeysOf<T> = {\n  [K in keyof T]: T[K] extends MockableFunction ? never : K;\n}[keyof T]\n\nexport type ArgumentsOf<T> = T extends (...args: infer A) => any ? A : never\n\nexport type ConstructorArgumentsOf<T> = T extends new (...args: infer A) => any\n  ? A\n  : never\nexport type MaybeMockedConstructor<T> = T extends new (\n  ...args: Array<any>\n) => infer R\n  ? JestMockCompatFn<ConstructorArgumentsOf<T>, R>\n  : T\nexport type MockedFunction<T extends MockableFunction> = MockWithArgs<T> & {\n  [K in keyof T]: T[K];\n}\nexport type MockedFunctionDeep<T extends MockableFunction> = MockWithArgs<T> &\nMockedObjectDeep<T>\nexport type MockedObject<T> = MaybeMockedConstructor<T> & {\n  [K in MethodKeysOf<T>]: T[K] extends MockableFunction\n    ? MockedFunction<T[K]>\n    : T[K];\n} & {[K in PropertyKeysOf<T>]: T[K]}\nexport type MockedObjectDeep<T> = MaybeMockedConstructor<T> & {\n  [K in MethodKeysOf<T>]: T[K] extends MockableFunction\n    ? MockedFunctionDeep<T[K]>\n    : T[K];\n} & {[K in PropertyKeysOf<T>]: MaybeMockedDeep<T[K]>}\n\nexport type MaybeMockedDeep<T> = T extends MockableFunction\n  ? MockedFunctionDeep<T>\n  : T extends object\n    ? MockedObjectDeep<T>\n    : T\n\nexport type MaybeMocked<T> = T extends MockableFunction\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 MockableFunction>\n  extends JestMockCompatFn<ArgumentsOf<T>, ReturnType<T>> {\n  new (...args: ConstructorArgumentsOf<T>): T\n  (...args: ArgumentsOf<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, K extends keyof T>(\n  obj: T,\n  method: K,\n  accessType?: 'get' | 'set',\n): T[K] extends (...args: infer TArgs) => infer TReturnValue\n    ? JestMockCompat<TArgs, TReturnValue> : 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 any\n}\n\ntype Awaited<T> = T extends Promise<infer R> ? R : never\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,18 @@ declare class VerboseReporter extends DefaultReporter {
|
|
|
68
68
|
constructor();
|
|
69
69
|
}
|
|
70
70
|
|
|
71
|
+
declare class TapReporter implements Reporter {
|
|
72
|
+
private ctx;
|
|
73
|
+
onInit(ctx: Vitest): void;
|
|
74
|
+
logTasks(tasks: Task[], currentIdent: string): void;
|
|
75
|
+
onFinished(files?: File[]): Promise<void>;
|
|
76
|
+
}
|
|
77
|
+
|
|
71
78
|
declare const ReportersMap: {
|
|
72
79
|
default: typeof DefaultReporter;
|
|
73
80
|
verbose: typeof VerboseReporter;
|
|
74
81
|
dot: typeof DotReporter;
|
|
82
|
+
tap: typeof TapReporter;
|
|
75
83
|
};
|
|
76
84
|
declare type BuiltinReporters = keyof typeof ReportersMap;
|
|
77
85
|
|
|
@@ -125,6 +133,86 @@ interface ResolvedC8Options extends Required<C8Options> {
|
|
|
125
133
|
tempDirectory: string;
|
|
126
134
|
}
|
|
127
135
|
|
|
136
|
+
interface JSDOMOptions {
|
|
137
|
+
/**
|
|
138
|
+
* The html content for the test.
|
|
139
|
+
*
|
|
140
|
+
* @default '<!DOCTYPE html>'
|
|
141
|
+
*/
|
|
142
|
+
html?: string | Buffer | ArrayBufferLike;
|
|
143
|
+
/**
|
|
144
|
+
* referrer just affects the value read from document.referrer.
|
|
145
|
+
* It defaults to no referrer (which reflects as the empty string).
|
|
146
|
+
*/
|
|
147
|
+
referrer?: string;
|
|
148
|
+
/**
|
|
149
|
+
* userAgent affects the value read from navigator.userAgent, as well as the User-Agent header sent while fetching subresources.
|
|
150
|
+
*
|
|
151
|
+
* @default `Mozilla/5.0 (${process.platform}) AppleWebKit/537.36 (KHTML, like Gecko) jsdom/${jsdomVersion}`
|
|
152
|
+
*/
|
|
153
|
+
userAgent?: string;
|
|
154
|
+
/**
|
|
155
|
+
* url sets the value returned by window.location, document.URL, and document.documentURI,
|
|
156
|
+
* and affects things like resolution of relative URLs within the document
|
|
157
|
+
* and the same-origin restrictions and referrer used while fetching subresources.
|
|
158
|
+
*
|
|
159
|
+
* @default 'http://localhost:3000'.
|
|
160
|
+
*/
|
|
161
|
+
url?: string;
|
|
162
|
+
/**
|
|
163
|
+
* contentType affects the value read from document.contentType, and how the document is parsed: as HTML or as XML.
|
|
164
|
+
* Values that are not "text/html" or an XML mime type will throw.
|
|
165
|
+
*
|
|
166
|
+
* @default 'text/html'.
|
|
167
|
+
*/
|
|
168
|
+
contentType?: string;
|
|
169
|
+
/**
|
|
170
|
+
* The maximum size in code units for the separate storage areas used by localStorage and sessionStorage.
|
|
171
|
+
* Attempts to store data larger than this limit will cause a DOMException to be thrown. By default, it is set
|
|
172
|
+
* to 5,000,000 code units per origin, as inspired by the HTML specification.
|
|
173
|
+
*
|
|
174
|
+
* @default 5_000_000
|
|
175
|
+
*/
|
|
176
|
+
storageQuota?: number;
|
|
177
|
+
/**
|
|
178
|
+
* Enable console?
|
|
179
|
+
*
|
|
180
|
+
* @default false
|
|
181
|
+
*/
|
|
182
|
+
console?: boolean;
|
|
183
|
+
/**
|
|
184
|
+
* jsdom does not have the capability to render visual content, and will act like a headless browser by default.
|
|
185
|
+
* It provides hints to web pages through APIs such as document.hidden that their content is not visible.
|
|
186
|
+
*
|
|
187
|
+
* When the `pretendToBeVisual` option is set to `true`, jsdom will pretend that it is rendering and displaying
|
|
188
|
+
* content.
|
|
189
|
+
*
|
|
190
|
+
* @default true
|
|
191
|
+
*/
|
|
192
|
+
pretendToBeVisual?: boolean;
|
|
193
|
+
/**
|
|
194
|
+
* `includeNodeLocations` preserves the location info produced by the HTML parser,
|
|
195
|
+
* allowing you to retrieve it with the nodeLocation() method (described below).
|
|
196
|
+
*
|
|
197
|
+
* It defaults to false to give the best performance,
|
|
198
|
+
* and cannot be used with an XML content type since our XML parser does not support location info.
|
|
199
|
+
*
|
|
200
|
+
* @default false
|
|
201
|
+
*/
|
|
202
|
+
includeNodeLocations?: boolean | undefined;
|
|
203
|
+
/**
|
|
204
|
+
* @default 'dangerously'
|
|
205
|
+
*/
|
|
206
|
+
runScripts?: 'dangerously' | 'outside-only';
|
|
207
|
+
/**
|
|
208
|
+
* Enable CookieJar
|
|
209
|
+
*
|
|
210
|
+
* @default false
|
|
211
|
+
*/
|
|
212
|
+
cookieJar?: boolean;
|
|
213
|
+
resources?: 'usable' | any;
|
|
214
|
+
}
|
|
215
|
+
|
|
128
216
|
declare type Awaitable<T> = T | PromiseLike<T>;
|
|
129
217
|
declare type Arrayable<T> = T | Array<T>;
|
|
130
218
|
declare type ArgumentsType<T> = T extends (...args: infer U) => any ? U : never;
|
|
@@ -326,6 +414,13 @@ interface SnapshotSummary {
|
|
|
326
414
|
|
|
327
415
|
declare type BuiltinEnvironment = 'node' | 'jsdom' | 'happy-dom';
|
|
328
416
|
declare type ApiConfig = Pick<CommonServerOptions, 'port' | 'strictPort' | 'host'>;
|
|
417
|
+
|
|
418
|
+
interface EnvironmentOptions {
|
|
419
|
+
/**
|
|
420
|
+
* jsdom options.
|
|
421
|
+
*/
|
|
422
|
+
jsdom?: JSDOMOptions;
|
|
423
|
+
}
|
|
329
424
|
interface InlineConfig {
|
|
330
425
|
/**
|
|
331
426
|
* Include globs for test files
|
|
@@ -387,7 +482,11 @@ interface InlineConfig {
|
|
|
387
482
|
*/
|
|
388
483
|
environment?: BuiltinEnvironment;
|
|
389
484
|
/**
|
|
390
|
-
*
|
|
485
|
+
* Environment options.
|
|
486
|
+
*/
|
|
487
|
+
environmentOptions?: EnvironmentOptions;
|
|
488
|
+
/**
|
|
489
|
+
* Update snapshot
|
|
391
490
|
*
|
|
392
491
|
* @default false
|
|
393
492
|
*/
|
|
@@ -400,6 +499,8 @@ interface InlineConfig {
|
|
|
400
499
|
watch?: boolean;
|
|
401
500
|
/**
|
|
402
501
|
* Project root
|
|
502
|
+
*
|
|
503
|
+
* @default process.cwd()
|
|
403
504
|
*/
|
|
404
505
|
root?: string;
|
|
405
506
|
/**
|
|
@@ -524,6 +625,7 @@ interface UserConfig extends InlineConfig {
|
|
|
524
625
|
related?: string[] | string;
|
|
525
626
|
}
|
|
526
627
|
interface ResolvedConfig extends Omit<Required<UserConfig>, 'config' | 'filters' | 'coverage' | 'testNamePattern' | 'related' | 'api'> {
|
|
628
|
+
base?: string;
|
|
527
629
|
config?: string;
|
|
528
630
|
filters?: string[];
|
|
529
631
|
testNamePattern?: RegExp;
|
package/dist/node.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
export { c as createVitest } from './index-
|
|
1
|
+
export { c as createVitest } from './index-9e44ed60.js';
|
|
2
2
|
import 'fs';
|
|
3
|
-
import './index-
|
|
3
|
+
import './index-64aafe4b.js';
|
|
4
4
|
import 'url';
|
|
5
5
|
import 'tty';
|
|
6
6
|
import 'local-pkg';
|
|
@@ -11,10 +11,10 @@ import 'os';
|
|
|
11
11
|
import 'util';
|
|
12
12
|
import 'stream';
|
|
13
13
|
import 'events';
|
|
14
|
-
import './constants-
|
|
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';
|