vitest 0.0.136 → 0.0.140
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/LICENSE.md +24 -0
- package/dist/cli.js +10 -9
- package/dist/{constants-d24b670d.js → constants-124522a1.js} +2 -2
- package/dist/{diff-04ac7bc9.js → diff-deb11fa7.js} +4 -5
- package/dist/entry.js +204 -22
- package/dist/global-7907d87d.js +22 -0
- package/dist/index-1b2eb03b.js +187 -0
- package/dist/index-3faf3d6e.js +8807 -0
- package/dist/{index-6397bdab.js → index-4a8eca63.js} +3 -3
- package/dist/index-53aca3c1.js +205 -0
- package/dist/index-c037b40c.js +9272 -0
- package/dist/index.d.ts +47 -23
- package/dist/index.js +5 -7
- package/dist/jest-mock-6c629944.js +95 -0
- package/dist/node.d.ts +31 -8
- package/dist/node.js +12 -11
- package/dist/{setup-6bff359f.js → setup-901b91d4.js} +68 -83
- package/dist/{vi-2509fe43.js → vi-8e5d0623.js} +3 -3
- package/dist/worker.js +227 -215
- package/package.json +10 -8
- package/dist/externalize-b979f524.js +0 -9259
- package/dist/global-3d90eb55.js +0 -21
- package/dist/index-0b823579.js +0 -8588
- package/dist/index-64aafe4b.js +0 -396
- package/dist/index-e909c175.js +0 -63
- package/dist/jest-mock-30625866.js +0 -94
package/dist/index.d.ts
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { ViteDevServer, CommonServerOptions, TransformResult } from 'vite';
|
|
2
|
+
import { ViteNodeServer } from 'vite-node/server';
|
|
2
3
|
import { MessagePort } from 'worker_threads';
|
|
3
4
|
import { SpyImpl } from 'tinyspy';
|
|
4
5
|
export { Spy, SpyFn } from 'tinyspy';
|
|
@@ -98,7 +99,7 @@ declare const RECEIVED_COLOR: Formatter;
|
|
|
98
99
|
declare const INVERTED_COLOR: Formatter;
|
|
99
100
|
declare const BOLD_WEIGHT: Formatter;
|
|
100
101
|
declare const DIM_COLOR: Formatter;
|
|
101
|
-
|
|
102
|
+
interface MatcherHintOptions {
|
|
102
103
|
comment?: string;
|
|
103
104
|
expectedColor?: Formatter;
|
|
104
105
|
isDirectExpectCall?: boolean;
|
|
@@ -107,12 +108,12 @@ declare type MatcherHintOptions = {
|
|
|
107
108
|
receivedColor?: Formatter;
|
|
108
109
|
secondArgument?: string;
|
|
109
110
|
secondArgumentColor?: Formatter;
|
|
110
|
-
}
|
|
111
|
+
}
|
|
111
112
|
declare function matcherHint(matcherName: string, received?: string, expected?: string, options?: MatcherHintOptions): string;
|
|
112
113
|
declare const stringify: (object: unknown, maxDepth?: number) => string;
|
|
113
114
|
declare const printReceived: (object: unknown) => string;
|
|
114
115
|
declare const printExpected: (value: unknown) => string;
|
|
115
|
-
|
|
116
|
+
interface DiffOptions {
|
|
116
117
|
aAnnotation?: string;
|
|
117
118
|
aColor?: Formatter;
|
|
118
119
|
aIndicator?: string;
|
|
@@ -131,7 +132,7 @@ declare type DiffOptions = {
|
|
|
131
132
|
omitAnnotationLines?: boolean;
|
|
132
133
|
patchColor?: Formatter;
|
|
133
134
|
compareKeys?: any;
|
|
134
|
-
}
|
|
135
|
+
}
|
|
135
136
|
declare function diff(a: any, b: any, options?: DiffOptions): string;
|
|
136
137
|
|
|
137
138
|
declare const jestMatcherUtils_EXPECTED_COLOR: typeof EXPECTED_COLOR;
|
|
@@ -164,7 +165,7 @@ declare namespace jestMatcherUtils {
|
|
|
164
165
|
}
|
|
165
166
|
|
|
166
167
|
declare type Tester = (a: any, b: any) => boolean | undefined;
|
|
167
|
-
|
|
168
|
+
interface MatcherState {
|
|
168
169
|
assertionCalls: number;
|
|
169
170
|
currentTestName?: string;
|
|
170
171
|
dontThrow?: () => void;
|
|
@@ -183,21 +184,19 @@ declare type MatcherState = {
|
|
|
183
184
|
iterableEquality: Tester;
|
|
184
185
|
subsetEquality: Tester;
|
|
185
186
|
};
|
|
186
|
-
}
|
|
187
|
-
|
|
187
|
+
}
|
|
188
|
+
interface SyncExpectationResult {
|
|
188
189
|
pass: boolean;
|
|
189
190
|
message: () => string;
|
|
190
191
|
actual?: any;
|
|
191
192
|
expected?: any;
|
|
192
|
-
}
|
|
193
|
+
}
|
|
193
194
|
declare type AsyncExpectationResult = Promise<SyncExpectationResult>;
|
|
194
195
|
declare type ExpectationResult = SyncExpectationResult | AsyncExpectationResult;
|
|
195
|
-
|
|
196
|
+
interface RawMatcherFn<T extends MatcherState = MatcherState> {
|
|
196
197
|
(this: T, received: any, expected: any, options?: any): ExpectationResult;
|
|
197
|
-
}
|
|
198
|
-
declare type MatchersObject<T extends MatcherState = MatcherState> =
|
|
199
|
-
[id: string]: RawMatcherFn<T>;
|
|
200
|
-
};
|
|
198
|
+
}
|
|
199
|
+
declare type MatchersObject<T extends MatcherState = MatcherState> = Record<string, RawMatcherFn<T>>;
|
|
201
200
|
|
|
202
201
|
interface AsymmetricMatcherInterface {
|
|
203
202
|
asymmetricMatch(other: unknown): boolean;
|
|
@@ -302,6 +301,7 @@ declare class Vitest {
|
|
|
302
301
|
errorStream: NodeJS.WriteStream & {
|
|
303
302
|
fd: 2;
|
|
304
303
|
};
|
|
304
|
+
vitenode: ViteNodeServer;
|
|
305
305
|
invalidates: Set<string>;
|
|
306
306
|
changedTests: Set<string>;
|
|
307
307
|
visitedFilesMap: Map<string, RawSourceMap>;
|
|
@@ -666,19 +666,19 @@ interface Reporter {
|
|
|
666
666
|
|
|
667
667
|
declare type SnapshotData = Record<string, string>;
|
|
668
668
|
declare type SnapshotUpdateState = 'all' | 'new' | 'none';
|
|
669
|
-
|
|
669
|
+
interface SnapshotStateOptions {
|
|
670
670
|
updateSnapshot: SnapshotUpdateState;
|
|
671
671
|
expand?: boolean;
|
|
672
672
|
snapshotFormat?: OptionsReceived;
|
|
673
|
-
}
|
|
674
|
-
|
|
673
|
+
}
|
|
674
|
+
interface SnapshotMatchOptions {
|
|
675
675
|
testName: string;
|
|
676
676
|
received: unknown;
|
|
677
677
|
key?: string;
|
|
678
678
|
inlineSnapshot?: string;
|
|
679
679
|
isInline: boolean;
|
|
680
680
|
error?: Error;
|
|
681
|
-
}
|
|
681
|
+
}
|
|
682
682
|
interface SnapshotResult {
|
|
683
683
|
filepath: string;
|
|
684
684
|
added: number;
|
|
@@ -845,6 +845,10 @@ interface InlineConfig {
|
|
|
845
845
|
* Path to setup files
|
|
846
846
|
*/
|
|
847
847
|
setupFiles?: string | string[];
|
|
848
|
+
/**
|
|
849
|
+
* Path to global setup files
|
|
850
|
+
*/
|
|
851
|
+
globalSetup?: string | string[];
|
|
848
852
|
/**
|
|
849
853
|
* Pattern of file paths to be ignore from triggering watch rerun
|
|
850
854
|
*
|
|
@@ -899,6 +903,26 @@ interface InlineConfig {
|
|
|
899
903
|
* @default '/__vitest__/'
|
|
900
904
|
*/
|
|
901
905
|
uiBase?: string;
|
|
906
|
+
/**
|
|
907
|
+
* Determine the transform method of modules
|
|
908
|
+
*/
|
|
909
|
+
transformMode?: {
|
|
910
|
+
/**
|
|
911
|
+
* Use SSR transform pipeline for the specified files.
|
|
912
|
+
* Vite plugins will receive `ssr: true` flag when processing those files.
|
|
913
|
+
*
|
|
914
|
+
* @default [/\.([cm]?[jt]sx?|json)$/]
|
|
915
|
+
*/
|
|
916
|
+
ssr?: RegExp[];
|
|
917
|
+
/**
|
|
918
|
+
* First do a normal transform pipeline (targeting browser),
|
|
919
|
+
* then then do a SSR rewrite to run the code in Node.
|
|
920
|
+
* Vite plugins will receive `ssr: false` flag when processing those files.
|
|
921
|
+
*
|
|
922
|
+
* @default other than `ssr`
|
|
923
|
+
*/
|
|
924
|
+
web?: RegExp[];
|
|
925
|
+
};
|
|
902
926
|
}
|
|
903
927
|
interface UserConfig extends InlineConfig {
|
|
904
928
|
/**
|
|
@@ -934,10 +958,6 @@ interface ResolvedConfig extends Omit<Required<UserConfig>, 'config' | 'filters'
|
|
|
934
958
|
filters?: string[];
|
|
935
959
|
testNamePattern?: RegExp;
|
|
936
960
|
related?: string[];
|
|
937
|
-
depsInline: (string | RegExp)[];
|
|
938
|
-
depsExternal: (string | RegExp)[];
|
|
939
|
-
fallbackCJS: boolean;
|
|
940
|
-
interpretDefault: boolean;
|
|
941
961
|
coverage: ResolvedC8Options;
|
|
942
962
|
snapshotOptions: SnapshotStateOptions;
|
|
943
963
|
api?: ApiConfig;
|
|
@@ -949,8 +969,12 @@ interface WorkerContext {
|
|
|
949
969
|
files: string[];
|
|
950
970
|
invalidates?: string[];
|
|
951
971
|
}
|
|
972
|
+
declare type FetchFunction = (id: string) => Promise<{
|
|
973
|
+
code?: string;
|
|
974
|
+
externalize?: string;
|
|
975
|
+
}>;
|
|
952
976
|
interface WorkerRPC {
|
|
953
|
-
fetch:
|
|
977
|
+
fetch: FetchFunction;
|
|
954
978
|
getSourceMap: (id: string, force?: boolean) => Promise<RawSourceMap | undefined>;
|
|
955
979
|
onWorkerExit: (code?: number) => void;
|
|
956
980
|
onUserLog: (log: UserConsoleLog) => void;
|
|
@@ -1240,4 +1264,4 @@ declare global {
|
|
|
1240
1264
|
}
|
|
1241
1265
|
}
|
|
1242
1266
|
|
|
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 };
|
|
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,12 +1,10 @@
|
|
|
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-8e5d0623.js';
|
|
2
|
+
export { a as afterAll, d as afterEach, b as beforeAll, c as beforeEach, e as expect } from './index-4a8eca63.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
|
-
import './index-
|
|
6
|
-
import 'url';
|
|
5
|
+
import './index-53aca3c1.js';
|
|
7
6
|
import 'tty';
|
|
8
7
|
import 'local-pkg';
|
|
9
|
-
import 'path';
|
|
10
8
|
import './_commonjsHelpers-c9e3b764.js';
|
|
11
9
|
import 'tinyspy';
|
|
12
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
10
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VzIjpbXSwic291cmNlc0NvbnRlbnQiOltdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7OzsifQ==
|
|
@@ -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,5 @@
|
|
|
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
|
+
import { ViteNodeServer } from 'vite-node/server';
|
|
2
3
|
|
|
3
4
|
interface StartOfSourceMap {
|
|
4
5
|
file?: string;
|
|
@@ -382,11 +383,11 @@ declare type Plugin = NewPlugin | OldPlugin;
|
|
|
382
383
|
declare type Plugins = Array<Plugin>;
|
|
383
384
|
|
|
384
385
|
declare type SnapshotUpdateState = 'all' | 'new' | 'none';
|
|
385
|
-
|
|
386
|
+
interface SnapshotStateOptions {
|
|
386
387
|
updateSnapshot: SnapshotUpdateState;
|
|
387
388
|
expand?: boolean;
|
|
388
389
|
snapshotFormat?: OptionsReceived;
|
|
389
|
-
}
|
|
390
|
+
}
|
|
390
391
|
interface SnapshotResult {
|
|
391
392
|
filepath: string;
|
|
392
393
|
added: number;
|
|
@@ -553,6 +554,10 @@ interface InlineConfig {
|
|
|
553
554
|
* Path to setup files
|
|
554
555
|
*/
|
|
555
556
|
setupFiles?: string | string[];
|
|
557
|
+
/**
|
|
558
|
+
* Path to global setup files
|
|
559
|
+
*/
|
|
560
|
+
globalSetup?: string | string[];
|
|
556
561
|
/**
|
|
557
562
|
* Pattern of file paths to be ignore from triggering watch rerun
|
|
558
563
|
*
|
|
@@ -607,6 +612,26 @@ interface InlineConfig {
|
|
|
607
612
|
* @default '/__vitest__/'
|
|
608
613
|
*/
|
|
609
614
|
uiBase?: string;
|
|
615
|
+
/**
|
|
616
|
+
* Determine the transform method of modules
|
|
617
|
+
*/
|
|
618
|
+
transformMode?: {
|
|
619
|
+
/**
|
|
620
|
+
* Use SSR transform pipeline for the specified files.
|
|
621
|
+
* Vite plugins will receive `ssr: true` flag when processing those files.
|
|
622
|
+
*
|
|
623
|
+
* @default [/\.([cm]?[jt]sx?|json)$/]
|
|
624
|
+
*/
|
|
625
|
+
ssr?: RegExp[];
|
|
626
|
+
/**
|
|
627
|
+
* First do a normal transform pipeline (targeting browser),
|
|
628
|
+
* then then do a SSR rewrite to run the code in Node.
|
|
629
|
+
* Vite plugins will receive `ssr: false` flag when processing those files.
|
|
630
|
+
*
|
|
631
|
+
* @default other than `ssr`
|
|
632
|
+
*/
|
|
633
|
+
web?: RegExp[];
|
|
634
|
+
};
|
|
610
635
|
}
|
|
611
636
|
interface UserConfig extends InlineConfig {
|
|
612
637
|
/**
|
|
@@ -642,10 +667,6 @@ interface ResolvedConfig extends Omit<Required<UserConfig>, 'config' | 'filters'
|
|
|
642
667
|
filters?: string[];
|
|
643
668
|
testNamePattern?: RegExp;
|
|
644
669
|
related?: string[];
|
|
645
|
-
depsInline: (string | RegExp)[];
|
|
646
|
-
depsExternal: (string | RegExp)[];
|
|
647
|
-
fallbackCJS: boolean;
|
|
648
|
-
interpretDefault: boolean;
|
|
649
670
|
coverage: ResolvedC8Options;
|
|
650
671
|
snapshotOptions: SnapshotStateOptions;
|
|
651
672
|
api?: ApiConfig;
|
|
@@ -690,6 +711,7 @@ declare class Vitest {
|
|
|
690
711
|
errorStream: NodeJS.WriteStream & {
|
|
691
712
|
fd: 2;
|
|
692
713
|
};
|
|
714
|
+
vitenode: ViteNodeServer;
|
|
693
715
|
invalidates: Set<string>;
|
|
694
716
|
changedTests: Set<string>;
|
|
695
717
|
visitedFilesMap: Map<string, RawSourceMap>;
|
|
@@ -718,6 +740,7 @@ declare class Vitest {
|
|
|
718
740
|
onServerRestarted(fn: () => void): void;
|
|
719
741
|
}
|
|
720
742
|
|
|
743
|
+
declare function VitestPlugin(options?: UserConfig, viteOverrides?: UserConfig$1, ctx?: Vitest): Promise<Plugin$1[]>;
|
|
721
744
|
declare function createVitest(options: UserConfig, viteOverrides?: UserConfig$1): Promise<Vitest>;
|
|
722
745
|
|
|
723
|
-
export { Vitest, createVitest };
|
|
746
|
+
export { Vitest, VitestPlugin, createVitest };
|
package/dist/node.js
CHANGED
|
@@ -1,9 +1,6 @@
|
|
|
1
|
-
export { c as createVitest } from './index-
|
|
1
|
+
export { V as VitestPlugin, c as createVitest } from './index-3faf3d6e.js';
|
|
2
2
|
import 'fs';
|
|
3
|
-
import './index-
|
|
4
|
-
import 'url';
|
|
5
|
-
import 'tty';
|
|
6
|
-
import 'local-pkg';
|
|
3
|
+
import './index-1b2eb03b.js';
|
|
7
4
|
import 'path';
|
|
8
5
|
import 'vite';
|
|
9
6
|
import 'process';
|
|
@@ -11,15 +8,19 @@ import 'os';
|
|
|
11
8
|
import 'util';
|
|
12
9
|
import 'stream';
|
|
13
10
|
import 'events';
|
|
14
|
-
import './
|
|
11
|
+
import './index-53aca3c1.js';
|
|
12
|
+
import 'tty';
|
|
13
|
+
import 'local-pkg';
|
|
14
|
+
import './index-c037b40c.js';
|
|
15
|
+
import 'module';
|
|
16
|
+
import 'url';
|
|
17
|
+
import 'assert';
|
|
18
|
+
import './constants-124522a1.js';
|
|
15
19
|
import './magic-string.es-94000aea.js';
|
|
16
20
|
import 'perf_hooks';
|
|
17
|
-
import './diff-
|
|
21
|
+
import './diff-deb11fa7.js';
|
|
18
22
|
import './index-648e7ab2.js';
|
|
19
23
|
import './_commonjsHelpers-c9e3b764.js';
|
|
20
|
-
import 'assert';
|
|
21
|
-
import 'module';
|
|
22
24
|
import 'worker_threads';
|
|
23
25
|
import 'tinypool';
|
|
24
|
-
|
|
25
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9kZS5qcyIsInNvdXJjZXMiOltdLCJzb3VyY2VzQ29udGVudCI6W10sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OyJ9
|
|
26
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9kZS5qcyIsInNvdXJjZXMiOltdLCJzb3VyY2VzQ29udGVudCI6W10sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OzsifQ==
|