vitest 0.2.3 → 0.2.7
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 +34 -5
- package/dist/{_commonjsHelpers-bdec4bbd.js → _commonjsHelpers-c9e3b764.js} +6 -2
- package/dist/cli.js +1089 -20
- package/dist/client-f15310bf.js +9442 -0
- package/dist/create-bc179830.js +9208 -0
- package/dist/{diff-abc9f1a4.js → diff-275cfd15.js} +3 -3
- package/dist/entry.js +139 -100
- package/dist/{globals-67f38862.js → globals-1e6cf014.js} +8 -8
- package/dist/{index-6102d563.js → index-08faa6e3.js} +3 -3
- package/dist/index-26cb6e63.js +1644 -0
- package/dist/{index-87602a5a.js → index-2e2d319c.js} +2 -2
- package/dist/index-4cd25949.js +782 -0
- package/dist/index-7975be53.js +331 -0
- package/dist/index.d.ts +132 -98
- package/dist/index.js +7 -7
- package/dist/jest-mock.js +99 -0
- package/dist/node.d.ts +67 -56
- package/dist/node.js +9 -8
- package/dist/setup-cb313f20.js +4402 -0
- package/dist/{source-map-002462f4.js → source-map-799c200a.js} +2 -2
- package/dist/vi-ec8761e0.js +5916 -0
- package/dist/worker.js +19 -177
- package/package.json +16 -15
- package/dist/create-b3e0df3f.js +0 -9169
- package/dist/index-0c3a317d.js +0 -2411
- package/dist/index-1085cee5.js +0 -9288
- package/dist/index-825cb54c.js +0 -331
- package/dist/jest-mock-113430de.js +0 -99
- package/dist/setup-0edb4bff.js +0 -4389
- package/dist/vi-7f0c5d26.js +0 -5750
package/dist/index.d.ts
CHANGED
|
@@ -1,5 +1,4 @@
|
|
|
1
1
|
import { ViteDevServer, TransformResult, CommonServerOptions } from 'vite';
|
|
2
|
-
import { Profiler } from 'inspector';
|
|
3
2
|
import { MessagePort } from 'worker_threads';
|
|
4
3
|
import { SpyImpl } from 'tinyspy';
|
|
5
4
|
export { assert, default as chai, should } from 'chai';
|
|
@@ -228,11 +227,6 @@ declare class Any extends AsymmetricMatcher<any> {
|
|
|
228
227
|
toAsymmetricMatcher(): string;
|
|
229
228
|
}
|
|
230
229
|
|
|
231
|
-
interface FetchResult$1 {
|
|
232
|
-
code?: string;
|
|
233
|
-
externalize?: string;
|
|
234
|
-
}
|
|
235
|
-
|
|
236
230
|
interface DepsHandlingOptions {
|
|
237
231
|
external?: (string | RegExp)[];
|
|
238
232
|
inline?: (string | RegExp)[];
|
|
@@ -242,6 +236,22 @@ interface DepsHandlingOptions {
|
|
|
242
236
|
*/
|
|
243
237
|
fallbackCJS?: boolean;
|
|
244
238
|
}
|
|
239
|
+
interface StartOfSourceMap$1 {
|
|
240
|
+
file?: string;
|
|
241
|
+
sourceRoot?: string;
|
|
242
|
+
}
|
|
243
|
+
interface RawSourceMap$1 extends StartOfSourceMap$1 {
|
|
244
|
+
version: string;
|
|
245
|
+
sources: string[];
|
|
246
|
+
names: string[];
|
|
247
|
+
sourcesContent?: string[];
|
|
248
|
+
mappings: string;
|
|
249
|
+
}
|
|
250
|
+
interface FetchResult$1 {
|
|
251
|
+
code?: string;
|
|
252
|
+
externalize?: string;
|
|
253
|
+
map?: RawSourceMap$1;
|
|
254
|
+
}
|
|
245
255
|
interface ViteNodeResolveId$1 {
|
|
246
256
|
external?: boolean | 'absolute' | 'relative';
|
|
247
257
|
id: string;
|
|
@@ -252,9 +262,9 @@ interface ViteNodeResolveId$1 {
|
|
|
252
262
|
interface ViteNodeServerOptions {
|
|
253
263
|
/**
|
|
254
264
|
* Inject inline sourcemap to modules
|
|
255
|
-
* @default
|
|
265
|
+
* @default 'inline'
|
|
256
266
|
*/
|
|
257
|
-
sourcemap?: boolean;
|
|
267
|
+
sourcemap?: 'inline' | boolean;
|
|
258
268
|
/**
|
|
259
269
|
* Deps handling
|
|
260
270
|
*/
|
|
@@ -273,7 +283,10 @@ declare class ViteNodeServer {
|
|
|
273
283
|
options: ViteNodeServerOptions;
|
|
274
284
|
private fetchPromiseMap;
|
|
275
285
|
private transformPromiseMap;
|
|
276
|
-
|
|
286
|
+
fetchCache: Map<string, {
|
|
287
|
+
timestamp: number;
|
|
288
|
+
result: FetchResult$1;
|
|
289
|
+
}>;
|
|
277
290
|
constructor(server: ViteDevServer, options?: ViteNodeServerOptions);
|
|
278
291
|
shouldExternalize(id: string): Promise<string | false>;
|
|
279
292
|
resolveId(id: string, importer?: string): Promise<ViteNodeResolveId$1 | null>;
|
|
@@ -318,7 +331,6 @@ declare class Vitest {
|
|
|
318
331
|
server: ViteDevServer;
|
|
319
332
|
state: StateManager;
|
|
320
333
|
snapshot: SnapshotManager;
|
|
321
|
-
coverage: Profiler.TakePreciseCoverageReturnType[];
|
|
322
334
|
reporters: Reporter[];
|
|
323
335
|
console: Console;
|
|
324
336
|
pool: WorkerPool | undefined;
|
|
@@ -331,7 +343,6 @@ declare class Vitest {
|
|
|
331
343
|
vitenode: ViteNodeServer;
|
|
332
344
|
invalidates: Set<string>;
|
|
333
345
|
changedTests: Set<string>;
|
|
334
|
-
visitedFilesMap: Map<string, RawSourceMap>;
|
|
335
346
|
runningPromise?: Promise<void>;
|
|
336
347
|
closingPromise?: Promise<void>;
|
|
337
348
|
isFirstRun: boolean;
|
|
@@ -472,6 +483,65 @@ declare const ReportersMap: {
|
|
|
472
483
|
};
|
|
473
484
|
declare type BuiltinReporters = keyof typeof ReportersMap;
|
|
474
485
|
|
|
486
|
+
declare type Awaitable<T> = T | PromiseLike<T>;
|
|
487
|
+
declare type Nullable<T> = T | null | undefined;
|
|
488
|
+
declare type Arrayable<T> = T | Array<T>;
|
|
489
|
+
declare type ArgumentsType<T> = T extends (...args: infer U) => any ? U : never;
|
|
490
|
+
declare type MergeInsertions<T> = T extends object ? {
|
|
491
|
+
[K in keyof T]: MergeInsertions<T[K]>;
|
|
492
|
+
} : T;
|
|
493
|
+
declare type DeepMerge<F, S> = MergeInsertions<{
|
|
494
|
+
[K in keyof F | keyof S]: K extends keyof S & keyof F ? DeepMerge<F[K], S[K]> : K extends keyof S ? S[K] : K extends keyof F ? F[K] : never;
|
|
495
|
+
}>;
|
|
496
|
+
interface Constructable {
|
|
497
|
+
new (...args: any[]): any;
|
|
498
|
+
}
|
|
499
|
+
interface ModuleCache {
|
|
500
|
+
promise?: Promise<any>;
|
|
501
|
+
exports?: any;
|
|
502
|
+
code?: string;
|
|
503
|
+
}
|
|
504
|
+
interface EnvironmentReturn {
|
|
505
|
+
teardown: (global: any) => Awaitable<void>;
|
|
506
|
+
}
|
|
507
|
+
interface Environment {
|
|
508
|
+
name: string;
|
|
509
|
+
setup(global: any, options: Record<string, any>): Awaitable<EnvironmentReturn>;
|
|
510
|
+
}
|
|
511
|
+
interface UserConsoleLog {
|
|
512
|
+
content: string;
|
|
513
|
+
type: 'stdout' | 'stderr';
|
|
514
|
+
taskId?: string;
|
|
515
|
+
time: number;
|
|
516
|
+
}
|
|
517
|
+
interface Position {
|
|
518
|
+
line: number;
|
|
519
|
+
column: number;
|
|
520
|
+
}
|
|
521
|
+
interface ParsedStack {
|
|
522
|
+
method: string;
|
|
523
|
+
file: string;
|
|
524
|
+
line: number;
|
|
525
|
+
column: number;
|
|
526
|
+
sourcePos?: Position;
|
|
527
|
+
}
|
|
528
|
+
interface ErrorWithDiff extends Error {
|
|
529
|
+
name: string;
|
|
530
|
+
nameStr?: string;
|
|
531
|
+
stack?: string;
|
|
532
|
+
stackStr?: string;
|
|
533
|
+
stacks?: ParsedStack[];
|
|
534
|
+
showDiff?: boolean;
|
|
535
|
+
actual?: any;
|
|
536
|
+
expected?: any;
|
|
537
|
+
operator?: string;
|
|
538
|
+
}
|
|
539
|
+
interface ModuleGraphData {
|
|
540
|
+
graph: Record<string, string[]>;
|
|
541
|
+
externalized: string[];
|
|
542
|
+
inlined: string[];
|
|
543
|
+
}
|
|
544
|
+
|
|
475
545
|
declare type CoverageReporter = 'clover' | 'cobertura' | 'html-spa' | 'html' | 'json-summary' | 'json' | 'lcov' | 'lcovonly' | 'none' | 'teamcity' | 'text-lcov' | 'text-summary' | 'text';
|
|
476
546
|
interface C8Options {
|
|
477
547
|
/**
|
|
@@ -521,6 +591,7 @@ interface C8Options {
|
|
|
521
591
|
all?: boolean;
|
|
522
592
|
}
|
|
523
593
|
interface ResolvedC8Options extends Required<C8Options> {
|
|
594
|
+
tempDirectory: string;
|
|
524
595
|
}
|
|
525
596
|
|
|
526
597
|
interface JSDOMOptions {
|
|
@@ -603,76 +674,6 @@ interface JSDOMOptions {
|
|
|
603
674
|
resources?: 'usable' | any;
|
|
604
675
|
}
|
|
605
676
|
|
|
606
|
-
declare type Awaitable<T> = T | PromiseLike<T>;
|
|
607
|
-
declare type Nullable<T> = T | null | undefined;
|
|
608
|
-
declare type Arrayable<T> = T | Array<T>;
|
|
609
|
-
declare type ArgumentsType<T> = T extends (...args: infer U) => any ? U : never;
|
|
610
|
-
declare type MergeInsertions<T> = T extends object ? {
|
|
611
|
-
[K in keyof T]: MergeInsertions<T[K]>;
|
|
612
|
-
} : T;
|
|
613
|
-
declare type DeepMerge<F, S> = MergeInsertions<{
|
|
614
|
-
[K in keyof F | keyof S]: K extends keyof S & keyof F ? DeepMerge<F[K], S[K]> : K extends keyof S ? S[K] : K extends keyof F ? F[K] : never;
|
|
615
|
-
}>;
|
|
616
|
-
interface Constructable {
|
|
617
|
-
new (...args: any[]): any;
|
|
618
|
-
}
|
|
619
|
-
interface ModuleCache {
|
|
620
|
-
promise?: Promise<any>;
|
|
621
|
-
exports?: any;
|
|
622
|
-
code?: string;
|
|
623
|
-
}
|
|
624
|
-
interface EnvironmentReturn {
|
|
625
|
-
teardown: (global: any) => Awaitable<void>;
|
|
626
|
-
}
|
|
627
|
-
interface Environment {
|
|
628
|
-
name: string;
|
|
629
|
-
setup(global: any, options: Record<string, any>): Awaitable<EnvironmentReturn>;
|
|
630
|
-
}
|
|
631
|
-
interface UserConsoleLog {
|
|
632
|
-
content: string;
|
|
633
|
-
type: 'stdout' | 'stderr';
|
|
634
|
-
taskId?: string;
|
|
635
|
-
time: number;
|
|
636
|
-
}
|
|
637
|
-
interface Position {
|
|
638
|
-
line: number;
|
|
639
|
-
column: number;
|
|
640
|
-
}
|
|
641
|
-
interface ParsedStack {
|
|
642
|
-
method: string;
|
|
643
|
-
file: string;
|
|
644
|
-
line: number;
|
|
645
|
-
column: number;
|
|
646
|
-
sourcePos?: Position;
|
|
647
|
-
}
|
|
648
|
-
interface ErrorWithDiff extends Error {
|
|
649
|
-
name: string;
|
|
650
|
-
nameStr?: string;
|
|
651
|
-
stack?: string;
|
|
652
|
-
stackStr?: string;
|
|
653
|
-
stacks?: ParsedStack[];
|
|
654
|
-
showDiff?: boolean;
|
|
655
|
-
actual?: any;
|
|
656
|
-
expected?: any;
|
|
657
|
-
operator?: string;
|
|
658
|
-
}
|
|
659
|
-
interface ModuleGraphData {
|
|
660
|
-
graph: Record<string, string[]>;
|
|
661
|
-
externalized: string[];
|
|
662
|
-
inlined: string[];
|
|
663
|
-
}
|
|
664
|
-
interface StartOfSourceMap {
|
|
665
|
-
file?: string;
|
|
666
|
-
sourceRoot?: string;
|
|
667
|
-
}
|
|
668
|
-
interface RawSourceMap extends StartOfSourceMap {
|
|
669
|
-
version: string;
|
|
670
|
-
sources: string[];
|
|
671
|
-
names: string[];
|
|
672
|
-
sourcesContent?: string[];
|
|
673
|
-
mappings: string;
|
|
674
|
-
}
|
|
675
|
-
|
|
676
677
|
declare type ChainableFunction<T extends string, Args extends any[], R = any> = {
|
|
677
678
|
(...args: Args): R;
|
|
678
679
|
} & {
|
|
@@ -714,11 +715,20 @@ interface Test extends TaskBase {
|
|
|
714
715
|
declare type Task = Test | Suite | File;
|
|
715
716
|
declare type DoneCallback = (error?: any) => void;
|
|
716
717
|
declare type TestFunction = (done: DoneCallback) => Awaitable<void>;
|
|
717
|
-
declare type
|
|
718
|
+
declare type EachFunction = <T>(cases: T[]) => (name: string, fn: (...args: T extends any[] ? T : [T]) => void) => void;
|
|
719
|
+
declare type TestAPI = ChainableFunction<'concurrent' | 'only' | 'skip' | 'todo' | 'fails', [
|
|
718
720
|
name: string,
|
|
719
721
|
fn?: TestFunction,
|
|
720
722
|
timeout?: number
|
|
721
|
-
], void
|
|
723
|
+
], void> & {
|
|
724
|
+
each: EachFunction;
|
|
725
|
+
};
|
|
726
|
+
declare type SuiteAPI = ChainableFunction<'concurrent' | 'only' | 'skip' | 'todo', [
|
|
727
|
+
name: string,
|
|
728
|
+
factory?: SuiteFactory
|
|
729
|
+
], SuiteCollector> & {
|
|
730
|
+
each: EachFunction;
|
|
731
|
+
};
|
|
722
732
|
declare type HookListener<T extends any[]> = (...args: T) => Awaitable<void>;
|
|
723
733
|
interface SuiteHooks {
|
|
724
734
|
beforeAll: HookListener<[Suite]>[];
|
|
@@ -730,13 +740,13 @@ interface SuiteCollector {
|
|
|
730
740
|
readonly name: string;
|
|
731
741
|
readonly mode: RunMode;
|
|
732
742
|
type: 'collector';
|
|
733
|
-
test:
|
|
743
|
+
test: TestAPI;
|
|
734
744
|
tasks: (Suite | Test | SuiteCollector)[];
|
|
735
745
|
collect: (file?: File) => Promise<Suite>;
|
|
736
746
|
clear: () => void;
|
|
737
747
|
on: <T extends keyof SuiteHooks>(name: T, ...fn: SuiteHooks[T]) => void;
|
|
738
748
|
}
|
|
739
|
-
declare type
|
|
749
|
+
declare type SuiteFactory = (test: (name: string, fn: TestFunction) => void) => Awaitable<void>;
|
|
740
750
|
interface RuntimeContext {
|
|
741
751
|
tasks: (SuiteCollector | Test)[];
|
|
742
752
|
currentSuite: SuiteCollector | null;
|
|
@@ -990,10 +1000,16 @@ interface InlineConfig {
|
|
|
990
1000
|
*/
|
|
991
1001
|
api?: boolean | number | ApiConfig;
|
|
992
1002
|
/**
|
|
993
|
-
*
|
|
1003
|
+
* Enable Vitest UI
|
|
994
1004
|
* @internal WIP
|
|
995
1005
|
*/
|
|
996
1006
|
ui?: boolean;
|
|
1007
|
+
/**
|
|
1008
|
+
* Open UI automatically.
|
|
1009
|
+
*
|
|
1010
|
+
* @default true
|
|
1011
|
+
*/
|
|
1012
|
+
open?: boolean;
|
|
997
1013
|
/**
|
|
998
1014
|
* Base url for the UI
|
|
999
1015
|
*
|
|
@@ -1048,6 +1064,10 @@ interface UserConfig extends InlineConfig {
|
|
|
1048
1064
|
* Pass with no tests
|
|
1049
1065
|
*/
|
|
1050
1066
|
passWithNoTests?: boolean;
|
|
1067
|
+
/**
|
|
1068
|
+
* Allow tests and suites that are marked as only
|
|
1069
|
+
*/
|
|
1070
|
+
allowOnly?: boolean;
|
|
1051
1071
|
/**
|
|
1052
1072
|
* Run tests that cover a list of source files
|
|
1053
1073
|
*/
|
|
@@ -1064,9 +1084,21 @@ interface ResolvedConfig extends Omit<Required<UserConfig>, 'config' | 'filters'
|
|
|
1064
1084
|
api?: ApiConfig;
|
|
1065
1085
|
}
|
|
1066
1086
|
|
|
1087
|
+
interface StartOfSourceMap {
|
|
1088
|
+
file?: string;
|
|
1089
|
+
sourceRoot?: string;
|
|
1090
|
+
}
|
|
1091
|
+
interface RawSourceMap extends StartOfSourceMap {
|
|
1092
|
+
version: string;
|
|
1093
|
+
sources: string[];
|
|
1094
|
+
names: string[];
|
|
1095
|
+
sourcesContent?: string[];
|
|
1096
|
+
mappings: string;
|
|
1097
|
+
}
|
|
1067
1098
|
interface FetchResult {
|
|
1068
1099
|
code?: string;
|
|
1069
1100
|
externalize?: string;
|
|
1101
|
+
map?: RawSourceMap;
|
|
1070
1102
|
}
|
|
1071
1103
|
declare type FetchFunction = (id: string) => Promise<FetchResult>;
|
|
1072
1104
|
interface ViteNodeResolveId {
|
|
@@ -1094,13 +1126,12 @@ interface WorkerRPC {
|
|
|
1094
1126
|
onCollected: (files: File[]) => void;
|
|
1095
1127
|
onTaskUpdate: (pack: TaskResultPack[]) => void;
|
|
1096
1128
|
snapshotSaved: (snapshot: SnapshotResult) => void;
|
|
1097
|
-
coverageCollected: (coverage: Profiler.TakePreciseCoverageReturnType) => void;
|
|
1098
1129
|
}
|
|
1099
1130
|
|
|
1100
|
-
declare const suite:
|
|
1101
|
-
declare const test:
|
|
1102
|
-
declare const describe:
|
|
1103
|
-
declare const it:
|
|
1131
|
+
declare const suite: SuiteAPI;
|
|
1132
|
+
declare const test: TestAPI;
|
|
1133
|
+
declare const describe: SuiteAPI;
|
|
1134
|
+
declare const it: TestAPI;
|
|
1104
1135
|
|
|
1105
1136
|
declare const beforeAll: (fn: SuiteHooks['beforeAll'][0], timeout?: number | undefined) => void;
|
|
1106
1137
|
declare const afterAll: (fn: SuiteHooks['afterAll'][0], timeout?: number | undefined) => void;
|
|
@@ -1185,8 +1216,7 @@ declare const spies: Set<SpyInstance<any[], any>>;
|
|
|
1185
1216
|
declare function isMockFunction(fn: any): fn is EnhancedSpy;
|
|
1186
1217
|
declare function spyOn<T, S extends Properties<Required<T>>>(obj: T, methodName: S, accesType: 'get'): SpyInstance<[], T[S]>;
|
|
1187
1218
|
declare function spyOn<T, G extends Properties<Required<T>>>(obj: T, methodName: G, accesType: 'set'): SpyInstance<[T[G]], void>;
|
|
1188
|
-
declare function spyOn<T, M extends Classes<Required<T
|
|
1189
|
-
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 ? SpyInstance<A, R> : never;
|
|
1219
|
+
declare function spyOn<T, M extends (Methods<Required<T>> | Classes<Required<T>>)>(obj: T, methodName: M): Required<T>[M] extends (...args: infer A) => infer R | (new (...args: infer A) => infer R) ? SpyInstance<A, R> : never;
|
|
1190
1220
|
declare function fn<TArgs extends any[] = any[], R = any>(): SpyInstanceFn<TArgs, R>;
|
|
1191
1221
|
declare function fn<TArgs extends any[] = any[], R = any>(implementation: (...args: TArgs) => R): SpyInstanceFn<TArgs, R>;
|
|
1192
1222
|
|
|
@@ -1312,6 +1342,10 @@ declare type Promisify<O> = {
|
|
|
1312
1342
|
[K in keyof O]: O[K] extends (...args: infer A) => infer R ? O extends R ? Promisify<O[K]> : (...args: A) => Promise<R> : O[K];
|
|
1313
1343
|
};
|
|
1314
1344
|
declare global {
|
|
1345
|
+
namespace jest {
|
|
1346
|
+
interface Matchers<R, T = {}> {
|
|
1347
|
+
}
|
|
1348
|
+
}
|
|
1315
1349
|
namespace Vi {
|
|
1316
1350
|
interface ExpectStatic extends Chai.ExpectStatic, AsymmetricMatchersContaining {
|
|
1317
1351
|
<T>(actual: T, message?: string): Vi.Assertion<T>;
|
|
@@ -1325,7 +1359,7 @@ declare global {
|
|
|
1325
1359
|
setState(state: Partial<MatcherState>): void;
|
|
1326
1360
|
not: AsymmetricMatchersContaining;
|
|
1327
1361
|
}
|
|
1328
|
-
interface JestAssertion<T = any> {
|
|
1362
|
+
interface JestAssertion<T = any> extends jest.Matchers<void, T> {
|
|
1329
1363
|
toMatchSnapshot<U extends {
|
|
1330
1364
|
[P in keyof T]: any;
|
|
1331
1365
|
}>(snapshot: Partial<U>, message?: string): void;
|
|
@@ -1385,14 +1419,14 @@ declare global {
|
|
|
1385
1419
|
toHaveNthReturnedWith<E>(nthCall: number, value: E): void;
|
|
1386
1420
|
nthReturnedWith<E>(nthCall: number, value: E): void;
|
|
1387
1421
|
}
|
|
1388
|
-
type
|
|
1389
|
-
[K in keyof A]: A[K] extends Chai.Assertion ? Assertion<any> : A[K] extends (...args: any[]) => any ? A[K] :
|
|
1422
|
+
type VitestAssertion<A> = {
|
|
1423
|
+
[K in keyof A]: A[K] extends Chai.Assertion ? Assertion<any> : A[K] extends (...args: any[]) => any ? A[K] : VitestAssertion<A[K]>;
|
|
1390
1424
|
};
|
|
1391
|
-
interface Assertion<T = any> extends
|
|
1425
|
+
interface Assertion<T = any> extends VitestAssertion<Chai.Assertion>, JestAssertion<T> {
|
|
1392
1426
|
resolves: Promisify<Assertion<T>>;
|
|
1393
1427
|
rejects: Promisify<Assertion<T>>;
|
|
1394
1428
|
}
|
|
1395
1429
|
}
|
|
1396
1430
|
}
|
|
1397
1431
|
|
|
1398
|
-
export { ApiConfig, ArgumentsType, Arrayable, Awaitable, BuiltinEnvironment, Constructable, DeepMerge, DoneCallback, EnhancedSpy, Environment, EnvironmentOptions, EnvironmentReturn, ErrorWithDiff, File, HookListener, InlineConfig, JSDOMOptions, JestMockCompatContext, MaybeMocked, MaybeMockedConstructor, MaybeMockedDeep, MergeInsertions, MockWithArgs, MockedFunction, MockedFunctionDeep, MockedObject, MockedObjectDeep, ModuleCache, ModuleGraphData, Nullable, ParsedStack, Position,
|
|
1432
|
+
export { ApiConfig, ArgumentsType, Arrayable, Awaitable, BuiltinEnvironment, C8Options, Constructable, CoverageReporter, DeepMerge, DoneCallback, EachFunction, EnhancedSpy, Environment, EnvironmentOptions, EnvironmentReturn, ErrorWithDiff, File, HookListener, InlineConfig, JSDOMOptions, JestMockCompatContext, MaybeMocked, MaybeMockedConstructor, MaybeMockedDeep, MergeInsertions, MockWithArgs, MockedFunction, MockedFunctionDeep, MockedObject, MockedObjectDeep, ModuleCache, ModuleGraphData, Nullable, ParsedStack, Position, Reporter, ResolveIdFunction, ResolvedC8Options, ResolvedConfig, RunMode, RuntimeContext, SnapshotData, SnapshotMatchOptions, SnapshotResult, SnapshotStateOptions, SnapshotSummary, SnapshotUpdateState, SpyInstance, SpyInstanceFn, Suite, SuiteAPI, SuiteCollector, SuiteFactory, SuiteHooks, Task, TaskBase, TaskResult, TaskResultPack, TaskState, Test, TestAPI, 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,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-
|
|
3
|
-
export {
|
|
1
|
+
export { d as describe, i as it, c as suite, t as test, e as vi, v as vitest } from './vi-ec8761e0.js';
|
|
2
|
+
export { a as afterAll, d as afterEach, b as beforeAll, c as beforeEach, e as expect } from './index-08faa6e3.js';
|
|
3
|
+
export { fn, isMockFunction, spies, spyOn } from './jest-mock.js';
|
|
4
4
|
export { assert, default as chai, should } from 'chai';
|
|
5
|
-
import '
|
|
5
|
+
import 'util';
|
|
6
|
+
import './index-2e2d319c.js';
|
|
6
7
|
import 'tty';
|
|
7
8
|
import 'local-pkg';
|
|
8
|
-
import './source-map-
|
|
9
|
-
import './_commonjsHelpers-
|
|
10
|
-
import 'util';
|
|
9
|
+
import './source-map-799c200a.js';
|
|
10
|
+
import './_commonjsHelpers-c9e3b764.js';
|
|
11
11
|
import 'tinyspy';
|
|
12
12
|
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VzIjpbXSwic291cmNlc0NvbnRlbnQiOltdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7OyJ9
|
|
@@ -0,0 +1,99 @@
|
|
|
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
|
+
let callOrder = 0;
|
|
18
|
+
function enhanceSpy(spy) {
|
|
19
|
+
const stub = spy;
|
|
20
|
+
let implementation;
|
|
21
|
+
let instances = [];
|
|
22
|
+
let invocations = [];
|
|
23
|
+
const mockContext = {
|
|
24
|
+
get calls() {
|
|
25
|
+
return stub.calls;
|
|
26
|
+
},
|
|
27
|
+
get instances() {
|
|
28
|
+
return instances;
|
|
29
|
+
},
|
|
30
|
+
get invocationCallOrder() {
|
|
31
|
+
return invocations;
|
|
32
|
+
},
|
|
33
|
+
get results() {
|
|
34
|
+
return stub.results.map(([callType, value]) => {
|
|
35
|
+
const type = callType === "error" ? "throw" : "return";
|
|
36
|
+
return { type, value };
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
};
|
|
40
|
+
let onceImplementations = [];
|
|
41
|
+
let name = stub.name;
|
|
42
|
+
stub.getMockName = () => name || "vi.fn()";
|
|
43
|
+
stub.mockName = (n) => {
|
|
44
|
+
name = n;
|
|
45
|
+
return stub;
|
|
46
|
+
};
|
|
47
|
+
stub.mockClear = () => {
|
|
48
|
+
stub.reset();
|
|
49
|
+
instances = [];
|
|
50
|
+
invocations = [];
|
|
51
|
+
return stub;
|
|
52
|
+
};
|
|
53
|
+
stub.mockReset = () => {
|
|
54
|
+
stub.mockClear();
|
|
55
|
+
implementation = () => void 0;
|
|
56
|
+
onceImplementations = [];
|
|
57
|
+
return stub;
|
|
58
|
+
};
|
|
59
|
+
stub.mockRestore = () => {
|
|
60
|
+
stub.mockReset();
|
|
61
|
+
implementation = void 0;
|
|
62
|
+
return stub;
|
|
63
|
+
};
|
|
64
|
+
stub.getMockImplementation = () => implementation;
|
|
65
|
+
stub.mockImplementation = (fn2) => {
|
|
66
|
+
implementation = fn2;
|
|
67
|
+
return stub;
|
|
68
|
+
};
|
|
69
|
+
stub.mockImplementationOnce = (fn2) => {
|
|
70
|
+
onceImplementations.push(fn2);
|
|
71
|
+
return stub;
|
|
72
|
+
};
|
|
73
|
+
stub.mockReturnThis = () => stub.mockImplementation(function() {
|
|
74
|
+
return this;
|
|
75
|
+
});
|
|
76
|
+
stub.mockReturnValue = (val) => stub.mockImplementation(() => val);
|
|
77
|
+
stub.mockReturnValueOnce = (val) => stub.mockImplementationOnce(() => val);
|
|
78
|
+
stub.mockResolvedValue = (val) => stub.mockImplementation(() => Promise.resolve(val));
|
|
79
|
+
stub.mockResolvedValueOnce = (val) => stub.mockImplementationOnce(() => Promise.resolve(val));
|
|
80
|
+
stub.mockRejectedValue = (val) => stub.mockImplementation(() => Promise.reject(val));
|
|
81
|
+
stub.mockRejectedValueOnce = (val) => stub.mockImplementationOnce(() => Promise.reject(val));
|
|
82
|
+
util.addProperty(stub, "mock", () => mockContext);
|
|
83
|
+
stub.willCall(function(...args) {
|
|
84
|
+
instances.push(this);
|
|
85
|
+
invocations.push(++callOrder);
|
|
86
|
+
const impl = onceImplementations.shift() || implementation || stub.getOriginal() || (() => {
|
|
87
|
+
});
|
|
88
|
+
return impl.apply(this, args);
|
|
89
|
+
});
|
|
90
|
+
spies.add(stub);
|
|
91
|
+
return stub;
|
|
92
|
+
}
|
|
93
|
+
function fn(implementation) {
|
|
94
|
+
return enhanceSpy(tinyspy.spyOn({ fn: implementation || (() => {
|
|
95
|
+
}) }, "fn"));
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
export { fn, isMockFunction, spies, spyOn };
|
|
99
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"jest-mock.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  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 SpyInstance<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 SpyInstanceFn<TArgs extends any[] = any, TReturns = any> extends SpyInstance<TArgs, TReturns> {\n  (...args: TArgs): TReturns\n}\n\nexport type MaybeMockedConstructor<T> = T extends new (\n  ...args: Array<any>\n) => infer R\n  ? SpyInstanceFn<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> = SpyInstance<TArgs, TReturns> & SpyImpl<TArgs, TReturns>\n\nexport interface MockWithArgs<T extends Procedure>\n  extends SpyInstanceFn<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<SpyInstance>()\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): SpyInstance<[], T[S]>\nexport function spyOn<T, G extends Properties<Required<T>>>(\n  obj: T,\n  methodName: G,\n  accesType: 'set',\n): SpyInstance<[T[G]], void>\nexport function spyOn<T, M extends (Methods<Required<T>> | Classes<Required<T>>)>(\n  obj: T,\n  methodName: M,\n): Required<T>[M] extends (...args: infer A) => infer R | (new (...args: infer A) => infer R) ? SpyInstance<A, R> : never\nexport function spyOn<T, K extends keyof T>(\n  obj: T,\n  method: K,\n  accessType?: 'get' | 'set',\n): SpyInstance {\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 SpyInstance\n}\n\nlet callOrder = 0\n\nfunction enhanceSpy<TArgs extends any[], TReturns>(\n  spy: SpyImpl<TArgs, TReturns>,\n): SpyInstance<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  let invocations: number[] = []\n\n  const mockContext = {\n    get calls() {\n      return stub.calls\n    },\n    get instances() {\n      return instances\n    },\n    get invocationCallOrder() {\n      return invocations\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    invocations = []\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    invocations.push(++callOrder)\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>(): SpyInstanceFn<TArgs, R>\nexport function fn<TArgs extends any[] = any[], R = any>(\n  implementation: (...args: TArgs) => R\n): SpyInstanceFn<TArgs, R>\nexport function fn<TArgs extends any[] = any[], R = any>(\n  implementation?: (...args: TArgs) => R,\n): SpyInstanceFn<TArgs, R> {\n  return enhanceSpy(tinyspy.spyOn({ fn: implementation || (() => {}) }, 'fn')) as unknown as SpyInstanceFn\n}\n"],"names":[],"mappings":"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"}
|