vitest 0.0.135 → 0.0.139
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 +6 -6
- package/dist/{diff-04ac7bc9.js → diff-5dfc7eb4.js} +2 -4
- package/dist/entry.js +21 -10
- package/dist/{global-3d90eb55.js → global-f971f18f.js} +4 -4
- package/dist/index-21eabd8a.js +8727 -0
- package/dist/{index-6397bdab.js → index-314cb4d9.js} +3 -3
- package/dist/index-64aafe4b.js +1 -1
- package/dist/index-8cb72062.js +9255 -0
- package/dist/index.d.ts +58 -22
- package/dist/index.js +3 -3
- package/dist/jest-mock-6c629944.js +95 -0
- package/dist/node.d.ts +42 -7
- package/dist/node.js +3 -3
- package/dist/{setup-a9c8349a.js → setup-7a362fbc.js} +9 -10
- package/dist/{vi-2509fe43.js → vi-567ba572.js} +2 -2
- package/dist/worker.js +25 -33
- package/package.json +5 -5
- package/dist/externalize-b979f524.js +0 -9259
- package/dist/index-9e44ed60.js +0 -8544
- package/dist/index-e909c175.js +0 -63
- package/dist/jest-mock-30625866.js +0 -94
package/dist/index.d.ts
CHANGED
|
@@ -98,7 +98,7 @@ declare const RECEIVED_COLOR: Formatter;
|
|
|
98
98
|
declare const INVERTED_COLOR: Formatter;
|
|
99
99
|
declare const BOLD_WEIGHT: Formatter;
|
|
100
100
|
declare const DIM_COLOR: Formatter;
|
|
101
|
-
|
|
101
|
+
interface MatcherHintOptions {
|
|
102
102
|
comment?: string;
|
|
103
103
|
expectedColor?: Formatter;
|
|
104
104
|
isDirectExpectCall?: boolean;
|
|
@@ -107,12 +107,12 @@ declare type MatcherHintOptions = {
|
|
|
107
107
|
receivedColor?: Formatter;
|
|
108
108
|
secondArgument?: string;
|
|
109
109
|
secondArgumentColor?: Formatter;
|
|
110
|
-
}
|
|
110
|
+
}
|
|
111
111
|
declare function matcherHint(matcherName: string, received?: string, expected?: string, options?: MatcherHintOptions): string;
|
|
112
112
|
declare const stringify: (object: unknown, maxDepth?: number) => string;
|
|
113
113
|
declare const printReceived: (object: unknown) => string;
|
|
114
114
|
declare const printExpected: (value: unknown) => string;
|
|
115
|
-
|
|
115
|
+
interface DiffOptions {
|
|
116
116
|
aAnnotation?: string;
|
|
117
117
|
aColor?: Formatter;
|
|
118
118
|
aIndicator?: string;
|
|
@@ -131,7 +131,7 @@ declare type DiffOptions = {
|
|
|
131
131
|
omitAnnotationLines?: boolean;
|
|
132
132
|
patchColor?: Formatter;
|
|
133
133
|
compareKeys?: any;
|
|
134
|
-
}
|
|
134
|
+
}
|
|
135
135
|
declare function diff(a: any, b: any, options?: DiffOptions): string;
|
|
136
136
|
|
|
137
137
|
declare const jestMatcherUtils_EXPECTED_COLOR: typeof EXPECTED_COLOR;
|
|
@@ -164,7 +164,7 @@ declare namespace jestMatcherUtils {
|
|
|
164
164
|
}
|
|
165
165
|
|
|
166
166
|
declare type Tester = (a: any, b: any) => boolean | undefined;
|
|
167
|
-
|
|
167
|
+
interface MatcherState {
|
|
168
168
|
assertionCalls: number;
|
|
169
169
|
currentTestName?: string;
|
|
170
170
|
dontThrow?: () => void;
|
|
@@ -183,21 +183,19 @@ declare type MatcherState = {
|
|
|
183
183
|
iterableEquality: Tester;
|
|
184
184
|
subsetEquality: Tester;
|
|
185
185
|
};
|
|
186
|
-
}
|
|
187
|
-
|
|
186
|
+
}
|
|
187
|
+
interface SyncExpectationResult {
|
|
188
188
|
pass: boolean;
|
|
189
189
|
message: () => string;
|
|
190
190
|
actual?: any;
|
|
191
191
|
expected?: any;
|
|
192
|
-
}
|
|
192
|
+
}
|
|
193
193
|
declare type AsyncExpectationResult = Promise<SyncExpectationResult>;
|
|
194
194
|
declare type ExpectationResult = SyncExpectationResult | AsyncExpectationResult;
|
|
195
|
-
|
|
195
|
+
interface RawMatcherFn<T extends MatcherState = MatcherState> {
|
|
196
196
|
(this: T, received: any, expected: any, options?: any): ExpectationResult;
|
|
197
|
-
}
|
|
198
|
-
declare type MatchersObject<T extends MatcherState = MatcherState> =
|
|
199
|
-
[id: string]: RawMatcherFn<T>;
|
|
200
|
-
};
|
|
197
|
+
}
|
|
198
|
+
declare type MatchersObject<T extends MatcherState = MatcherState> = Record<string, RawMatcherFn<T>>;
|
|
201
199
|
|
|
202
200
|
interface AsymmetricMatcherInterface {
|
|
203
201
|
asymmetricMatch(other: unknown): boolean;
|
|
@@ -307,6 +305,7 @@ declare class Vitest {
|
|
|
307
305
|
visitedFilesMap: Map<string, RawSourceMap>;
|
|
308
306
|
runningPromise?: Promise<void>;
|
|
309
307
|
closingPromise?: Promise<void>;
|
|
308
|
+
externalizeCache: Map<string, Promise<string | false>>;
|
|
310
309
|
isFirstRun: boolean;
|
|
311
310
|
restartsCount: number;
|
|
312
311
|
private _onRestartListeners;
|
|
@@ -327,6 +326,7 @@ declare class Vitest {
|
|
|
327
326
|
report<T extends keyof Reporter>(name: T, ...args: ArgumentsType<Reporter[T]>): Promise<void>;
|
|
328
327
|
globTestFiles(filters?: string[]): Promise<string[]>;
|
|
329
328
|
isTargetFile(id: string): boolean;
|
|
329
|
+
shouldExternalize(id: string): Promise<string | false>;
|
|
330
330
|
onServerRestarted(fn: () => void): void;
|
|
331
331
|
}
|
|
332
332
|
|
|
@@ -386,9 +386,14 @@ declare class VerboseReporter extends DefaultReporter {
|
|
|
386
386
|
}
|
|
387
387
|
|
|
388
388
|
declare class TapReporter implements Reporter {
|
|
389
|
-
|
|
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 {
|
|
390
396
|
onInit(ctx: Vitest): void;
|
|
391
|
-
logTasks(tasks: Task[], currentIdent: string): void;
|
|
392
397
|
onFinished(files?: File[]): Promise<void>;
|
|
393
398
|
}
|
|
394
399
|
|
|
@@ -397,6 +402,7 @@ declare const ReportersMap: {
|
|
|
397
402
|
verbose: typeof VerboseReporter;
|
|
398
403
|
dot: typeof DotReporter;
|
|
399
404
|
tap: typeof TapReporter;
|
|
405
|
+
'tap-flat': typeof TapFlatReporter;
|
|
400
406
|
};
|
|
401
407
|
declare type BuiltinReporters = keyof typeof ReportersMap;
|
|
402
408
|
|
|
@@ -660,19 +666,19 @@ interface Reporter {
|
|
|
660
666
|
|
|
661
667
|
declare type SnapshotData = Record<string, string>;
|
|
662
668
|
declare type SnapshotUpdateState = 'all' | 'new' | 'none';
|
|
663
|
-
|
|
669
|
+
interface SnapshotStateOptions {
|
|
664
670
|
updateSnapshot: SnapshotUpdateState;
|
|
665
671
|
expand?: boolean;
|
|
666
672
|
snapshotFormat?: OptionsReceived;
|
|
667
|
-
}
|
|
668
|
-
|
|
673
|
+
}
|
|
674
|
+
interface SnapshotMatchOptions {
|
|
669
675
|
testName: string;
|
|
670
676
|
received: unknown;
|
|
671
677
|
key?: string;
|
|
672
678
|
inlineSnapshot?: string;
|
|
673
679
|
isInline: boolean;
|
|
674
680
|
error?: Error;
|
|
675
|
-
}
|
|
681
|
+
}
|
|
676
682
|
interface SnapshotResult {
|
|
677
683
|
filepath: string;
|
|
678
684
|
added: number;
|
|
@@ -886,7 +892,33 @@ interface InlineConfig {
|
|
|
886
892
|
* Open Vitest UI
|
|
887
893
|
* @internal WIP
|
|
888
894
|
*/
|
|
889
|
-
|
|
895
|
+
ui?: boolean;
|
|
896
|
+
/**
|
|
897
|
+
* Base url for the UI
|
|
898
|
+
*
|
|
899
|
+
* @default '/__vitest__/'
|
|
900
|
+
*/
|
|
901
|
+
uiBase?: string;
|
|
902
|
+
/**
|
|
903
|
+
* Determine the transform method of modules
|
|
904
|
+
*/
|
|
905
|
+
transformMode?: {
|
|
906
|
+
/**
|
|
907
|
+
* Use SSR transform pipeline for the specified files.
|
|
908
|
+
* Vite plugins will receive `ssr: true` flag when processing those files.
|
|
909
|
+
*
|
|
910
|
+
* @default [/\.([cm]?[jt]sx?|json)$/]
|
|
911
|
+
*/
|
|
912
|
+
ssr?: RegExp[];
|
|
913
|
+
/**
|
|
914
|
+
* First do a normal transform pipeline (targeting browser),
|
|
915
|
+
* then then do a SSR rewrite to run the code in Node.
|
|
916
|
+
* Vite plugins will receive `ssr: false` flag when processing those files.
|
|
917
|
+
*
|
|
918
|
+
* @default other than `ssr`
|
|
919
|
+
*/
|
|
920
|
+
web?: RegExp[];
|
|
921
|
+
};
|
|
890
922
|
}
|
|
891
923
|
interface UserConfig extends InlineConfig {
|
|
892
924
|
/**
|
|
@@ -937,8 +969,12 @@ interface WorkerContext {
|
|
|
937
969
|
files: string[];
|
|
938
970
|
invalidates?: string[];
|
|
939
971
|
}
|
|
972
|
+
declare type FetchFunction = (id: string) => Promise<{
|
|
973
|
+
code?: string;
|
|
974
|
+
externalize?: string;
|
|
975
|
+
}>;
|
|
940
976
|
interface WorkerRPC {
|
|
941
|
-
fetch:
|
|
977
|
+
fetch: FetchFunction;
|
|
942
978
|
getSourceMap: (id: string, force?: boolean) => Promise<RawSourceMap | undefined>;
|
|
943
979
|
onWorkerExit: (code?: number) => void;
|
|
944
980
|
onUserLog: (log: UserConsoleLog) => void;
|
|
@@ -1228,4 +1264,4 @@ declare global {
|
|
|
1228
1264
|
}
|
|
1229
1265
|
}
|
|
1230
1266
|
|
|
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 };
|
|
1267
|
+
export { ApiConfig, ArgumentsType, Arrayable, Awaitable, BuiltinEnvironment, DoneCallback, EnhancedSpy, Environment, EnvironmentOptions, EnvironmentReturn, ErrorWithDiff, FetchFunction, 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,6 +1,6 @@
|
|
|
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-
|
|
3
|
-
export { f as fn, i as isMockFunction, s as spies, a as spyOn } from './jest-mock-
|
|
1
|
+
export { d as describe, i as it, c as suite, t as test, e as vi, v as vitest } from './vi-567ba572.js';
|
|
2
|
+
export { a as afterAll, d as afterEach, b as beforeAll, c as beforeEach, e as expect } from './index-314cb4d9.js';
|
|
3
|
+
export { f as fn, i as isMockFunction, s as spies, a as spyOn } from './jest-mock-6c629944.js';
|
|
4
4
|
export { assert, default as chai, should } from 'chai';
|
|
5
5
|
import './index-64aafe4b.js';
|
|
6
6
|
import 'url';
|
|
@@ -0,0 +1,95 @@
|
|
|
1
|
+
import { util } from 'chai';
|
|
2
|
+
import * as tinyspy from 'tinyspy';
|
|
3
|
+
|
|
4
|
+
const spies = new Set();
|
|
5
|
+
function isMockFunction(fn2) {
|
|
6
|
+
return typeof fn2 === "function" && "__isSpy" in fn2 && fn2.__isSpy;
|
|
7
|
+
}
|
|
8
|
+
function spyOn(obj, method, accessType) {
|
|
9
|
+
const dictionary = {
|
|
10
|
+
get: "getter",
|
|
11
|
+
set: "setter"
|
|
12
|
+
};
|
|
13
|
+
const objMethod = accessType ? { [dictionary[accessType]]: method } : method;
|
|
14
|
+
const stub = tinyspy.spyOn(obj, objMethod);
|
|
15
|
+
return enhanceSpy(stub);
|
|
16
|
+
}
|
|
17
|
+
function enhanceSpy(spy) {
|
|
18
|
+
const stub = spy;
|
|
19
|
+
let implementation;
|
|
20
|
+
let instances = [];
|
|
21
|
+
const mockContext = {
|
|
22
|
+
get calls() {
|
|
23
|
+
return stub.calls;
|
|
24
|
+
},
|
|
25
|
+
get instances() {
|
|
26
|
+
return instances;
|
|
27
|
+
},
|
|
28
|
+
get invocationCallOrder() {
|
|
29
|
+
return [];
|
|
30
|
+
},
|
|
31
|
+
get results() {
|
|
32
|
+
return stub.results.map(([callType, value]) => {
|
|
33
|
+
const type = callType === "error" ? "throw" : "return";
|
|
34
|
+
return { type, value };
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
};
|
|
38
|
+
let onceImplementations = [];
|
|
39
|
+
let name = stub.name;
|
|
40
|
+
stub.getMockName = () => name || "vi.fn()";
|
|
41
|
+
stub.mockName = (n) => {
|
|
42
|
+
name = n;
|
|
43
|
+
return stub;
|
|
44
|
+
};
|
|
45
|
+
stub.mockClear = () => {
|
|
46
|
+
stub.reset();
|
|
47
|
+
instances = [];
|
|
48
|
+
return stub;
|
|
49
|
+
};
|
|
50
|
+
stub.mockReset = () => {
|
|
51
|
+
stub.mockClear();
|
|
52
|
+
implementation = () => void 0;
|
|
53
|
+
onceImplementations = [];
|
|
54
|
+
return stub;
|
|
55
|
+
};
|
|
56
|
+
stub.mockRestore = () => {
|
|
57
|
+
stub.mockReset();
|
|
58
|
+
implementation = void 0;
|
|
59
|
+
return stub;
|
|
60
|
+
};
|
|
61
|
+
stub.getMockImplementation = () => implementation;
|
|
62
|
+
stub.mockImplementation = (fn2) => {
|
|
63
|
+
implementation = fn2;
|
|
64
|
+
return stub;
|
|
65
|
+
};
|
|
66
|
+
stub.mockImplementationOnce = (fn2) => {
|
|
67
|
+
onceImplementations.push(fn2);
|
|
68
|
+
return stub;
|
|
69
|
+
};
|
|
70
|
+
stub.mockReturnThis = () => stub.mockImplementation(function() {
|
|
71
|
+
return this;
|
|
72
|
+
});
|
|
73
|
+
stub.mockReturnValue = (val) => stub.mockImplementation(() => val);
|
|
74
|
+
stub.mockReturnValueOnce = (val) => stub.mockImplementationOnce(() => val);
|
|
75
|
+
stub.mockResolvedValue = (val) => stub.mockImplementation(() => Promise.resolve(val));
|
|
76
|
+
stub.mockResolvedValueOnce = (val) => stub.mockImplementationOnce(() => Promise.resolve(val));
|
|
77
|
+
stub.mockRejectedValue = (val) => stub.mockImplementation(() => Promise.reject(val));
|
|
78
|
+
stub.mockRejectedValueOnce = (val) => stub.mockImplementationOnce(() => Promise.reject(val));
|
|
79
|
+
util.addProperty(stub, "mock", () => mockContext);
|
|
80
|
+
stub.willCall(function(...args) {
|
|
81
|
+
instances.push(this);
|
|
82
|
+
const impl = onceImplementations.shift() || implementation || stub.getOriginal() || (() => {
|
|
83
|
+
});
|
|
84
|
+
return impl.apply(this, args);
|
|
85
|
+
});
|
|
86
|
+
spies.add(stub);
|
|
87
|
+
return stub;
|
|
88
|
+
}
|
|
89
|
+
function fn(implementation) {
|
|
90
|
+
return enhanceSpy(tinyspy.spyOn({ fn: implementation || (() => {
|
|
91
|
+
}) }, "fn"));
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
export { spyOn as a, fn as f, isMockFunction as i, spies as s };
|
|
95
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"jest-mock-6c629944.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  let 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    instances = []\n    return stub\n  }\n\n  stub.mockReset = () => {\n    stub.mockClear()\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
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { CommonServerOptions, ViteDevServer, UserConfig as UserConfig$1 } from 'vite';
|
|
1
|
+
import { CommonServerOptions, ViteDevServer, UserConfig as UserConfig$1, Plugin as Plugin$1 } from 'vite';
|
|
2
2
|
|
|
3
3
|
interface StartOfSourceMap {
|
|
4
4
|
file?: string;
|
|
@@ -69,9 +69,14 @@ declare class VerboseReporter extends DefaultReporter {
|
|
|
69
69
|
}
|
|
70
70
|
|
|
71
71
|
declare class TapReporter implements Reporter {
|
|
72
|
-
|
|
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 {
|
|
73
79
|
onInit(ctx: Vitest): void;
|
|
74
|
-
logTasks(tasks: Task[], currentIdent: string): void;
|
|
75
80
|
onFinished(files?: File[]): Promise<void>;
|
|
76
81
|
}
|
|
77
82
|
|
|
@@ -80,6 +85,7 @@ declare const ReportersMap: {
|
|
|
80
85
|
verbose: typeof VerboseReporter;
|
|
81
86
|
dot: typeof DotReporter;
|
|
82
87
|
tap: typeof TapReporter;
|
|
88
|
+
'tap-flat': typeof TapFlatReporter;
|
|
83
89
|
};
|
|
84
90
|
declare type BuiltinReporters = keyof typeof ReportersMap;
|
|
85
91
|
|
|
@@ -376,11 +382,11 @@ declare type Plugin = NewPlugin | OldPlugin;
|
|
|
376
382
|
declare type Plugins = Array<Plugin>;
|
|
377
383
|
|
|
378
384
|
declare type SnapshotUpdateState = 'all' | 'new' | 'none';
|
|
379
|
-
|
|
385
|
+
interface SnapshotStateOptions {
|
|
380
386
|
updateSnapshot: SnapshotUpdateState;
|
|
381
387
|
expand?: boolean;
|
|
382
388
|
snapshotFormat?: OptionsReceived;
|
|
383
|
-
}
|
|
389
|
+
}
|
|
384
390
|
interface SnapshotResult {
|
|
385
391
|
filepath: string;
|
|
386
392
|
added: number;
|
|
@@ -594,7 +600,33 @@ interface InlineConfig {
|
|
|
594
600
|
* Open Vitest UI
|
|
595
601
|
* @internal WIP
|
|
596
602
|
*/
|
|
597
|
-
|
|
603
|
+
ui?: boolean;
|
|
604
|
+
/**
|
|
605
|
+
* Base url for the UI
|
|
606
|
+
*
|
|
607
|
+
* @default '/__vitest__/'
|
|
608
|
+
*/
|
|
609
|
+
uiBase?: string;
|
|
610
|
+
/**
|
|
611
|
+
* Determine the transform method of modules
|
|
612
|
+
*/
|
|
613
|
+
transformMode?: {
|
|
614
|
+
/**
|
|
615
|
+
* Use SSR transform pipeline for the specified files.
|
|
616
|
+
* Vite plugins will receive `ssr: true` flag when processing those files.
|
|
617
|
+
*
|
|
618
|
+
* @default [/\.([cm]?[jt]sx?|json)$/]
|
|
619
|
+
*/
|
|
620
|
+
ssr?: RegExp[];
|
|
621
|
+
/**
|
|
622
|
+
* First do a normal transform pipeline (targeting browser),
|
|
623
|
+
* then then do a SSR rewrite to run the code in Node.
|
|
624
|
+
* Vite plugins will receive `ssr: false` flag when processing those files.
|
|
625
|
+
*
|
|
626
|
+
* @default other than `ssr`
|
|
627
|
+
*/
|
|
628
|
+
web?: RegExp[];
|
|
629
|
+
};
|
|
598
630
|
}
|
|
599
631
|
interface UserConfig extends InlineConfig {
|
|
600
632
|
/**
|
|
@@ -683,6 +715,7 @@ declare class Vitest {
|
|
|
683
715
|
visitedFilesMap: Map<string, RawSourceMap>;
|
|
684
716
|
runningPromise?: Promise<void>;
|
|
685
717
|
closingPromise?: Promise<void>;
|
|
718
|
+
externalizeCache: Map<string, Promise<string | false>>;
|
|
686
719
|
isFirstRun: boolean;
|
|
687
720
|
restartsCount: number;
|
|
688
721
|
private _onRestartListeners;
|
|
@@ -703,9 +736,11 @@ declare class Vitest {
|
|
|
703
736
|
report<T extends keyof Reporter>(name: T, ...args: ArgumentsType<Reporter[T]>): Promise<void>;
|
|
704
737
|
globTestFiles(filters?: string[]): Promise<string[]>;
|
|
705
738
|
isTargetFile(id: string): boolean;
|
|
739
|
+
shouldExternalize(id: string): Promise<string | false>;
|
|
706
740
|
onServerRestarted(fn: () => void): void;
|
|
707
741
|
}
|
|
708
742
|
|
|
743
|
+
declare function VitestPlugin(options?: UserConfig, viteOverrides?: UserConfig$1, ctx?: Vitest): Promise<Plugin$1[]>;
|
|
709
744
|
declare function createVitest(options: UserConfig, viteOverrides?: UserConfig$1): Promise<Vitest>;
|
|
710
745
|
|
|
711
|
-
export { Vitest, createVitest };
|
|
746
|
+
export { Vitest, VitestPlugin, createVitest };
|
package/dist/node.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
export { c as createVitest } from './index-
|
|
1
|
+
export { V as VitestPlugin, c as createVitest } from './index-21eabd8a.js';
|
|
2
2
|
import 'fs';
|
|
3
3
|
import './index-64aafe4b.js';
|
|
4
4
|
import 'url';
|
|
@@ -14,12 +14,12 @@ 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-5dfc7eb4.js';
|
|
18
18
|
import './index-648e7ab2.js';
|
|
19
19
|
import './_commonjsHelpers-c9e3b764.js';
|
|
20
20
|
import 'assert';
|
|
21
21
|
import 'module';
|
|
22
|
+
import './index-8cb72062.js';
|
|
22
23
|
import 'worker_threads';
|
|
23
24
|
import 'tinypool';
|
|
24
|
-
import './index-e909c175.js';
|
|
25
25
|
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9kZS5qcyIsInNvdXJjZXMiOltdLCJzb3VyY2VzQ29udGVudCI6W10sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OyJ9
|