vitest 0.0.134 → 0.0.138
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cli.js +6 -6
- package/dist/{diff-04ac7bc9.js → diff-5dfc7eb4.js} +2 -4
- package/dist/entry.js +86 -20
- package/dist/{global-a033a355.js → global-f971f18f.js} +4 -4
- package/dist/{index-e7a9a813.js → index-314cb4d9.js} +5 -3
- package/dist/index-5d6a5929.js +9255 -0
- package/dist/index-64aafe4b.js +1 -1
- package/dist/index-a6ee95c8.js +8680 -0
- package/dist/index.d.ts +120 -7
- package/dist/index.js +3 -3
- package/dist/{jest-mock-30625866.js → jest-mock-6c629944.js} +4 -3
- package/dist/node.d.ts +111 -4
- package/dist/node.js +3 -3
- package/dist/{setup-55ef85af.js → setup-357bec8d.js} +9 -10
- package/dist/vi-567ba572.js +3462 -0
- package/dist/worker.js +46 -49
- package/package.json +5 -5
- package/dist/externalize-2f63779d.js +0 -9259
- package/dist/index-e909c175.js +0 -63
- package/dist/index-f164d9f3.js +0 -8548
- package/dist/vi-d23b3fa3.js +0 -3461
package/dist/index.d.ts
CHANGED
|
@@ -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;
|
|
@@ -626,6 +714,13 @@ interface SnapshotSummary {
|
|
|
626
714
|
|
|
627
715
|
declare type BuiltinEnvironment = 'node' | 'jsdom' | 'happy-dom';
|
|
628
716
|
declare type ApiConfig = Pick<CommonServerOptions, 'port' | 'strictPort' | 'host'>;
|
|
717
|
+
|
|
718
|
+
interface EnvironmentOptions {
|
|
719
|
+
/**
|
|
720
|
+
* jsdom options.
|
|
721
|
+
*/
|
|
722
|
+
jsdom?: JSDOMOptions;
|
|
723
|
+
}
|
|
629
724
|
interface InlineConfig {
|
|
630
725
|
/**
|
|
631
726
|
* Include globs for test files
|
|
@@ -687,7 +782,11 @@ interface InlineConfig {
|
|
|
687
782
|
*/
|
|
688
783
|
environment?: BuiltinEnvironment;
|
|
689
784
|
/**
|
|
690
|
-
*
|
|
785
|
+
* Environment options.
|
|
786
|
+
*/
|
|
787
|
+
environmentOptions?: EnvironmentOptions;
|
|
788
|
+
/**
|
|
789
|
+
* Update snapshot
|
|
691
790
|
*
|
|
692
791
|
* @default false
|
|
693
792
|
*/
|
|
@@ -700,6 +799,8 @@ interface InlineConfig {
|
|
|
700
799
|
watch?: boolean;
|
|
701
800
|
/**
|
|
702
801
|
* Project root
|
|
802
|
+
*
|
|
803
|
+
* @default process.cwd()
|
|
703
804
|
*/
|
|
704
805
|
root?: string;
|
|
705
806
|
/**
|
|
@@ -793,7 +894,13 @@ interface InlineConfig {
|
|
|
793
894
|
* Open Vitest UI
|
|
794
895
|
* @internal WIP
|
|
795
896
|
*/
|
|
796
|
-
|
|
897
|
+
ui?: boolean;
|
|
898
|
+
/**
|
|
899
|
+
* Base url for the UI
|
|
900
|
+
*
|
|
901
|
+
* @default '/__vitest__/'
|
|
902
|
+
*/
|
|
903
|
+
uiBase?: string;
|
|
797
904
|
}
|
|
798
905
|
interface UserConfig extends InlineConfig {
|
|
799
906
|
/**
|
|
@@ -844,8 +951,12 @@ interface WorkerContext {
|
|
|
844
951
|
files: string[];
|
|
845
952
|
invalidates?: string[];
|
|
846
953
|
}
|
|
954
|
+
declare type FetchFunction = (id: string) => Promise<{
|
|
955
|
+
code?: string;
|
|
956
|
+
externalize?: string;
|
|
957
|
+
}>;
|
|
847
958
|
interface WorkerRPC {
|
|
848
|
-
fetch:
|
|
959
|
+
fetch: FetchFunction;
|
|
849
960
|
getSourceMap: (id: string, force?: boolean) => Promise<RawSourceMap | undefined>;
|
|
850
961
|
onWorkerExit: (code?: number) => void;
|
|
851
962
|
onUserLog: (log: UserConsoleLog) => void;
|
|
@@ -1067,6 +1178,8 @@ declare global {
|
|
|
1067
1178
|
anything(): Anything;
|
|
1068
1179
|
any(constructor: unknown): Any;
|
|
1069
1180
|
addSnapshotSerializer(plugin: Plugin): void;
|
|
1181
|
+
getState(): MatcherState;
|
|
1182
|
+
setState(state: Partial<MatcherState>): void;
|
|
1070
1183
|
not: AsymmetricMatchersContaining;
|
|
1071
1184
|
}
|
|
1072
1185
|
interface JestAssertions {
|
|
@@ -1133,4 +1246,4 @@ declare global {
|
|
|
1133
1246
|
}
|
|
1134
1247
|
}
|
|
1135
1248
|
|
|
1136
|
-
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, 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 };
|
|
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,6 +1,6 @@
|
|
|
1
|
-
export { d as describe, i as it, c as suite, t as test, e as vi, v as vitest } from './vi-
|
|
2
|
-
export { a as afterAll, d as afterEach, b as beforeAll, c as beforeEach, e as expect } from './index-
|
|
3
|
-
export { f as fn, i as isMockFunction, s as spies, a as spyOn } from './jest-mock-
|
|
1
|
+
export { d as describe, i as it, c as suite, t as test, e as vi, v as vitest } from './vi-567ba572.js';
|
|
2
|
+
export { a as afterAll, d as afterEach, b as beforeAll, c as beforeEach, e as expect } from './index-314cb4d9.js';
|
|
3
|
+
export { f as fn, i as isMockFunction, s as spies, a as spyOn } from './jest-mock-6c629944.js';
|
|
4
4
|
export { assert, default as chai, should } from 'chai';
|
|
5
5
|
import './index-64aafe4b.js';
|
|
6
6
|
import 'url';
|
|
@@ -17,7 +17,7 @@ function spyOn(obj, method, accessType) {
|
|
|
17
17
|
function enhanceSpy(spy) {
|
|
18
18
|
const stub = spy;
|
|
19
19
|
let implementation;
|
|
20
|
-
|
|
20
|
+
let instances = [];
|
|
21
21
|
const mockContext = {
|
|
22
22
|
get calls() {
|
|
23
23
|
return stub.calls;
|
|
@@ -44,10 +44,11 @@ function enhanceSpy(spy) {
|
|
|
44
44
|
};
|
|
45
45
|
stub.mockClear = () => {
|
|
46
46
|
stub.reset();
|
|
47
|
+
instances = [];
|
|
47
48
|
return stub;
|
|
48
49
|
};
|
|
49
50
|
stub.mockReset = () => {
|
|
50
|
-
stub.
|
|
51
|
+
stub.mockClear();
|
|
51
52
|
implementation = () => void 0;
|
|
52
53
|
onceImplementations = [];
|
|
53
54
|
return stub;
|
|
@@ -91,4 +92,4 @@ function fn(implementation) {
|
|
|
91
92
|
}
|
|
92
93
|
|
|
93
94
|
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<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  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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"}
|
|
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,4 +1,4 @@
|
|
|
1
|
-
export { c as createVitest } from './index-
|
|
1
|
+
export { c as createVitest } from './index-a6ee95c8.js';
|
|
2
2
|
import 'fs';
|
|
3
3
|
import './index-64aafe4b.js';
|
|
4
4
|
import 'url';
|
|
@@ -14,12 +14,12 @@ import 'events';
|
|
|
14
14
|
import './constants-d24b670d.js';
|
|
15
15
|
import './magic-string.es-94000aea.js';
|
|
16
16
|
import 'perf_hooks';
|
|
17
|
-
import './diff-
|
|
17
|
+
import './diff-5dfc7eb4.js';
|
|
18
18
|
import './index-648e7ab2.js';
|
|
19
19
|
import './_commonjsHelpers-c9e3b764.js';
|
|
20
20
|
import 'assert';
|
|
21
21
|
import 'module';
|
|
22
|
+
import './index-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
|