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/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
- private ctx;
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
- * Update snapshot files
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
- open?: boolean;
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: (id: string) => Promise<string | undefined>;
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-d23b3fa3.js';
2
- export { a as afterAll, d as afterEach, b as beforeAll, c as beforeEach, e as expect } from './index-e7a9a813.js';
3
- export { f as fn, i as isMockFunction, s as spies, a as spyOn } from './jest-mock-30625866.js';
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
- const instances = [];
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.reset();
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
- private ctx;
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
- * Update snapshot files
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
- open?: boolean;
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-f164d9f3.js';
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-04ac7bc9.js';
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