vitest 0.0.129 → 0.0.133
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/_commonjsHelpers-c9e3b764.js +1 -0
- package/dist/cli.js +10 -9
- package/dist/constants-0211a379.js +34 -0
- package/dist/diff-18d4a7eb.js +4750 -0
- package/dist/entry.js +94 -33
- package/dist/externalize-2f63779d.js +1 -0
- package/dist/global-5d1fb309.js +21 -0
- package/dist/index-26cb6e63.js +1644 -0
- package/dist/index-354a6abd.js +40 -0
- package/dist/index-4cd25949.js +782 -0
- package/dist/index-720a83c6.js +396 -0
- package/dist/index-7975be53.js +331 -0
- package/dist/index-7f7acd60.js +8548 -0
- package/dist/index-e909c175.js +63 -0
- package/dist/index-fa899e66.js +5708 -0
- package/dist/index.d.ts +142 -27
- package/dist/index.js +4 -3
- package/dist/jest-mock-30625866.js +1 -0
- package/dist/magic-string.es-94000aea.js +1361 -0
- package/dist/node.d.ts +111 -4
- package/dist/node.js +9 -8
- package/dist/rpc-8c7cc374.js +1 -0
- package/dist/setup-5aaf533e.js +4365 -0
- package/dist/vi-aec007e7.js +3461 -0
- package/dist/worker.js +11 -7
- package/package.json +9 -9
- package/dist/constants-868b9a2e.js +0 -33
- package/dist/diff-be830986.js +0 -4751
- package/dist/global-0254dd68.js +0 -20
- package/dist/index-06712022.js +0 -39
- package/dist/index-42a3a132.js +0 -366
- package/dist/index-42d44ee5.js +0 -1643
- package/dist/index-93dcb598.js +0 -5707
- package/dist/index-a73f33e0.js +0 -62
- package/dist/index-cb02ee01.js +0 -330
- package/dist/index-cce5de77.js +0 -781
- package/dist/index-d30b5ed0.js +0 -8579
- package/dist/magic-string.es-98a8bfa0.js +0 -1360
- package/dist/setup-6e09a65a.js +0 -4364
- package/dist/vi-fe26a646.js +0 -3460
package/dist/index.d.ts
CHANGED
|
@@ -1,12 +1,98 @@
|
|
|
1
|
-
import { OptionsReceived, Plugin } from 'pretty-format';
|
|
2
|
-
import { Formatter } from 'picocolors/types';
|
|
3
1
|
import { ViteDevServer, CommonServerOptions } from 'vite';
|
|
4
|
-
import { RawSourceMap } from 'source-map-js';
|
|
5
2
|
import { MessagePort } from 'worker_threads';
|
|
6
3
|
import { SpyImpl } from 'tinyspy';
|
|
7
4
|
export { Spy, SpyFn } from 'tinyspy';
|
|
8
5
|
export { assert, default as chai, should } from 'chai';
|
|
9
6
|
|
|
7
|
+
/**
|
|
8
|
+
* Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved.
|
|
9
|
+
*
|
|
10
|
+
* This source code is licensed under the MIT license found in the
|
|
11
|
+
* LICENSE file in the root directory of this source tree.
|
|
12
|
+
*/
|
|
13
|
+
declare type Colors = {
|
|
14
|
+
comment: {
|
|
15
|
+
close: string;
|
|
16
|
+
open: string;
|
|
17
|
+
};
|
|
18
|
+
content: {
|
|
19
|
+
close: string;
|
|
20
|
+
open: string;
|
|
21
|
+
};
|
|
22
|
+
prop: {
|
|
23
|
+
close: string;
|
|
24
|
+
open: string;
|
|
25
|
+
};
|
|
26
|
+
tag: {
|
|
27
|
+
close: string;
|
|
28
|
+
open: string;
|
|
29
|
+
};
|
|
30
|
+
value: {
|
|
31
|
+
close: string;
|
|
32
|
+
open: string;
|
|
33
|
+
};
|
|
34
|
+
};
|
|
35
|
+
declare type Indent = (arg0: string) => string;
|
|
36
|
+
declare type Refs = Array<unknown>;
|
|
37
|
+
declare type Print = (arg0: unknown) => string;
|
|
38
|
+
declare type ThemeReceived = {
|
|
39
|
+
comment?: string;
|
|
40
|
+
content?: string;
|
|
41
|
+
prop?: string;
|
|
42
|
+
tag?: string;
|
|
43
|
+
value?: string;
|
|
44
|
+
};
|
|
45
|
+
declare type CompareKeys = ((a: string, b: string) => number) | undefined;
|
|
46
|
+
interface PrettyFormatOptions {
|
|
47
|
+
callToJSON?: boolean;
|
|
48
|
+
compareKeys?: CompareKeys;
|
|
49
|
+
escapeRegex?: boolean;
|
|
50
|
+
escapeString?: boolean;
|
|
51
|
+
highlight?: boolean;
|
|
52
|
+
indent?: number;
|
|
53
|
+
maxDepth?: number;
|
|
54
|
+
min?: boolean;
|
|
55
|
+
plugins?: Plugins;
|
|
56
|
+
printBasicPrototype?: boolean;
|
|
57
|
+
printFunctionName?: boolean;
|
|
58
|
+
theme?: ThemeReceived;
|
|
59
|
+
}
|
|
60
|
+
declare type OptionsReceived = PrettyFormatOptions;
|
|
61
|
+
declare type Config = {
|
|
62
|
+
callToJSON: boolean;
|
|
63
|
+
compareKeys: CompareKeys;
|
|
64
|
+
colors: Colors;
|
|
65
|
+
escapeRegex: boolean;
|
|
66
|
+
escapeString: boolean;
|
|
67
|
+
indent: string;
|
|
68
|
+
maxDepth: number;
|
|
69
|
+
min: boolean;
|
|
70
|
+
plugins: Plugins;
|
|
71
|
+
printBasicPrototype: boolean;
|
|
72
|
+
printFunctionName: boolean;
|
|
73
|
+
spacingInner: string;
|
|
74
|
+
spacingOuter: string;
|
|
75
|
+
};
|
|
76
|
+
declare type Printer = (val: unknown, config: Config, indentation: string, depth: number, refs: Refs, hasCalledToJSON?: boolean) => string;
|
|
77
|
+
declare type Test$1 = (arg0: any) => boolean;
|
|
78
|
+
declare type NewPlugin = {
|
|
79
|
+
serialize: (val: any, config: Config, indentation: string, depth: number, refs: Refs, printer: Printer) => string;
|
|
80
|
+
test: Test$1;
|
|
81
|
+
};
|
|
82
|
+
declare type PluginOptions = {
|
|
83
|
+
edgeSpacing: string;
|
|
84
|
+
min: boolean;
|
|
85
|
+
spacing: string;
|
|
86
|
+
};
|
|
87
|
+
declare type OldPlugin = {
|
|
88
|
+
print: (val: unknown, print: Print, indent: Indent, options: PluginOptions, colors: Colors) => string;
|
|
89
|
+
test: Test$1;
|
|
90
|
+
};
|
|
91
|
+
declare type Plugin = NewPlugin | OldPlugin;
|
|
92
|
+
declare type Plugins = Array<Plugin>;
|
|
93
|
+
|
|
94
|
+
declare type Formatter = (input: string | number | null | undefined) => string;
|
|
95
|
+
|
|
10
96
|
declare const EXPECTED_COLOR: Formatter;
|
|
11
97
|
declare const RECEIVED_COLOR: Formatter;
|
|
12
98
|
declare const INVERTED_COLOR: Formatter;
|
|
@@ -101,6 +187,8 @@ declare type MatcherState = {
|
|
|
101
187
|
declare type SyncExpectationResult = {
|
|
102
188
|
pass: boolean;
|
|
103
189
|
message: () => string;
|
|
190
|
+
actual?: any;
|
|
191
|
+
expected?: any;
|
|
104
192
|
};
|
|
105
193
|
declare type AsyncExpectationResult = Promise<SyncExpectationResult>;
|
|
106
194
|
declare type ExpectationResult = SyncExpectationResult | AsyncExpectationResult;
|
|
@@ -162,6 +250,19 @@ declare class StringMatching extends AsymmetricMatcher<RegExp> {
|
|
|
162
250
|
getExpectedType(): string;
|
|
163
251
|
}
|
|
164
252
|
|
|
253
|
+
interface StartOfSourceMap {
|
|
254
|
+
file?: string;
|
|
255
|
+
sourceRoot?: string;
|
|
256
|
+
}
|
|
257
|
+
|
|
258
|
+
interface RawSourceMap extends StartOfSourceMap {
|
|
259
|
+
version: string;
|
|
260
|
+
sources: string[];
|
|
261
|
+
names: string[];
|
|
262
|
+
sourcesContent?: string[];
|
|
263
|
+
mappings: string;
|
|
264
|
+
}
|
|
265
|
+
|
|
165
266
|
declare class SnapshotManager {
|
|
166
267
|
config: ResolvedConfig;
|
|
167
268
|
summary: SnapshotSummary;
|
|
@@ -284,10 +385,18 @@ declare class VerboseReporter extends DefaultReporter {
|
|
|
284
385
|
constructor();
|
|
285
386
|
}
|
|
286
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
|
+
|
|
287
395
|
declare const ReportersMap: {
|
|
288
396
|
default: typeof DefaultReporter;
|
|
289
397
|
verbose: typeof VerboseReporter;
|
|
290
398
|
dot: typeof DotReporter;
|
|
399
|
+
tap: typeof TapReporter;
|
|
291
400
|
};
|
|
292
401
|
declare type BuiltinReporters = keyof typeof ReportersMap;
|
|
293
402
|
|
|
@@ -710,6 +819,7 @@ interface UserConfig extends InlineConfig {
|
|
|
710
819
|
related?: string[] | string;
|
|
711
820
|
}
|
|
712
821
|
interface ResolvedConfig extends Omit<Required<UserConfig>, 'config' | 'filters' | 'coverage' | 'testNamePattern' | 'related' | 'api'> {
|
|
822
|
+
base?: string;
|
|
713
823
|
config?: string;
|
|
714
824
|
filters?: string[];
|
|
715
825
|
testNamePattern?: RegExp;
|
|
@@ -770,6 +880,16 @@ interface JestMockCompatContext<T, Y> {
|
|
|
770
880
|
invocationCallOrder: number[];
|
|
771
881
|
results: MockResult<T>[];
|
|
772
882
|
}
|
|
883
|
+
declare type Procedure = (...args: any[]) => any;
|
|
884
|
+
declare type Methods<T> = {
|
|
885
|
+
[K in keyof T]: T[K] extends Procedure ? K : never;
|
|
886
|
+
}[keyof T] & string;
|
|
887
|
+
declare type Properties<T> = {
|
|
888
|
+
[K in keyof T]: T[K] extends Procedure ? never : K;
|
|
889
|
+
}[keyof T] & string;
|
|
890
|
+
declare type Classes<T> = {
|
|
891
|
+
[K in keyof T]: T[K] extends new (...args: any[]) => any ? K : never;
|
|
892
|
+
}[keyof T] & string;
|
|
773
893
|
interface JestMockCompat<TArgs extends any[] = any[], TReturns = any> {
|
|
774
894
|
getMockName(): string;
|
|
775
895
|
mockName(n: string): this;
|
|
@@ -791,41 +911,34 @@ interface JestMockCompat<TArgs extends any[] = any[], TReturns = any> {
|
|
|
791
911
|
interface JestMockCompatFn<TArgs extends any[] = any, TReturns = any> extends JestMockCompat<TArgs, TReturns> {
|
|
792
912
|
(...args: TArgs): TReturns;
|
|
793
913
|
}
|
|
794
|
-
declare type
|
|
795
|
-
declare type
|
|
796
|
-
[K in keyof T]: T[K] extends MockableFunction ? K : never;
|
|
797
|
-
}[keyof T];
|
|
798
|
-
declare type PropertyKeysOf<T> = {
|
|
799
|
-
[K in keyof T]: T[K] extends MockableFunction ? never : K;
|
|
800
|
-
}[keyof T];
|
|
801
|
-
declare type ArgumentsOf<T> = T extends (...args: infer A) => any ? A : never;
|
|
802
|
-
declare type ConstructorArgumentsOf<T> = T extends new (...args: infer A) => any ? A : never;
|
|
803
|
-
declare type MaybeMockedConstructor<T> = T extends new (...args: Array<any>) => infer R ? JestMockCompatFn<ConstructorArgumentsOf<T>, R> : T;
|
|
804
|
-
declare type MockedFunction<T extends MockableFunction> = MockWithArgs<T> & {
|
|
914
|
+
declare type MaybeMockedConstructor<T> = T extends new (...args: Array<any>) => infer R ? JestMockCompatFn<ConstructorParameters<T>, R> : T;
|
|
915
|
+
declare type MockedFunction<T extends Procedure> = MockWithArgs<T> & {
|
|
805
916
|
[K in keyof T]: T[K];
|
|
806
917
|
};
|
|
807
|
-
declare type MockedFunctionDeep<T extends
|
|
918
|
+
declare type MockedFunctionDeep<T extends Procedure> = MockWithArgs<T> & MockedObjectDeep<T>;
|
|
808
919
|
declare type MockedObject<T> = MaybeMockedConstructor<T> & {
|
|
809
|
-
[K in
|
|
920
|
+
[K in Methods<T>]: T[K] extends Procedure ? MockedFunction<T[K]> : T[K];
|
|
810
921
|
} & {
|
|
811
|
-
[K in
|
|
922
|
+
[K in Properties<T>]: T[K];
|
|
812
923
|
};
|
|
813
924
|
declare type MockedObjectDeep<T> = MaybeMockedConstructor<T> & {
|
|
814
|
-
[K in
|
|
925
|
+
[K in Methods<T>]: T[K] extends Procedure ? MockedFunctionDeep<T[K]> : T[K];
|
|
815
926
|
} & {
|
|
816
|
-
[K in
|
|
927
|
+
[K in Properties<T>]: MaybeMockedDeep<T[K]>;
|
|
817
928
|
};
|
|
818
|
-
declare type MaybeMockedDeep<T> = T extends
|
|
819
|
-
declare type MaybeMocked<T> = T extends
|
|
929
|
+
declare type MaybeMockedDeep<T> = T extends Procedure ? MockedFunctionDeep<T> : T extends object ? MockedObjectDeep<T> : T;
|
|
930
|
+
declare type MaybeMocked<T> = T extends Procedure ? MockedFunction<T> : T extends object ? MockedObject<T> : T;
|
|
820
931
|
declare type EnhancedSpy<TArgs extends any[] = any[], TReturns = any> = JestMockCompat<TArgs, TReturns> & SpyImpl<TArgs, TReturns>;
|
|
821
|
-
interface MockWithArgs<T extends
|
|
822
|
-
new (...args:
|
|
823
|
-
(...args:
|
|
932
|
+
interface MockWithArgs<T extends Procedure> extends JestMockCompatFn<Parameters<T>, ReturnType<T>> {
|
|
933
|
+
new (...args: T extends new (...args: any) => any ? ConstructorParameters<T> : never): T;
|
|
934
|
+
(...args: Parameters<T>): ReturnType<T>;
|
|
824
935
|
}
|
|
825
936
|
declare const spies: Set<JestMockCompat<any[], any>>;
|
|
826
937
|
declare function isMockFunction(fn: any): fn is EnhancedSpy;
|
|
827
|
-
declare function spyOn<T,
|
|
828
|
-
declare
|
|
938
|
+
declare function spyOn<T, S extends Properties<Required<T>>>(obj: T, methodName: S, accesType: 'get'): JestMockCompat<[T[S]], void>;
|
|
939
|
+
declare function spyOn<T, G extends Properties<Required<T>>>(obj: T, methodName: G, accesType: 'set'): JestMockCompat<[], T[G]>;
|
|
940
|
+
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;
|
|
941
|
+
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;
|
|
829
942
|
declare function fn<TArgs extends any[] = any[], R = any>(): JestMockCompatFn<TArgs, R>;
|
|
830
943
|
declare function fn<TArgs extends any[] = any[], R = any>(implementation: (...args: TArgs) => R): JestMockCompatFn<TArgs, R>;
|
|
831
944
|
|
|
@@ -952,7 +1065,9 @@ declare global {
|
|
|
952
1065
|
not: AsymmetricMatchersContaining;
|
|
953
1066
|
}
|
|
954
1067
|
interface JestAssertions {
|
|
1068
|
+
toMatchSnapshot(snapshot: object, message?: string): void;
|
|
955
1069
|
toMatchSnapshot(message?: string): void;
|
|
1070
|
+
toMatchInlineSnapshot(properties: object, snapshot?: string, message?: string): void;
|
|
956
1071
|
toMatchInlineSnapshot(snapshot?: string, message?: string): void;
|
|
957
1072
|
toThrowErrorMatchingSnapshot(message?: string): void;
|
|
958
1073
|
toThrowErrorMatchingInlineSnapshot(snapshot?: string, message?: string): void;
|
|
@@ -1013,4 +1128,4 @@ declare global {
|
|
|
1013
1128
|
}
|
|
1014
1129
|
}
|
|
1015
1130
|
|
|
1016
|
-
export { ApiConfig,
|
|
1131
|
+
export { ApiConfig, ArgumentsType, Arrayable, Awaitable, BuiltinEnvironment, DoneCallback, EnhancedSpy, Environment, EnvironmentReturn, ErrorWithDiff, File, HookListener, InlineConfig, JestMockCompat, JestMockCompatContext, JestMockCompatFn, MaybeMocked, MaybeMockedConstructor, MaybeMockedDeep, MockWithArgs, MockedFunction, MockedFunctionDeep, MockedObject, MockedObjectDeep, ModuleCache, Nullable, ParsedStack, Position, Reporter, ResolvedConfig, RunMode, RuntimeContext, SnapshotData, SnapshotMatchOptions, SnapshotResult, SnapshotStateOptions, SnapshotSummary, SnapshotUpdateState, Suite, SuiteCollector, SuiteHooks, Task, TaskBase, TaskResult, TaskResultPack, TaskState, Test, TestCollector, TestFactory, TestFunction, UncheckedSnapshot, UserConfig, UserConsoleLog, WebSocketEvents, WebSocketHandlers, WorkerContext, WorkerRPC, afterAll, afterEach, beforeAll, beforeEach, describe, expect, fn, isMockFunction, it, spies, spyOn, suite, test, vi, vitest };
|
package/dist/index.js
CHANGED
|
@@ -1,11 +1,12 @@
|
|
|
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-aec007e7.js';
|
|
2
|
+
export { a as afterAll, d as afterEach, b as beforeAll, c as beforeEach, e as expect } from './index-354a6abd.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-720a83c6.js';
|
|
6
6
|
import 'url';
|
|
7
7
|
import 'tty';
|
|
8
8
|
import 'local-pkg';
|
|
9
9
|
import 'path';
|
|
10
10
|
import './_commonjsHelpers-c9e3b764.js';
|
|
11
11
|
import 'tinyspy';
|
|
12
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VzIjpbXSwic291cmNlc0NvbnRlbnQiOltdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7OyJ9
|
|
@@ -91,3 +91,4 @@ function fn(implementation) {
|
|
|
91
91
|
}
|
|
92
92
|
|
|
93
93
|
export { spyOn as a, fn as f, isMockFunction as i, spies as s };
|
|
94
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"jest-mock-30625866.js","sources":["../src/integrations/jest-mock.ts"],"sourcesContent":["import { util } from 'chai'\nimport type { SpyImpl } from 'tinyspy'\nimport * as tinyspy from 'tinyspy'\n\ninterface MockResultReturn<T> {\n  type: 'return'\n  value: T\n}\ninterface MockResultIncomplete {\n  type: 'incomplete'\n  value: undefined\n}\ninterface MockResultThrow {\n  type: 'throw'\n  value: any\n}\n\ntype MockResult<T> = MockResultReturn<T> | MockResultThrow | MockResultIncomplete\n\nexport interface JestMockCompatContext<T, Y> {\n  calls: Y[]\n  instances: T[]\n  // TODO: doesn't work\n  invocationCallOrder: number[]\n  results: MockResult<T>[]\n}\n\ntype Procedure = (...args: any[]) => any\n\ntype Methods<T> = {\n  [K in keyof T]: T[K] extends Procedure ? K : never\n}[keyof T] & string\ntype Properties<T> = {\n  [K in keyof T]: T[K] extends Procedure ? never : K\n}[keyof T] & string\ntype Classes<T> = {\n  [K in keyof T]: T[K] extends new (...args: any[]) => any ? K : never\n}[keyof T] & string\n\nexport interface JestMockCompat<TArgs extends any[] = any[], TReturns = any> {\n  getMockName(): string\n  mockName(n: string): this\n  mock: JestMockCompatContext<TArgs, TReturns>\n  mockClear(): this\n  mockReset(): this\n  mockRestore(): void\n  getMockImplementation(): ((...args: TArgs) => TReturns) | undefined\n  mockImplementation(fn: ((...args: TArgs) => TReturns) | (() => Promise<TReturns>)): this\n  mockImplementationOnce(fn: ((...args: TArgs) => TReturns) | (() => Promise<TReturns>)): this\n  mockReturnThis(): this\n  mockReturnValue(obj: TReturns): this\n  mockReturnValueOnce(obj: TReturns): this\n  mockResolvedValue(obj: Awaited<TReturns>): this\n  mockResolvedValueOnce(obj: Awaited<TReturns>): this\n  mockRejectedValue(obj: any): this\n  mockRejectedValueOnce(obj: any): this\n}\n\nexport interface JestMockCompatFn<TArgs extends any[] = any, TReturns = any> extends JestMockCompat<TArgs, TReturns> {\n  (...args: TArgs): TReturns\n}\n\nexport type MaybeMockedConstructor<T> = T extends new (\n  ...args: Array<any>\n) => infer R\n  ? JestMockCompatFn<ConstructorParameters<T>, R>\n  : T\nexport type MockedFunction<T extends Procedure> = MockWithArgs<T> & {\n  [K in keyof T]: T[K];\n}\nexport type MockedFunctionDeep<T extends Procedure> = MockWithArgs<T> & MockedObjectDeep<T>\nexport type MockedObject<T> = MaybeMockedConstructor<T> & {\n  [K in Methods<T>]: T[K] extends Procedure\n    ? MockedFunction<T[K]>\n    : T[K];\n} & {[K in Properties<T>]: T[K]}\nexport type MockedObjectDeep<T> = MaybeMockedConstructor<T> & {\n  [K in Methods<T>]: T[K] extends Procedure\n    ? MockedFunctionDeep<T[K]>\n    : T[K];\n} & {[K in Properties<T>]: MaybeMockedDeep<T[K]>}\n\nexport type MaybeMockedDeep<T> = T extends Procedure\n  ? MockedFunctionDeep<T>\n  : T extends object\n    ? MockedObjectDeep<T>\n    : T\n\nexport type MaybeMocked<T> = T extends Procedure\n  ? MockedFunction<T>\n  : T extends object\n    ? MockedObject<T>\n    : T\n\nexport type EnhancedSpy<TArgs extends any[] = any[], TReturns = any> = JestMockCompat<TArgs, TReturns> & SpyImpl<TArgs, TReturns>\n\nexport interface MockWithArgs<T extends Procedure>\n  extends JestMockCompatFn<Parameters<T>, ReturnType<T>> {\n  new (...args: T extends new (...args: any) => any ? ConstructorParameters<T> : never): T\n  (...args: Parameters<T>): ReturnType<T>\n}\n\nexport const spies = new Set<JestMockCompat>()\n\nexport function isMockFunction(fn: any): fn is EnhancedSpy {\n  return typeof fn === 'function'\n  && '__isSpy' in fn\n  && fn.__isSpy\n}\n\nexport function spyOn<T, S extends Properties<Required<T>>>(\n  obj: T,\n  methodName: S,\n  accesType: 'get',\n): JestMockCompat<[T[S]], void>\nexport function spyOn<T, G extends Properties<Required<T>>>(\n  obj: T,\n  methodName: G,\n  accesType: 'set',\n): JestMockCompat<[], T[G]>\nexport function spyOn<T, M extends Classes<Required<T>>>(\n  object: T,\n  method: M\n): Required<T>[M] extends new (...args: infer A) => infer R\n  ? JestMockCompat<A, R>\n  : never\nexport function spyOn<T, M extends Methods<Required<T>>>(\n  obj: T,\n  methodName: M,\n  mock?: T[M]\n): Required<T>[M] extends (...args: infer A) => infer R ? JestMockCompat<A, R> : never\nexport function spyOn<T, K extends keyof T>(\n  obj: T,\n  method: K,\n  accessType?: 'get' | 'set',\n): JestMockCompat {\n  const dictionary = {\n    get: 'getter',\n    set: 'setter',\n  } as const\n  const objMethod = accessType ? { [dictionary[accessType]]: method } : method\n\n  const stub = tinyspy.spyOn(obj, objMethod as any)\n\n  return enhanceSpy(stub) as JestMockCompat\n}\n\nfunction enhanceSpy<TArgs extends any[], TReturns>(\n  spy: SpyImpl<TArgs, TReturns>,\n): JestMockCompat<TArgs, TReturns> {\n  const stub = spy as unknown as EnhancedSpy<TArgs, TReturns>\n\n  let implementation: ((...args: TArgs) => TReturns) | undefined\n\n  const instances: any[] = []\n\n  const mockContext = {\n    get calls() {\n      return stub.calls\n    },\n    get instances() {\n      return instances\n    },\n    // not supported\n    get invocationCallOrder() {\n      return []\n    },\n    get results() {\n      return stub.results.map(([callType, value]) => {\n        const type = callType === 'error' ? 'throw' : 'return'\n        return { type, value }\n      })\n    },\n  }\n\n  let onceImplementations: ((...args: TArgs) => TReturns)[] = []\n\n  let name: string = (stub as any).name\n\n  stub.getMockName = () => name || 'vi.fn()'\n  stub.mockName = (n) => {\n    name = n\n    return stub\n  }\n\n  stub.mockClear = () => {\n    stub.reset()\n    return stub\n  }\n\n  stub.mockReset = () => {\n    stub.reset()\n    implementation = () => undefined as unknown as TReturns\n    onceImplementations = []\n    return stub\n  }\n\n  stub.mockRestore = () => {\n    stub.mockReset()\n    implementation = undefined\n    return stub\n  }\n\n  stub.getMockImplementation = () => implementation\n  stub.mockImplementation = (fn: (...args: TArgs) => TReturns) => {\n    implementation = fn\n    return stub\n  }\n\n  stub.mockImplementationOnce = (fn: (...args: TArgs) => TReturns) => {\n    onceImplementations.push(fn)\n    return stub\n  }\n\n  stub.mockReturnThis = () =>\n    stub.mockImplementation(function(this: TReturns) {\n      return this\n    })\n\n  stub.mockReturnValue = (val: TReturns) => stub.mockImplementation(() => val)\n  stub.mockReturnValueOnce = (val: TReturns) => stub.mockImplementationOnce(() => val)\n\n  stub.mockResolvedValue = (val: Awaited<TReturns>) =>\n    stub.mockImplementation(() => Promise.resolve(val as TReturns))\n\n  stub.mockResolvedValueOnce = (val: Awaited<TReturns>) =>\n    stub.mockImplementationOnce(() => Promise.resolve(val as TReturns))\n\n  stub.mockRejectedValue = (val: unknown) =>\n    stub.mockImplementation(() => Promise.reject(val))\n\n  stub.mockRejectedValueOnce = (val: unknown) =>\n    stub.mockImplementationOnce(() => Promise.reject(val))\n\n  util.addProperty(stub, 'mock', () => mockContext)\n\n  stub.willCall(function(this: unknown, ...args) {\n    instances.push(this)\n    const impl = onceImplementations.shift() || implementation || stub.getOriginal() || (() => {})\n    return impl.apply(this, args)\n  })\n\n  spies.add(stub)\n\n  return stub as any\n}\n\nexport function fn<TArgs extends any[] = any[], R = any>(): JestMockCompatFn<TArgs, R>\nexport function fn<TArgs extends any[] = any[], R = any>(\n  implementation: (...args: TArgs) => R\n): JestMockCompatFn<TArgs, R>\nexport function fn<TArgs extends any[] = any[], R = any>(\n  implementation?: (...args: TArgs) => R,\n): JestMockCompatFn<TArgs, R> {\n  return enhanceSpy(tinyspy.spyOn({ fn: implementation || (() => {}) }, 'fn')) as unknown as JestMockCompatFn\n}\n"],"names":[],"mappings":"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"}
|