vitest 0.0.133 → 0.0.137
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 +10 -10
- package/dist/{constants-0211a379.js → constants-d24b670d.js} +2 -2
- package/dist/{diff-18d4a7eb.js → diff-5dfc7eb4.js} +3 -5
- package/dist/entry.js +86 -20
- package/dist/{global-5d1fb309.js → global-f971f18f.js} +6 -6
- package/dist/{index-354a6abd.js → index-314cb4d9.js} +5 -3
- package/dist/index-5d6a5929.js +9255 -0
- package/dist/{index-7975be53.js → index-648e7ab2.js} +1 -1
- package/dist/index-64aafe4b.js +396 -0
- package/dist/index-64de1341.js +8677 -0
- package/dist/{index-4cd25949.js → index-6e709f57.js} +1 -1
- package/dist/{index-26cb6e63.js → index-ce49e384.js} +3 -3
- package/dist/index.d.ts +135 -17
- package/dist/index.js +4 -4
- package/dist/jest-mock-6c629944.js +95 -0
- package/dist/node.d.ts +111 -4
- package/dist/node.js +6 -6
- package/dist/{setup-5aaf533e.js → setup-97a1dda2.js} +49 -26
- package/dist/vi-567ba572.js +3462 -0
- package/dist/worker.js +48 -51
- package/package.json +5 -5
- package/dist/externalize-2f63779d.js +0 -9259
- package/dist/index-720a83c6.js +0 -396
- package/dist/index-7f7acd60.js +0 -8548
- package/dist/index-e909c175.js +0 -63
- package/dist/jest-mock-30625866.js +0 -94
- package/dist/vi-aec007e7.js +0 -3461
package/dist/index.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { ViteDevServer, CommonServerOptions } from 'vite';
|
|
1
|
+
import { ViteDevServer, CommonServerOptions, TransformResult } from 'vite';
|
|
2
2
|
import { MessagePort } from 'worker_threads';
|
|
3
3
|
import { SpyImpl } from 'tinyspy';
|
|
4
4
|
export { Spy, SpyFn } from 'tinyspy';
|
|
@@ -307,6 +307,7 @@ declare class Vitest {
|
|
|
307
307
|
visitedFilesMap: Map<string, RawSourceMap>;
|
|
308
308
|
runningPromise?: Promise<void>;
|
|
309
309
|
closingPromise?: Promise<void>;
|
|
310
|
+
externalizeCache: Map<string, Promise<string | false>>;
|
|
310
311
|
isFirstRun: boolean;
|
|
311
312
|
restartsCount: number;
|
|
312
313
|
private _onRestartListeners;
|
|
@@ -327,6 +328,7 @@ declare class Vitest {
|
|
|
327
328
|
report<T extends keyof Reporter>(name: T, ...args: ArgumentsType<Reporter[T]>): Promise<void>;
|
|
328
329
|
globTestFiles(filters?: string[]): Promise<string[]>;
|
|
329
330
|
isTargetFile(id: string): boolean;
|
|
331
|
+
shouldExternalize(id: string): Promise<string | false>;
|
|
330
332
|
onServerRestarted(fn: () => void): void;
|
|
331
333
|
}
|
|
332
334
|
|
|
@@ -386,9 +388,14 @@ declare class VerboseReporter extends DefaultReporter {
|
|
|
386
388
|
}
|
|
387
389
|
|
|
388
390
|
declare class TapReporter implements Reporter {
|
|
389
|
-
|
|
391
|
+
protected ctx: Vitest;
|
|
392
|
+
onInit(ctx: Vitest): void;
|
|
393
|
+
protected logTasks(tasks: Task[], currentIdent: string): void;
|
|
394
|
+
onFinished(files?: File[]): Promise<void>;
|
|
395
|
+
}
|
|
396
|
+
|
|
397
|
+
declare class TapFlatReporter extends TapReporter {
|
|
390
398
|
onInit(ctx: Vitest): void;
|
|
391
|
-
logTasks(tasks: Task[], currentIdent: string): void;
|
|
392
399
|
onFinished(files?: File[]): Promise<void>;
|
|
393
400
|
}
|
|
394
401
|
|
|
@@ -397,6 +404,7 @@ declare const ReportersMap: {
|
|
|
397
404
|
verbose: typeof VerboseReporter;
|
|
398
405
|
dot: typeof DotReporter;
|
|
399
406
|
tap: typeof TapReporter;
|
|
407
|
+
'tap-flat': typeof TapFlatReporter;
|
|
400
408
|
};
|
|
401
409
|
declare type BuiltinReporters = keyof typeof ReportersMap;
|
|
402
410
|
|
|
@@ -450,6 +458,86 @@ interface ResolvedC8Options extends Required<C8Options> {
|
|
|
450
458
|
tempDirectory: string;
|
|
451
459
|
}
|
|
452
460
|
|
|
461
|
+
interface JSDOMOptions {
|
|
462
|
+
/**
|
|
463
|
+
* The html content for the test.
|
|
464
|
+
*
|
|
465
|
+
* @default '<!DOCTYPE html>'
|
|
466
|
+
*/
|
|
467
|
+
html?: string | Buffer | ArrayBufferLike;
|
|
468
|
+
/**
|
|
469
|
+
* referrer just affects the value read from document.referrer.
|
|
470
|
+
* It defaults to no referrer (which reflects as the empty string).
|
|
471
|
+
*/
|
|
472
|
+
referrer?: string;
|
|
473
|
+
/**
|
|
474
|
+
* userAgent affects the value read from navigator.userAgent, as well as the User-Agent header sent while fetching subresources.
|
|
475
|
+
*
|
|
476
|
+
* @default `Mozilla/5.0 (${process.platform}) AppleWebKit/537.36 (KHTML, like Gecko) jsdom/${jsdomVersion}`
|
|
477
|
+
*/
|
|
478
|
+
userAgent?: string;
|
|
479
|
+
/**
|
|
480
|
+
* url sets the value returned by window.location, document.URL, and document.documentURI,
|
|
481
|
+
* and affects things like resolution of relative URLs within the document
|
|
482
|
+
* and the same-origin restrictions and referrer used while fetching subresources.
|
|
483
|
+
*
|
|
484
|
+
* @default 'http://localhost:3000'.
|
|
485
|
+
*/
|
|
486
|
+
url?: string;
|
|
487
|
+
/**
|
|
488
|
+
* contentType affects the value read from document.contentType, and how the document is parsed: as HTML or as XML.
|
|
489
|
+
* Values that are not "text/html" or an XML mime type will throw.
|
|
490
|
+
*
|
|
491
|
+
* @default 'text/html'.
|
|
492
|
+
*/
|
|
493
|
+
contentType?: string;
|
|
494
|
+
/**
|
|
495
|
+
* The maximum size in code units for the separate storage areas used by localStorage and sessionStorage.
|
|
496
|
+
* Attempts to store data larger than this limit will cause a DOMException to be thrown. By default, it is set
|
|
497
|
+
* to 5,000,000 code units per origin, as inspired by the HTML specification.
|
|
498
|
+
*
|
|
499
|
+
* @default 5_000_000
|
|
500
|
+
*/
|
|
501
|
+
storageQuota?: number;
|
|
502
|
+
/**
|
|
503
|
+
* Enable console?
|
|
504
|
+
*
|
|
505
|
+
* @default false
|
|
506
|
+
*/
|
|
507
|
+
console?: boolean;
|
|
508
|
+
/**
|
|
509
|
+
* jsdom does not have the capability to render visual content, and will act like a headless browser by default.
|
|
510
|
+
* It provides hints to web pages through APIs such as document.hidden that their content is not visible.
|
|
511
|
+
*
|
|
512
|
+
* When the `pretendToBeVisual` option is set to `true`, jsdom will pretend that it is rendering and displaying
|
|
513
|
+
* content.
|
|
514
|
+
*
|
|
515
|
+
* @default true
|
|
516
|
+
*/
|
|
517
|
+
pretendToBeVisual?: boolean;
|
|
518
|
+
/**
|
|
519
|
+
* `includeNodeLocations` preserves the location info produced by the HTML parser,
|
|
520
|
+
* allowing you to retrieve it with the nodeLocation() method (described below).
|
|
521
|
+
*
|
|
522
|
+
* It defaults to false to give the best performance,
|
|
523
|
+
* and cannot be used with an XML content type since our XML parser does not support location info.
|
|
524
|
+
*
|
|
525
|
+
* @default false
|
|
526
|
+
*/
|
|
527
|
+
includeNodeLocations?: boolean | undefined;
|
|
528
|
+
/**
|
|
529
|
+
* @default 'dangerously'
|
|
530
|
+
*/
|
|
531
|
+
runScripts?: 'dangerously' | 'outside-only';
|
|
532
|
+
/**
|
|
533
|
+
* Enable CookieJar
|
|
534
|
+
*
|
|
535
|
+
* @default false
|
|
536
|
+
*/
|
|
537
|
+
cookieJar?: boolean;
|
|
538
|
+
resources?: 'usable' | any;
|
|
539
|
+
}
|
|
540
|
+
|
|
453
541
|
declare type Awaitable<T> = T | PromiseLike<T>;
|
|
454
542
|
declare type Nullable<T> = T | null | undefined;
|
|
455
543
|
declare type Arrayable<T> = T | Array<T>;
|
|
@@ -464,7 +552,7 @@ interface EnvironmentReturn {
|
|
|
464
552
|
}
|
|
465
553
|
interface Environment {
|
|
466
554
|
name: string;
|
|
467
|
-
setup(global: any): Awaitable<EnvironmentReturn>;
|
|
555
|
+
setup(global: any, options: Record<string, any>): Awaitable<EnvironmentReturn>;
|
|
468
556
|
}
|
|
469
557
|
interface UserConsoleLog {
|
|
470
558
|
content: string;
|
|
@@ -493,6 +581,11 @@ interface ErrorWithDiff extends Error {
|
|
|
493
581
|
expected?: any;
|
|
494
582
|
operator?: string;
|
|
495
583
|
}
|
|
584
|
+
interface ModuleGraphData {
|
|
585
|
+
graph: Record<string, string[]>;
|
|
586
|
+
externalized: string[];
|
|
587
|
+
inlined: string[];
|
|
588
|
+
}
|
|
496
589
|
|
|
497
590
|
declare type ChainableFunction<T extends string, Args extends any[], R = any> = {
|
|
498
591
|
(...args: Args): R;
|
|
@@ -621,6 +714,13 @@ interface SnapshotSummary {
|
|
|
621
714
|
|
|
622
715
|
declare type BuiltinEnvironment = 'node' | 'jsdom' | 'happy-dom';
|
|
623
716
|
declare type ApiConfig = Pick<CommonServerOptions, 'port' | 'strictPort' | 'host'>;
|
|
717
|
+
|
|
718
|
+
interface EnvironmentOptions {
|
|
719
|
+
/**
|
|
720
|
+
* jsdom options.
|
|
721
|
+
*/
|
|
722
|
+
jsdom?: JSDOMOptions;
|
|
723
|
+
}
|
|
624
724
|
interface InlineConfig {
|
|
625
725
|
/**
|
|
626
726
|
* Include globs for test files
|
|
@@ -682,7 +782,11 @@ interface InlineConfig {
|
|
|
682
782
|
*/
|
|
683
783
|
environment?: BuiltinEnvironment;
|
|
684
784
|
/**
|
|
685
|
-
*
|
|
785
|
+
* Environment options.
|
|
786
|
+
*/
|
|
787
|
+
environmentOptions?: EnvironmentOptions;
|
|
788
|
+
/**
|
|
789
|
+
* Update snapshot
|
|
686
790
|
*
|
|
687
791
|
* @default false
|
|
688
792
|
*/
|
|
@@ -695,6 +799,8 @@ interface InlineConfig {
|
|
|
695
799
|
watch?: boolean;
|
|
696
800
|
/**
|
|
697
801
|
* Project root
|
|
802
|
+
*
|
|
803
|
+
* @default process.cwd()
|
|
698
804
|
*/
|
|
699
805
|
root?: string;
|
|
700
806
|
/**
|
|
@@ -788,7 +894,13 @@ interface InlineConfig {
|
|
|
788
894
|
* Open Vitest UI
|
|
789
895
|
* @internal WIP
|
|
790
896
|
*/
|
|
791
|
-
|
|
897
|
+
ui?: boolean;
|
|
898
|
+
/**
|
|
899
|
+
* Base url for the UI
|
|
900
|
+
*
|
|
901
|
+
* @default '/__vitest__/'
|
|
902
|
+
*/
|
|
903
|
+
uiBase?: string;
|
|
792
904
|
}
|
|
793
905
|
interface UserConfig extends InlineConfig {
|
|
794
906
|
/**
|
|
@@ -839,8 +951,12 @@ interface WorkerContext {
|
|
|
839
951
|
files: string[];
|
|
840
952
|
invalidates?: string[];
|
|
841
953
|
}
|
|
954
|
+
declare type FetchFunction = (id: string) => Promise<{
|
|
955
|
+
code?: string;
|
|
956
|
+
externalize?: string;
|
|
957
|
+
}>;
|
|
842
958
|
interface WorkerRPC {
|
|
843
|
-
fetch:
|
|
959
|
+
fetch: FetchFunction;
|
|
844
960
|
getSourceMap: (id: string, force?: boolean) => Promise<RawSourceMap | undefined>;
|
|
845
961
|
onWorkerExit: (code?: number) => void;
|
|
846
962
|
onUserLog: (log: UserConsoleLog) => void;
|
|
@@ -874,11 +990,11 @@ interface MockResultThrow {
|
|
|
874
990
|
value: any;
|
|
875
991
|
}
|
|
876
992
|
declare type MockResult<T> = MockResultReturn<T> | MockResultThrow | MockResultIncomplete;
|
|
877
|
-
interface JestMockCompatContext<
|
|
878
|
-
calls:
|
|
879
|
-
instances:
|
|
993
|
+
interface JestMockCompatContext<TArgs, TReturns> {
|
|
994
|
+
calls: TArgs[];
|
|
995
|
+
instances: TReturns[];
|
|
880
996
|
invocationCallOrder: number[];
|
|
881
|
-
results: MockResult<
|
|
997
|
+
results: MockResult<TReturns>[];
|
|
882
998
|
}
|
|
883
999
|
declare type Procedure = (...args: any[]) => any;
|
|
884
1000
|
declare type Methods<T> = {
|
|
@@ -1022,16 +1138,16 @@ declare class VitestUtils {
|
|
|
1022
1138
|
declare const vitest: VitestUtils;
|
|
1023
1139
|
declare const vi: VitestUtils;
|
|
1024
1140
|
|
|
1141
|
+
interface TransformResultWithSource extends TransformResult {
|
|
1142
|
+
source?: string;
|
|
1143
|
+
}
|
|
1025
1144
|
interface WebSocketHandlers {
|
|
1026
1145
|
getFiles(): File[];
|
|
1027
1146
|
getConfig(): ResolvedConfig;
|
|
1147
|
+
getModuleGraph(id: string): Promise<ModuleGraphData>;
|
|
1148
|
+
getTransformResult(id: string): Promise<TransformResultWithSource | undefined>;
|
|
1028
1149
|
readFile(id: string): Promise<string>;
|
|
1029
1150
|
writeFile(id: string, content: string): Promise<void>;
|
|
1030
|
-
getModuleGraph(id: string): Promise<{
|
|
1031
|
-
graph: Record<string, string[]>;
|
|
1032
|
-
externalized: string[];
|
|
1033
|
-
inlined: string[];
|
|
1034
|
-
}>;
|
|
1035
1151
|
rerun(files: string[]): Promise<void>;
|
|
1036
1152
|
}
|
|
1037
1153
|
interface WebSocketEvents extends Pick<Reporter, 'onCollected' | 'onTaskUpdate'> {
|
|
@@ -1062,6 +1178,8 @@ declare global {
|
|
|
1062
1178
|
anything(): Anything;
|
|
1063
1179
|
any(constructor: unknown): Any;
|
|
1064
1180
|
addSnapshotSerializer(plugin: Plugin): void;
|
|
1181
|
+
getState(): MatcherState;
|
|
1182
|
+
setState(state: Partial<MatcherState>): void;
|
|
1065
1183
|
not: AsymmetricMatchersContaining;
|
|
1066
1184
|
}
|
|
1067
1185
|
interface JestAssertions {
|
|
@@ -1128,4 +1246,4 @@ declare global {
|
|
|
1128
1246
|
}
|
|
1129
1247
|
}
|
|
1130
1248
|
|
|
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 };
|
|
1249
|
+
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,8 +1,8 @@
|
|
|
1
|
-
export { d as describe, i as it, c as suite, t as test, e as vi, v as vitest } from './vi-
|
|
2
|
-
export { a as afterAll, d as afterEach, b as beforeAll, c as beforeEach, e as expect } from './index-
|
|
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
|
-
import './index-
|
|
5
|
+
import './index-64aafe4b.js';
|
|
6
6
|
import 'url';
|
|
7
7
|
import 'tty';
|
|
8
8
|
import 'local-pkg';
|
|
@@ -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
|
@@ -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
|
|
|
@@ -133,6 +139,86 @@ interface ResolvedC8Options extends Required<C8Options> {
|
|
|
133
139
|
tempDirectory: string;
|
|
134
140
|
}
|
|
135
141
|
|
|
142
|
+
interface JSDOMOptions {
|
|
143
|
+
/**
|
|
144
|
+
* The html content for the test.
|
|
145
|
+
*
|
|
146
|
+
* @default '<!DOCTYPE html>'
|
|
147
|
+
*/
|
|
148
|
+
html?: string | Buffer | ArrayBufferLike;
|
|
149
|
+
/**
|
|
150
|
+
* referrer just affects the value read from document.referrer.
|
|
151
|
+
* It defaults to no referrer (which reflects as the empty string).
|
|
152
|
+
*/
|
|
153
|
+
referrer?: string;
|
|
154
|
+
/**
|
|
155
|
+
* userAgent affects the value read from navigator.userAgent, as well as the User-Agent header sent while fetching subresources.
|
|
156
|
+
*
|
|
157
|
+
* @default `Mozilla/5.0 (${process.platform}) AppleWebKit/537.36 (KHTML, like Gecko) jsdom/${jsdomVersion}`
|
|
158
|
+
*/
|
|
159
|
+
userAgent?: string;
|
|
160
|
+
/**
|
|
161
|
+
* url sets the value returned by window.location, document.URL, and document.documentURI,
|
|
162
|
+
* and affects things like resolution of relative URLs within the document
|
|
163
|
+
* and the same-origin restrictions and referrer used while fetching subresources.
|
|
164
|
+
*
|
|
165
|
+
* @default 'http://localhost:3000'.
|
|
166
|
+
*/
|
|
167
|
+
url?: string;
|
|
168
|
+
/**
|
|
169
|
+
* contentType affects the value read from document.contentType, and how the document is parsed: as HTML or as XML.
|
|
170
|
+
* Values that are not "text/html" or an XML mime type will throw.
|
|
171
|
+
*
|
|
172
|
+
* @default 'text/html'.
|
|
173
|
+
*/
|
|
174
|
+
contentType?: string;
|
|
175
|
+
/**
|
|
176
|
+
* The maximum size in code units for the separate storage areas used by localStorage and sessionStorage.
|
|
177
|
+
* Attempts to store data larger than this limit will cause a DOMException to be thrown. By default, it is set
|
|
178
|
+
* to 5,000,000 code units per origin, as inspired by the HTML specification.
|
|
179
|
+
*
|
|
180
|
+
* @default 5_000_000
|
|
181
|
+
*/
|
|
182
|
+
storageQuota?: number;
|
|
183
|
+
/**
|
|
184
|
+
* Enable console?
|
|
185
|
+
*
|
|
186
|
+
* @default false
|
|
187
|
+
*/
|
|
188
|
+
console?: boolean;
|
|
189
|
+
/**
|
|
190
|
+
* jsdom does not have the capability to render visual content, and will act like a headless browser by default.
|
|
191
|
+
* It provides hints to web pages through APIs such as document.hidden that their content is not visible.
|
|
192
|
+
*
|
|
193
|
+
* When the `pretendToBeVisual` option is set to `true`, jsdom will pretend that it is rendering and displaying
|
|
194
|
+
* content.
|
|
195
|
+
*
|
|
196
|
+
* @default true
|
|
197
|
+
*/
|
|
198
|
+
pretendToBeVisual?: boolean;
|
|
199
|
+
/**
|
|
200
|
+
* `includeNodeLocations` preserves the location info produced by the HTML parser,
|
|
201
|
+
* allowing you to retrieve it with the nodeLocation() method (described below).
|
|
202
|
+
*
|
|
203
|
+
* It defaults to false to give the best performance,
|
|
204
|
+
* and cannot be used with an XML content type since our XML parser does not support location info.
|
|
205
|
+
*
|
|
206
|
+
* @default false
|
|
207
|
+
*/
|
|
208
|
+
includeNodeLocations?: boolean | undefined;
|
|
209
|
+
/**
|
|
210
|
+
* @default 'dangerously'
|
|
211
|
+
*/
|
|
212
|
+
runScripts?: 'dangerously' | 'outside-only';
|
|
213
|
+
/**
|
|
214
|
+
* Enable CookieJar
|
|
215
|
+
*
|
|
216
|
+
* @default false
|
|
217
|
+
*/
|
|
218
|
+
cookieJar?: boolean;
|
|
219
|
+
resources?: 'usable' | any;
|
|
220
|
+
}
|
|
221
|
+
|
|
136
222
|
declare type Awaitable<T> = T | PromiseLike<T>;
|
|
137
223
|
declare type Arrayable<T> = T | Array<T>;
|
|
138
224
|
declare type ArgumentsType<T> = T extends (...args: infer U) => any ? U : never;
|
|
@@ -334,6 +420,13 @@ interface SnapshotSummary {
|
|
|
334
420
|
|
|
335
421
|
declare type BuiltinEnvironment = 'node' | 'jsdom' | 'happy-dom';
|
|
336
422
|
declare type ApiConfig = Pick<CommonServerOptions, 'port' | 'strictPort' | 'host'>;
|
|
423
|
+
|
|
424
|
+
interface EnvironmentOptions {
|
|
425
|
+
/**
|
|
426
|
+
* jsdom options.
|
|
427
|
+
*/
|
|
428
|
+
jsdom?: JSDOMOptions;
|
|
429
|
+
}
|
|
337
430
|
interface InlineConfig {
|
|
338
431
|
/**
|
|
339
432
|
* Include globs for test files
|
|
@@ -395,7 +488,11 @@ interface InlineConfig {
|
|
|
395
488
|
*/
|
|
396
489
|
environment?: BuiltinEnvironment;
|
|
397
490
|
/**
|
|
398
|
-
*
|
|
491
|
+
* Environment options.
|
|
492
|
+
*/
|
|
493
|
+
environmentOptions?: EnvironmentOptions;
|
|
494
|
+
/**
|
|
495
|
+
* Update snapshot
|
|
399
496
|
*
|
|
400
497
|
* @default false
|
|
401
498
|
*/
|
|
@@ -408,6 +505,8 @@ interface InlineConfig {
|
|
|
408
505
|
watch?: boolean;
|
|
409
506
|
/**
|
|
410
507
|
* Project root
|
|
508
|
+
*
|
|
509
|
+
* @default process.cwd()
|
|
411
510
|
*/
|
|
412
511
|
root?: string;
|
|
413
512
|
/**
|
|
@@ -501,7 +600,13 @@ interface InlineConfig {
|
|
|
501
600
|
* Open Vitest UI
|
|
502
601
|
* @internal WIP
|
|
503
602
|
*/
|
|
504
|
-
|
|
603
|
+
ui?: boolean;
|
|
604
|
+
/**
|
|
605
|
+
* Base url for the UI
|
|
606
|
+
*
|
|
607
|
+
* @default '/__vitest__/'
|
|
608
|
+
*/
|
|
609
|
+
uiBase?: string;
|
|
505
610
|
}
|
|
506
611
|
interface UserConfig extends InlineConfig {
|
|
507
612
|
/**
|
|
@@ -590,6 +695,7 @@ declare class Vitest {
|
|
|
590
695
|
visitedFilesMap: Map<string, RawSourceMap>;
|
|
591
696
|
runningPromise?: Promise<void>;
|
|
592
697
|
closingPromise?: Promise<void>;
|
|
698
|
+
externalizeCache: Map<string, Promise<string | false>>;
|
|
593
699
|
isFirstRun: boolean;
|
|
594
700
|
restartsCount: number;
|
|
595
701
|
private _onRestartListeners;
|
|
@@ -610,6 +716,7 @@ declare class Vitest {
|
|
|
610
716
|
report<T extends keyof Reporter>(name: T, ...args: ArgumentsType<Reporter[T]>): Promise<void>;
|
|
611
717
|
globTestFiles(filters?: string[]): Promise<string[]>;
|
|
612
718
|
isTargetFile(id: string): boolean;
|
|
719
|
+
shouldExternalize(id: string): Promise<string | false>;
|
|
613
720
|
onServerRestarted(fn: () => void): void;
|
|
614
721
|
}
|
|
615
722
|
|
package/dist/node.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
export { c as createVitest } from './index-
|
|
1
|
+
export { c as createVitest } from './index-64de1341.js';
|
|
2
2
|
import 'fs';
|
|
3
|
-
import './index-
|
|
3
|
+
import './index-64aafe4b.js';
|
|
4
4
|
import 'url';
|
|
5
5
|
import 'tty';
|
|
6
6
|
import 'local-pkg';
|
|
@@ -11,15 +11,15 @@ import 'os';
|
|
|
11
11
|
import 'util';
|
|
12
12
|
import 'stream';
|
|
13
13
|
import 'events';
|
|
14
|
-
import './constants-
|
|
14
|
+
import './constants-d24b670d.js';
|
|
15
15
|
import './magic-string.es-94000aea.js';
|
|
16
16
|
import 'perf_hooks';
|
|
17
|
-
import './diff-
|
|
18
|
-
import './index-
|
|
17
|
+
import './diff-5dfc7eb4.js';
|
|
18
|
+
import './index-648e7ab2.js';
|
|
19
19
|
import './_commonjsHelpers-c9e3b764.js';
|
|
20
20
|
import 'assert';
|
|
21
21
|
import 'module';
|
|
22
|
+
import './index-5d6a5929.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
|