vitest 0.0.137 → 0.0.141

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
@@ -1,4 +1,4 @@
1
- import { ViteDevServer, CommonServerOptions, TransformResult } from 'vite';
1
+ import { ViteDevServer, TransformResult, CommonServerOptions } from 'vite';
2
2
  import { MessagePort } from 'worker_threads';
3
3
  import { SpyImpl } from 'tinyspy';
4
4
  export { Spy, SpyFn } from 'tinyspy';
@@ -98,7 +98,7 @@ declare const RECEIVED_COLOR: Formatter;
98
98
  declare const INVERTED_COLOR: Formatter;
99
99
  declare const BOLD_WEIGHT: Formatter;
100
100
  declare const DIM_COLOR: Formatter;
101
- declare type MatcherHintOptions = {
101
+ interface MatcherHintOptions {
102
102
  comment?: string;
103
103
  expectedColor?: Formatter;
104
104
  isDirectExpectCall?: boolean;
@@ -107,12 +107,12 @@ declare type MatcherHintOptions = {
107
107
  receivedColor?: Formatter;
108
108
  secondArgument?: string;
109
109
  secondArgumentColor?: Formatter;
110
- };
110
+ }
111
111
  declare function matcherHint(matcherName: string, received?: string, expected?: string, options?: MatcherHintOptions): string;
112
112
  declare const stringify: (object: unknown, maxDepth?: number) => string;
113
113
  declare const printReceived: (object: unknown) => string;
114
114
  declare const printExpected: (value: unknown) => string;
115
- declare type DiffOptions = {
115
+ interface DiffOptions {
116
116
  aAnnotation?: string;
117
117
  aColor?: Formatter;
118
118
  aIndicator?: string;
@@ -131,7 +131,7 @@ declare type DiffOptions = {
131
131
  omitAnnotationLines?: boolean;
132
132
  patchColor?: Formatter;
133
133
  compareKeys?: any;
134
- };
134
+ }
135
135
  declare function diff(a: any, b: any, options?: DiffOptions): string;
136
136
 
137
137
  declare const jestMatcherUtils_EXPECTED_COLOR: typeof EXPECTED_COLOR;
@@ -164,7 +164,7 @@ declare namespace jestMatcherUtils {
164
164
  }
165
165
 
166
166
  declare type Tester = (a: any, b: any) => boolean | undefined;
167
- declare type MatcherState = {
167
+ interface MatcherState {
168
168
  assertionCalls: number;
169
169
  currentTestName?: string;
170
170
  dontThrow?: () => void;
@@ -183,21 +183,19 @@ declare type MatcherState = {
183
183
  iterableEquality: Tester;
184
184
  subsetEquality: Tester;
185
185
  };
186
- };
187
- declare type SyncExpectationResult = {
186
+ }
187
+ interface SyncExpectationResult {
188
188
  pass: boolean;
189
189
  message: () => string;
190
190
  actual?: any;
191
191
  expected?: any;
192
- };
192
+ }
193
193
  declare type AsyncExpectationResult = Promise<SyncExpectationResult>;
194
194
  declare type ExpectationResult = SyncExpectationResult | AsyncExpectationResult;
195
- declare type RawMatcherFn<T extends MatcherState = MatcherState> = {
195
+ interface RawMatcherFn<T extends MatcherState = MatcherState> {
196
196
  (this: T, received: any, expected: any, options?: any): ExpectationResult;
197
- };
198
- declare type MatchersObject<T extends MatcherState = MatcherState> = {
199
- [id: string]: RawMatcherFn<T>;
200
- };
197
+ }
198
+ declare type MatchersObject<T extends MatcherState = MatcherState> = Record<string, RawMatcherFn<T>>;
201
199
 
202
200
  interface AsymmetricMatcherInterface {
203
201
  asymmetricMatch(other: unknown): boolean;
@@ -263,6 +261,37 @@ interface RawSourceMap extends StartOfSourceMap {
263
261
  mappings: string;
264
262
  }
265
263
 
264
+ interface ExternalizeOptions {
265
+ external?: (string | RegExp)[];
266
+ inline?: (string | RegExp)[];
267
+ fallbackCJS?: boolean;
268
+ }
269
+ interface ViteNodeServerOptions {
270
+ deps?: ExternalizeOptions;
271
+ transformMode?: {
272
+ ssr?: RegExp[];
273
+ web?: RegExp[];
274
+ };
275
+ }
276
+
277
+ declare class ViteNodeServer {
278
+ server: ViteDevServer;
279
+ options: ViteNodeServerOptions;
280
+ promiseMap: Map<string, Promise<TransformResult | null | undefined>>;
281
+ constructor(server: ViteDevServer, options?: ViteNodeServerOptions);
282
+ shouldExternalize(id: string): Promise<string | false>;
283
+ fetchModule(id: string): Promise<{
284
+ externalize: string;
285
+ code?: undefined;
286
+ } | {
287
+ code: string | undefined;
288
+ externalize?: undefined;
289
+ }>;
290
+ transformRequest(id: string): Promise<TransformResult | null | undefined>;
291
+ private getTransformMode;
292
+ private _transformRequest;
293
+ }
294
+
266
295
  declare class SnapshotManager {
267
296
  config: ResolvedConfig;
268
297
  summary: SnapshotSummary;
@@ -302,12 +331,12 @@ declare class Vitest {
302
331
  errorStream: NodeJS.WriteStream & {
303
332
  fd: 2;
304
333
  };
334
+ vitenode: ViteNodeServer;
305
335
  invalidates: Set<string>;
306
336
  changedTests: Set<string>;
307
337
  visitedFilesMap: Map<string, RawSourceMap>;
308
338
  runningPromise?: Promise<void>;
309
339
  closingPromise?: Promise<void>;
310
- externalizeCache: Map<string, Promise<string | false>>;
311
340
  isFirstRun: boolean;
312
341
  restartsCount: number;
313
342
  private _onRestartListeners;
@@ -328,7 +357,6 @@ declare class Vitest {
328
357
  report<T extends keyof Reporter>(name: T, ...args: ArgumentsType<Reporter[T]>): Promise<void>;
329
358
  globTestFiles(filters?: string[]): Promise<string[]>;
330
359
  isTargetFile(id: string): boolean;
331
- shouldExternalize(id: string): Promise<string | false>;
332
360
  onServerRestarted(fn: () => void): void;
333
361
  }
334
362
 
@@ -668,19 +696,19 @@ interface Reporter {
668
696
 
669
697
  declare type SnapshotData = Record<string, string>;
670
698
  declare type SnapshotUpdateState = 'all' | 'new' | 'none';
671
- declare type SnapshotStateOptions = {
699
+ interface SnapshotStateOptions {
672
700
  updateSnapshot: SnapshotUpdateState;
673
701
  expand?: boolean;
674
702
  snapshotFormat?: OptionsReceived;
675
- };
676
- declare type SnapshotMatchOptions = {
703
+ }
704
+ interface SnapshotMatchOptions {
677
705
  testName: string;
678
706
  received: unknown;
679
707
  key?: string;
680
708
  inlineSnapshot?: string;
681
709
  isInline: boolean;
682
710
  error?: Error;
683
- };
711
+ }
684
712
  interface SnapshotResult {
685
713
  filepath: string;
686
714
  added: number;
@@ -847,6 +875,10 @@ interface InlineConfig {
847
875
  * Path to setup files
848
876
  */
849
877
  setupFiles?: string | string[];
878
+ /**
879
+ * Path to global setup files
880
+ */
881
+ globalSetup?: string | string[];
850
882
  /**
851
883
  * Pattern of file paths to be ignore from triggering watch rerun
852
884
  *
@@ -901,6 +933,30 @@ interface InlineConfig {
901
933
  * @default '/__vitest__/'
902
934
  */
903
935
  uiBase?: string;
936
+ /**
937
+ * Determine the transform method of modules
938
+ */
939
+ transformMode?: {
940
+ /**
941
+ * Use SSR transform pipeline for the specified files.
942
+ * Vite plugins will receive `ssr: true` flag when processing those files.
943
+ *
944
+ * @default [/\.([cm]?[jt]sx?|json)$/]
945
+ */
946
+ ssr?: RegExp[];
947
+ /**
948
+ * First do a normal transform pipeline (targeting browser),
949
+ * then then do a SSR rewrite to run the code in Node.
950
+ * Vite plugins will receive `ssr: false` flag when processing those files.
951
+ *
952
+ * @default other than `ssr`
953
+ */
954
+ web?: RegExp[];
955
+ };
956
+ /**
957
+ * Format options for snapshot testing.
958
+ */
959
+ snapshotFormat?: PrettyFormatOptions;
904
960
  }
905
961
  interface UserConfig extends InlineConfig {
906
962
  /**
@@ -936,10 +992,6 @@ interface ResolvedConfig extends Omit<Required<UserConfig>, 'config' | 'filters'
936
992
  filters?: string[];
937
993
  testNamePattern?: RegExp;
938
994
  related?: string[];
939
- depsInline: (string | RegExp)[];
940
- depsExternal: (string | RegExp)[];
941
- fallbackCJS: boolean;
942
- interpretDefault: boolean;
943
995
  coverage: ResolvedC8Options;
944
996
  snapshotOptions: SnapshotStateOptions;
945
997
  api?: ApiConfig;
package/dist/index.js CHANGED
@@ -1,12 +1,10 @@
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';
1
+ export { d as describe, i as it, c as suite, t as test, e as vi, v as vitest } from './vi-8d17efa1.js';
2
+ export { a as afterAll, d as afterEach, b as beforeAll, c as beforeEach, e as expect } from './index-9387000b.js';
3
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-64aafe4b.js';
6
- import 'url';
5
+ import './index-1bb8e174.js';
7
6
  import 'tty';
8
7
  import 'local-pkg';
9
- import 'path';
10
8
  import './_commonjsHelpers-c9e3b764.js';
11
9
  import 'tinyspy';
12
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VzIjpbXSwic291cmNlc0NvbnRlbnQiOltdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7OyJ9
10
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VzIjpbXSwic291cmNlc0NvbnRlbnQiOltdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7OzsifQ==
@@ -92,4 +92,4 @@ function fn(implementation) {
92
92
  }
93
93
 
94
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":";;;AAEY,MAAC,KAAK,GAAG,IAAI,GAAG,GAAG;AACxB,SAAS,cAAc,CAAC,GAAG,EAAE;AACpC,EAAE,OAAO,OAAO,GAAG,KAAK,UAAU,IAAI,SAAS,IAAI,GAAG,IAAI,GAAG,CAAC,OAAO,CAAC;AACtE,CAAC;AACM,SAAS,KAAK,CAAC,GAAG,EAAE,MAAM,EAAE,UAAU,EAAE;AAC/C,EAAE,MAAM,UAAU,GAAG;AACrB,IAAI,GAAG,EAAE,QAAQ;AACjB,IAAI,GAAG,EAAE,QAAQ;AACjB,GAAG,CAAC;AACJ,EAAE,MAAM,SAAS,GAAG,UAAU,GAAG,EAAE,CAAC,UAAU,CAAC,UAAU,CAAC,GAAG,MAAM,EAAE,GAAG,MAAM,CAAC;AAC/E,EAAE,MAAM,IAAI,GAAG,OAAO,CAAC,KAAK,CAAC,GAAG,EAAE,SAAS,CAAC,CAAC;AAC7C,EAAE,OAAO,UAAU,CAAC,IAAI,CAAC,CAAC;AAC1B,CAAC;AACD,SAAS,UAAU,CAAC,GAAG,EAAE;AACzB,EAAE,MAAM,IAAI,GAAG,GAAG,CAAC;AACnB,EAAE,IAAI,cAAc,CAAC;AACrB,EAAE,IAAI,SAAS,GAAG,EAAE,CAAC;AACrB,EAAE,MAAM,WAAW,GAAG;AACtB,IAAI,IAAI,KAAK,GAAG;AAChB,MAAM,OAAO,IAAI,CAAC,KAAK,CAAC;AACxB,KAAK;AACL,IAAI,IAAI,SAAS,GAAG;AACpB,MAAM,OAAO,SAAS,CAAC;AACvB,KAAK;AACL,IAAI,IAAI,mBAAmB,GAAG;AAC9B,MAAM,OAAO,EAAE,CAAC;AAChB,KAAK;AACL,IAAI,IAAI,OAAO,GAAG;AAClB,MAAM,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,QAAQ,EAAE,KAAK,CAAC,KAAK;AACrD,QAAQ,MAAM,IAAI,GAAG,QAAQ,KAAK,OAAO,GAAG,OAAO,GAAG,QAAQ,CAAC;AAC/D,QAAQ,OAAO,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC;AAC/B,OAAO,CAAC,CAAC;AACT,KAAK;AACL,GAAG,CAAC;AACJ,EAAE,IAAI,mBAAmB,GAAG,EAAE,CAAC;AAC/B,EAAE,IAAI,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC;AACvB,EAAE,IAAI,CAAC,WAAW,GAAG,MAAM,IAAI,IAAI,SAAS,CAAC;AAC7C,EAAE,IAAI,CAAC,QAAQ,GAAG,CAAC,CAAC,KAAK;AACzB,IAAI,IAAI,GAAG,CAAC,CAAC;AACb,IAAI,OAAO,IAAI,CAAC;AAChB,GAAG,CAAC;AACJ,EAAE,IAAI,CAAC,SAAS,GAAG,MAAM;AACzB,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;AACjB,IAAI,SAAS,GAAG,EAAE,CAAC;AACnB,IAAI,OAAO,IAAI,CAAC;AAChB,GAAG,CAAC;AACJ,EAAE,IAAI,CAAC,SAAS,GAAG,MAAM;AACzB,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;AACrB,IAAI,cAAc,GAAG,MAAM,KAAK,CAAC,CAAC;AAClC,IAAI,mBAAmB,GAAG,EAAE,CAAC;AAC7B,IAAI,OAAO,IAAI,CAAC;AAChB,GAAG,CAAC;AACJ,EAAE,IAAI,CAAC,WAAW,GAAG,MAAM;AAC3B,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;AACrB,IAAI,cAAc,GAAG,KAAK,CAAC,CAAC;AAC5B,IAAI,OAAO,IAAI,CAAC;AAChB,GAAG,CAAC;AACJ,EAAE,IAAI,CAAC,qBAAqB,GAAG,MAAM,cAAc,CAAC;AACpD,EAAE,IAAI,CAAC,kBAAkB,GAAG,CAAC,GAAG,KAAK;AACrC,IAAI,cAAc,GAAG,GAAG,CAAC;AACzB,IAAI,OAAO,IAAI,CAAC;AAChB,GAAG,CAAC;AACJ,EAAE,IAAI,CAAC,sBAAsB,GAAG,CAAC,GAAG,KAAK;AACzC,IAAI,mBAAmB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;AAClC,IAAI,OAAO,IAAI,CAAC;AAChB,GAAG,CAAC;AACJ,EAAE,IAAI,CAAC,cAAc,GAAG,MAAM,IAAI,CAAC,kBAAkB,CAAC,WAAW;AACjE,IAAI,OAAO,IAAI,CAAC;AAChB,GAAG,CAAC,CAAC;AACL,EAAE,IAAI,CAAC,eAAe,GAAG,CAAC,GAAG,KAAK,IAAI,CAAC,kBAAkB,CAAC,MAAM,GAAG,CAAC,CAAC;AACrE,EAAE,IAAI,CAAC,mBAAmB,GAAG,CAAC,GAAG,KAAK,IAAI,CAAC,sBAAsB,CAAC,MAAM,GAAG,CAAC,CAAC;AAC7E,EAAE,IAAI,CAAC,iBAAiB,GAAG,CAAC,GAAG,KAAK,IAAI,CAAC,kBAAkB,CAAC,MAAM,OAAO,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC;AACxF,EAAE,IAAI,CAAC,qBAAqB,GAAG,CAAC,GAAG,KAAK,IAAI,CAAC,sBAAsB,CAAC,MAAM,OAAO,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC;AAChG,EAAE,IAAI,CAAC,iBAAiB,GAAG,CAAC,GAAG,KAAK,IAAI,CAAC,kBAAkB,CAAC,MAAM,OAAO,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC;AACvF,EAAE,IAAI,CAAC,qBAAqB,GAAG,CAAC,GAAG,KAAK,IAAI,CAAC,sBAAsB,CAAC,MAAM,OAAO,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC;AAC/F,EAAE,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,WAAW,CAAC,CAAC;AACpD,EAAE,IAAI,CAAC,QAAQ,CAAC,SAAS,GAAG,IAAI,EAAE;AAClC,IAAI,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;AACzB,IAAI,MAAM,IAAI,GAAG,mBAAmB,CAAC,KAAK,EAAE,IAAI,cAAc,IAAI,IAAI,CAAC,WAAW,EAAE,KAAK,MAAM;AAC/F,KAAK,CAAC,CAAC;AACP,IAAI,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;AAClC,GAAG,CAAC,CAAC;AACL,EAAE,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;AAClB,EAAE,OAAO,IAAI,CAAC;AACd,CAAC;AACM,SAAS,EAAE,CAAC,cAAc,EAAE;AACnC,EAAE,OAAO,UAAU,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,cAAc,KAAK,MAAM;AACjE,GAAG,CAAC,EAAE,EAAE,IAAI,CAAC,CAAC,CAAC;AACf;;"}
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
@@ -1,4 +1,4 @@
1
- import { CommonServerOptions, ViteDevServer, UserConfig as UserConfig$1 } from 'vite';
1
+ import { ViteDevServer, TransformResult, CommonServerOptions, UserConfig as UserConfig$1, Plugin as Plugin$1 } from 'vite';
2
2
 
3
3
  interface StartOfSourceMap {
4
4
  file?: string;
@@ -13,6 +13,124 @@ interface RawSourceMap extends StartOfSourceMap {
13
13
  mappings: string;
14
14
  }
15
15
 
16
+ interface ExternalizeOptions {
17
+ external?: (string | RegExp)[];
18
+ inline?: (string | RegExp)[];
19
+ fallbackCJS?: boolean;
20
+ }
21
+ interface ViteNodeServerOptions {
22
+ deps?: ExternalizeOptions;
23
+ transformMode?: {
24
+ ssr?: RegExp[];
25
+ web?: RegExp[];
26
+ };
27
+ }
28
+
29
+ declare class ViteNodeServer {
30
+ server: ViteDevServer;
31
+ options: ViteNodeServerOptions;
32
+ promiseMap: Map<string, Promise<TransformResult | null | undefined>>;
33
+ constructor(server: ViteDevServer, options?: ViteNodeServerOptions);
34
+ shouldExternalize(id: string): Promise<string | false>;
35
+ fetchModule(id: string): Promise<{
36
+ externalize: string;
37
+ code?: undefined;
38
+ } | {
39
+ code: string | undefined;
40
+ externalize?: undefined;
41
+ }>;
42
+ transformRequest(id: string): Promise<TransformResult | null | undefined>;
43
+ private getTransformMode;
44
+ private _transformRequest;
45
+ }
46
+
47
+ /**
48
+ * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved.
49
+ *
50
+ * This source code is licensed under the MIT license found in the
51
+ * LICENSE file in the root directory of this source tree.
52
+ */
53
+ declare type Colors = {
54
+ comment: {
55
+ close: string;
56
+ open: string;
57
+ };
58
+ content: {
59
+ close: string;
60
+ open: string;
61
+ };
62
+ prop: {
63
+ close: string;
64
+ open: string;
65
+ };
66
+ tag: {
67
+ close: string;
68
+ open: string;
69
+ };
70
+ value: {
71
+ close: string;
72
+ open: string;
73
+ };
74
+ };
75
+ declare type Indent = (arg0: string) => string;
76
+ declare type Refs = Array<unknown>;
77
+ declare type Print = (arg0: unknown) => string;
78
+ declare type ThemeReceived = {
79
+ comment?: string;
80
+ content?: string;
81
+ prop?: string;
82
+ tag?: string;
83
+ value?: string;
84
+ };
85
+ declare type CompareKeys = ((a: string, b: string) => number) | undefined;
86
+ interface PrettyFormatOptions {
87
+ callToJSON?: boolean;
88
+ compareKeys?: CompareKeys;
89
+ escapeRegex?: boolean;
90
+ escapeString?: boolean;
91
+ highlight?: boolean;
92
+ indent?: number;
93
+ maxDepth?: number;
94
+ min?: boolean;
95
+ plugins?: Plugins;
96
+ printBasicPrototype?: boolean;
97
+ printFunctionName?: boolean;
98
+ theme?: ThemeReceived;
99
+ }
100
+ declare type OptionsReceived = PrettyFormatOptions;
101
+ declare type Config = {
102
+ callToJSON: boolean;
103
+ compareKeys: CompareKeys;
104
+ colors: Colors;
105
+ escapeRegex: boolean;
106
+ escapeString: boolean;
107
+ indent: string;
108
+ maxDepth: number;
109
+ min: boolean;
110
+ plugins: Plugins;
111
+ printBasicPrototype: boolean;
112
+ printFunctionName: boolean;
113
+ spacingInner: string;
114
+ spacingOuter: string;
115
+ };
116
+ declare type Printer = (val: unknown, config: Config, indentation: string, depth: number, refs: Refs, hasCalledToJSON?: boolean) => string;
117
+ declare type Test$1 = (arg0: any) => boolean;
118
+ declare type NewPlugin = {
119
+ serialize: (val: any, config: Config, indentation: string, depth: number, refs: Refs, printer: Printer) => string;
120
+ test: Test$1;
121
+ };
122
+ declare type PluginOptions = {
123
+ edgeSpacing: string;
124
+ min: boolean;
125
+ spacing: string;
126
+ };
127
+ declare type OldPlugin = {
128
+ print: (val: unknown, print: Print, indent: Indent, options: PluginOptions, colors: Colors) => string;
129
+ test: Test$1;
130
+ };
131
+ declare type Plugin = NewPlugin | OldPlugin;
132
+ declare type Plugins = Array<Plugin>;
133
+
16
134
  declare abstract class BaseReporter implements Reporter {
17
135
  start: number;
18
136
  end: number;
@@ -275,13 +393,13 @@ interface File extends Suite {
275
393
  filepath: string;
276
394
  collectDuration?: number;
277
395
  }
278
- interface Test$1 extends TaskBase {
396
+ interface Test extends TaskBase {
279
397
  type: 'test';
280
398
  suite: Suite;
281
399
  result?: TaskResult;
282
400
  fails?: boolean;
283
401
  }
284
- declare type Task = Test$1 | Suite | File;
402
+ declare type Task = Test | Suite | File;
285
403
 
286
404
  interface Reporter {
287
405
  onInit?(ctx: Vitest): void;
@@ -294,99 +412,12 @@ interface Reporter {
294
412
  onUserConsoleLog?: (log: UserConsoleLog) => Awaitable<void>;
295
413
  }
296
414
 
297
- /**
298
- * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved.
299
- *
300
- * This source code is licensed under the MIT license found in the
301
- * LICENSE file in the root directory of this source tree.
302
- */
303
- declare type Colors = {
304
- comment: {
305
- close: string;
306
- open: string;
307
- };
308
- content: {
309
- close: string;
310
- open: string;
311
- };
312
- prop: {
313
- close: string;
314
- open: string;
315
- };
316
- tag: {
317
- close: string;
318
- open: string;
319
- };
320
- value: {
321
- close: string;
322
- open: string;
323
- };
324
- };
325
- declare type Indent = (arg0: string) => string;
326
- declare type Refs = Array<unknown>;
327
- declare type Print = (arg0: unknown) => string;
328
- declare type ThemeReceived = {
329
- comment?: string;
330
- content?: string;
331
- prop?: string;
332
- tag?: string;
333
- value?: string;
334
- };
335
- declare type CompareKeys = ((a: string, b: string) => number) | undefined;
336
- interface PrettyFormatOptions {
337
- callToJSON?: boolean;
338
- compareKeys?: CompareKeys;
339
- escapeRegex?: boolean;
340
- escapeString?: boolean;
341
- highlight?: boolean;
342
- indent?: number;
343
- maxDepth?: number;
344
- min?: boolean;
345
- plugins?: Plugins;
346
- printBasicPrototype?: boolean;
347
- printFunctionName?: boolean;
348
- theme?: ThemeReceived;
349
- }
350
- declare type OptionsReceived = PrettyFormatOptions;
351
- declare type Config = {
352
- callToJSON: boolean;
353
- compareKeys: CompareKeys;
354
- colors: Colors;
355
- escapeRegex: boolean;
356
- escapeString: boolean;
357
- indent: string;
358
- maxDepth: number;
359
- min: boolean;
360
- plugins: Plugins;
361
- printBasicPrototype: boolean;
362
- printFunctionName: boolean;
363
- spacingInner: string;
364
- spacingOuter: string;
365
- };
366
- declare type Printer = (val: unknown, config: Config, indentation: string, depth: number, refs: Refs, hasCalledToJSON?: boolean) => string;
367
- declare type Test = (arg0: any) => boolean;
368
- declare type NewPlugin = {
369
- serialize: (val: any, config: Config, indentation: string, depth: number, refs: Refs, printer: Printer) => string;
370
- test: Test;
371
- };
372
- declare type PluginOptions = {
373
- edgeSpacing: string;
374
- min: boolean;
375
- spacing: string;
376
- };
377
- declare type OldPlugin = {
378
- print: (val: unknown, print: Print, indent: Indent, options: PluginOptions, colors: Colors) => string;
379
- test: Test;
380
- };
381
- declare type Plugin = NewPlugin | OldPlugin;
382
- declare type Plugins = Array<Plugin>;
383
-
384
415
  declare type SnapshotUpdateState = 'all' | 'new' | 'none';
385
- declare type SnapshotStateOptions = {
416
+ interface SnapshotStateOptions {
386
417
  updateSnapshot: SnapshotUpdateState;
387
418
  expand?: boolean;
388
419
  snapshotFormat?: OptionsReceived;
389
- };
420
+ }
390
421
  interface SnapshotResult {
391
422
  filepath: string;
392
423
  added: number;
@@ -553,6 +584,10 @@ interface InlineConfig {
553
584
  * Path to setup files
554
585
  */
555
586
  setupFiles?: string | string[];
587
+ /**
588
+ * Path to global setup files
589
+ */
590
+ globalSetup?: string | string[];
556
591
  /**
557
592
  * Pattern of file paths to be ignore from triggering watch rerun
558
593
  *
@@ -607,6 +642,30 @@ interface InlineConfig {
607
642
  * @default '/__vitest__/'
608
643
  */
609
644
  uiBase?: string;
645
+ /**
646
+ * Determine the transform method of modules
647
+ */
648
+ transformMode?: {
649
+ /**
650
+ * Use SSR transform pipeline for the specified files.
651
+ * Vite plugins will receive `ssr: true` flag when processing those files.
652
+ *
653
+ * @default [/\.([cm]?[jt]sx?|json)$/]
654
+ */
655
+ ssr?: RegExp[];
656
+ /**
657
+ * First do a normal transform pipeline (targeting browser),
658
+ * then then do a SSR rewrite to run the code in Node.
659
+ * Vite plugins will receive `ssr: false` flag when processing those files.
660
+ *
661
+ * @default other than `ssr`
662
+ */
663
+ web?: RegExp[];
664
+ };
665
+ /**
666
+ * Format options for snapshot testing.
667
+ */
668
+ snapshotFormat?: PrettyFormatOptions;
610
669
  }
611
670
  interface UserConfig extends InlineConfig {
612
671
  /**
@@ -642,10 +701,6 @@ interface ResolvedConfig extends Omit<Required<UserConfig>, 'config' | 'filters'
642
701
  filters?: string[];
643
702
  testNamePattern?: RegExp;
644
703
  related?: string[];
645
- depsInline: (string | RegExp)[];
646
- depsExternal: (string | RegExp)[];
647
- fallbackCJS: boolean;
648
- interpretDefault: boolean;
649
704
  coverage: ResolvedC8Options;
650
705
  snapshotOptions: SnapshotStateOptions;
651
706
  api?: ApiConfig;
@@ -690,12 +745,12 @@ declare class Vitest {
690
745
  errorStream: NodeJS.WriteStream & {
691
746
  fd: 2;
692
747
  };
748
+ vitenode: ViteNodeServer;
693
749
  invalidates: Set<string>;
694
750
  changedTests: Set<string>;
695
751
  visitedFilesMap: Map<string, RawSourceMap>;
696
752
  runningPromise?: Promise<void>;
697
753
  closingPromise?: Promise<void>;
698
- externalizeCache: Map<string, Promise<string | false>>;
699
754
  isFirstRun: boolean;
700
755
  restartsCount: number;
701
756
  private _onRestartListeners;
@@ -716,10 +771,10 @@ declare class Vitest {
716
771
  report<T extends keyof Reporter>(name: T, ...args: ArgumentsType<Reporter[T]>): Promise<void>;
717
772
  globTestFiles(filters?: string[]): Promise<string[]>;
718
773
  isTargetFile(id: string): boolean;
719
- shouldExternalize(id: string): Promise<string | false>;
720
774
  onServerRestarted(fn: () => void): void;
721
775
  }
722
776
 
777
+ declare function VitestPlugin(options?: UserConfig, viteOverrides?: UserConfig$1, ctx?: Vitest): Promise<Plugin$1[]>;
723
778
  declare function createVitest(options: UserConfig, viteOverrides?: UserConfig$1): Promise<Vitest>;
724
779
 
725
- export { Vitest, createVitest };
780
+ export { Vitest, VitestPlugin, createVitest };
package/dist/node.js CHANGED
@@ -1,9 +1,6 @@
1
- export { c as createVitest } from './index-64de1341.js';
1
+ export { V as VitestPlugin, c as createVitest } from './index-9a69ca2e.js';
2
2
  import 'fs';
3
- import './index-64aafe4b.js';
4
- import 'url';
5
- import 'tty';
6
- import 'local-pkg';
3
+ import './index-1b2eb03b.js';
7
4
  import 'path';
8
5
  import 'vite';
9
6
  import 'process';
@@ -11,15 +8,19 @@ import 'os';
11
8
  import 'util';
12
9
  import 'stream';
13
10
  import 'events';
14
- import './constants-d24b670d.js';
11
+ import './index-1bb8e174.js';
12
+ import 'tty';
13
+ import 'local-pkg';
14
+ import './index-c037b40c.js';
15
+ import 'module';
16
+ import 'url';
17
+ import 'assert';
18
+ import './constants-124522a1.js';
15
19
  import './magic-string.es-94000aea.js';
16
20
  import 'perf_hooks';
17
- import './diff-5dfc7eb4.js';
21
+ import './diff-f7af3876.js';
18
22
  import './index-648e7ab2.js';
19
23
  import './_commonjsHelpers-c9e3b764.js';
20
- import 'assert';
21
- import 'module';
22
- import './index-5d6a5929.js';
23
24
  import 'worker_threads';
24
25
  import 'tinypool';
25
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9kZS5qcyIsInNvdXJjZXMiOltdLCJzb3VyY2VzQ29udGVudCI6W10sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OyJ9
26
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9kZS5qcyIsInNvdXJjZXMiOltdLCJzb3VyY2VzQ29udGVudCI6W10sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OzsifQ==