vitest 0.0.136 → 0.0.140

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,5 @@
1
1
  import { ViteDevServer, CommonServerOptions, TransformResult } from 'vite';
2
+ import { ViteNodeServer } from 'vite-node/server';
2
3
  import { MessagePort } from 'worker_threads';
3
4
  import { SpyImpl } from 'tinyspy';
4
5
  export { Spy, SpyFn } from 'tinyspy';
@@ -98,7 +99,7 @@ declare const RECEIVED_COLOR: Formatter;
98
99
  declare const INVERTED_COLOR: Formatter;
99
100
  declare const BOLD_WEIGHT: Formatter;
100
101
  declare const DIM_COLOR: Formatter;
101
- declare type MatcherHintOptions = {
102
+ interface MatcherHintOptions {
102
103
  comment?: string;
103
104
  expectedColor?: Formatter;
104
105
  isDirectExpectCall?: boolean;
@@ -107,12 +108,12 @@ declare type MatcherHintOptions = {
107
108
  receivedColor?: Formatter;
108
109
  secondArgument?: string;
109
110
  secondArgumentColor?: Formatter;
110
- };
111
+ }
111
112
  declare function matcherHint(matcherName: string, received?: string, expected?: string, options?: MatcherHintOptions): string;
112
113
  declare const stringify: (object: unknown, maxDepth?: number) => string;
113
114
  declare const printReceived: (object: unknown) => string;
114
115
  declare const printExpected: (value: unknown) => string;
115
- declare type DiffOptions = {
116
+ interface DiffOptions {
116
117
  aAnnotation?: string;
117
118
  aColor?: Formatter;
118
119
  aIndicator?: string;
@@ -131,7 +132,7 @@ declare type DiffOptions = {
131
132
  omitAnnotationLines?: boolean;
132
133
  patchColor?: Formatter;
133
134
  compareKeys?: any;
134
- };
135
+ }
135
136
  declare function diff(a: any, b: any, options?: DiffOptions): string;
136
137
 
137
138
  declare const jestMatcherUtils_EXPECTED_COLOR: typeof EXPECTED_COLOR;
@@ -164,7 +165,7 @@ declare namespace jestMatcherUtils {
164
165
  }
165
166
 
166
167
  declare type Tester = (a: any, b: any) => boolean | undefined;
167
- declare type MatcherState = {
168
+ interface MatcherState {
168
169
  assertionCalls: number;
169
170
  currentTestName?: string;
170
171
  dontThrow?: () => void;
@@ -183,21 +184,19 @@ declare type MatcherState = {
183
184
  iterableEquality: Tester;
184
185
  subsetEquality: Tester;
185
186
  };
186
- };
187
- declare type SyncExpectationResult = {
187
+ }
188
+ interface SyncExpectationResult {
188
189
  pass: boolean;
189
190
  message: () => string;
190
191
  actual?: any;
191
192
  expected?: any;
192
- };
193
+ }
193
194
  declare type AsyncExpectationResult = Promise<SyncExpectationResult>;
194
195
  declare type ExpectationResult = SyncExpectationResult | AsyncExpectationResult;
195
- declare type RawMatcherFn<T extends MatcherState = MatcherState> = {
196
+ interface RawMatcherFn<T extends MatcherState = MatcherState> {
196
197
  (this: T, received: any, expected: any, options?: any): ExpectationResult;
197
- };
198
- declare type MatchersObject<T extends MatcherState = MatcherState> = {
199
- [id: string]: RawMatcherFn<T>;
200
- };
198
+ }
199
+ declare type MatchersObject<T extends MatcherState = MatcherState> = Record<string, RawMatcherFn<T>>;
201
200
 
202
201
  interface AsymmetricMatcherInterface {
203
202
  asymmetricMatch(other: unknown): boolean;
@@ -302,6 +301,7 @@ declare class Vitest {
302
301
  errorStream: NodeJS.WriteStream & {
303
302
  fd: 2;
304
303
  };
304
+ vitenode: ViteNodeServer;
305
305
  invalidates: Set<string>;
306
306
  changedTests: Set<string>;
307
307
  visitedFilesMap: Map<string, RawSourceMap>;
@@ -666,19 +666,19 @@ interface Reporter {
666
666
 
667
667
  declare type SnapshotData = Record<string, string>;
668
668
  declare type SnapshotUpdateState = 'all' | 'new' | 'none';
669
- declare type SnapshotStateOptions = {
669
+ interface SnapshotStateOptions {
670
670
  updateSnapshot: SnapshotUpdateState;
671
671
  expand?: boolean;
672
672
  snapshotFormat?: OptionsReceived;
673
- };
674
- declare type SnapshotMatchOptions = {
673
+ }
674
+ interface SnapshotMatchOptions {
675
675
  testName: string;
676
676
  received: unknown;
677
677
  key?: string;
678
678
  inlineSnapshot?: string;
679
679
  isInline: boolean;
680
680
  error?: Error;
681
- };
681
+ }
682
682
  interface SnapshotResult {
683
683
  filepath: string;
684
684
  added: number;
@@ -845,6 +845,10 @@ interface InlineConfig {
845
845
  * Path to setup files
846
846
  */
847
847
  setupFiles?: string | string[];
848
+ /**
849
+ * Path to global setup files
850
+ */
851
+ globalSetup?: string | string[];
848
852
  /**
849
853
  * Pattern of file paths to be ignore from triggering watch rerun
850
854
  *
@@ -899,6 +903,26 @@ interface InlineConfig {
899
903
  * @default '/__vitest__/'
900
904
  */
901
905
  uiBase?: string;
906
+ /**
907
+ * Determine the transform method of modules
908
+ */
909
+ transformMode?: {
910
+ /**
911
+ * Use SSR transform pipeline for the specified files.
912
+ * Vite plugins will receive `ssr: true` flag when processing those files.
913
+ *
914
+ * @default [/\.([cm]?[jt]sx?|json)$/]
915
+ */
916
+ ssr?: RegExp[];
917
+ /**
918
+ * First do a normal transform pipeline (targeting browser),
919
+ * then then do a SSR rewrite to run the code in Node.
920
+ * Vite plugins will receive `ssr: false` flag when processing those files.
921
+ *
922
+ * @default other than `ssr`
923
+ */
924
+ web?: RegExp[];
925
+ };
902
926
  }
903
927
  interface UserConfig extends InlineConfig {
904
928
  /**
@@ -934,10 +958,6 @@ interface ResolvedConfig extends Omit<Required<UserConfig>, 'config' | 'filters'
934
958
  filters?: string[];
935
959
  testNamePattern?: RegExp;
936
960
  related?: string[];
937
- depsInline: (string | RegExp)[];
938
- depsExternal: (string | RegExp)[];
939
- fallbackCJS: boolean;
940
- interpretDefault: boolean;
941
961
  coverage: ResolvedC8Options;
942
962
  snapshotOptions: SnapshotStateOptions;
943
963
  api?: ApiConfig;
@@ -949,8 +969,12 @@ interface WorkerContext {
949
969
  files: string[];
950
970
  invalidates?: string[];
951
971
  }
972
+ declare type FetchFunction = (id: string) => Promise<{
973
+ code?: string;
974
+ externalize?: string;
975
+ }>;
952
976
  interface WorkerRPC {
953
- fetch: (id: string) => Promise<string | undefined>;
977
+ fetch: FetchFunction;
954
978
  getSourceMap: (id: string, force?: boolean) => Promise<RawSourceMap | undefined>;
955
979
  onWorkerExit: (code?: number) => void;
956
980
  onUserLog: (log: UserConsoleLog) => void;
@@ -1240,4 +1264,4 @@ declare global {
1240
1264
  }
1241
1265
  }
1242
1266
 
1243
- export { ApiConfig, ArgumentsType, Arrayable, Awaitable, BuiltinEnvironment, DoneCallback, EnhancedSpy, Environment, EnvironmentOptions, EnvironmentReturn, ErrorWithDiff, 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 };
1267
+ 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,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-2509fe43.js';
2
- export { a as afterAll, d as afterEach, b as beforeAll, c as beforeEach, e as expect } from './index-6397bdab.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-8e5d0623.js';
2
+ export { a as afterAll, d as afterEach, b as beforeAll, c as beforeEach, e as expect } from './index-4a8eca63.js';
3
+ export { f as fn, i as isMockFunction, s as spies, a as spyOn } from './jest-mock-6c629944.js';
4
4
  export { assert, default as chai, should } from 'chai';
5
- import './index-64aafe4b.js';
6
- import 'url';
5
+ import './index-53aca3c1.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==
@@ -0,0 +1,95 @@
1
+ import { util } from 'chai';
2
+ import * as tinyspy from 'tinyspy';
3
+
4
+ const spies = new Set();
5
+ function isMockFunction(fn2) {
6
+ return typeof fn2 === "function" && "__isSpy" in fn2 && fn2.__isSpy;
7
+ }
8
+ function spyOn(obj, method, accessType) {
9
+ const dictionary = {
10
+ get: "getter",
11
+ set: "setter"
12
+ };
13
+ const objMethod = accessType ? { [dictionary[accessType]]: method } : method;
14
+ const stub = tinyspy.spyOn(obj, objMethod);
15
+ return enhanceSpy(stub);
16
+ }
17
+ function enhanceSpy(spy) {
18
+ const stub = spy;
19
+ let implementation;
20
+ let instances = [];
21
+ const mockContext = {
22
+ get calls() {
23
+ return stub.calls;
24
+ },
25
+ get instances() {
26
+ return instances;
27
+ },
28
+ get invocationCallOrder() {
29
+ return [];
30
+ },
31
+ get results() {
32
+ return stub.results.map(([callType, value]) => {
33
+ const type = callType === "error" ? "throw" : "return";
34
+ return { type, value };
35
+ });
36
+ }
37
+ };
38
+ let onceImplementations = [];
39
+ let name = stub.name;
40
+ stub.getMockName = () => name || "vi.fn()";
41
+ stub.mockName = (n) => {
42
+ name = n;
43
+ return stub;
44
+ };
45
+ stub.mockClear = () => {
46
+ stub.reset();
47
+ instances = [];
48
+ return stub;
49
+ };
50
+ stub.mockReset = () => {
51
+ stub.mockClear();
52
+ implementation = () => void 0;
53
+ onceImplementations = [];
54
+ return stub;
55
+ };
56
+ stub.mockRestore = () => {
57
+ stub.mockReset();
58
+ implementation = void 0;
59
+ return stub;
60
+ };
61
+ stub.getMockImplementation = () => implementation;
62
+ stub.mockImplementation = (fn2) => {
63
+ implementation = fn2;
64
+ return stub;
65
+ };
66
+ stub.mockImplementationOnce = (fn2) => {
67
+ onceImplementations.push(fn2);
68
+ return stub;
69
+ };
70
+ stub.mockReturnThis = () => stub.mockImplementation(function() {
71
+ return this;
72
+ });
73
+ stub.mockReturnValue = (val) => stub.mockImplementation(() => val);
74
+ stub.mockReturnValueOnce = (val) => stub.mockImplementationOnce(() => val);
75
+ stub.mockResolvedValue = (val) => stub.mockImplementation(() => Promise.resolve(val));
76
+ stub.mockResolvedValueOnce = (val) => stub.mockImplementationOnce(() => Promise.resolve(val));
77
+ stub.mockRejectedValue = (val) => stub.mockImplementation(() => Promise.reject(val));
78
+ stub.mockRejectedValueOnce = (val) => stub.mockImplementationOnce(() => Promise.reject(val));
79
+ util.addProperty(stub, "mock", () => mockContext);
80
+ stub.willCall(function(...args) {
81
+ instances.push(this);
82
+ const impl = onceImplementations.shift() || implementation || stub.getOriginal() || (() => {
83
+ });
84
+ return impl.apply(this, args);
85
+ });
86
+ spies.add(stub);
87
+ return stub;
88
+ }
89
+ function fn(implementation) {
90
+ return enhanceSpy(tinyspy.spyOn({ fn: implementation || (() => {
91
+ }) }, "fn"));
92
+ }
93
+
94
+ export { spyOn as a, fn as f, isMockFunction as i, spies as s };
95
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"jest-mock-6c629944.js","sources":["../src/integrations/jest-mock.ts"],"sourcesContent":["import { util } from 'chai'\nimport type { SpyImpl } from 'tinyspy'\nimport * as tinyspy from 'tinyspy'\n\ninterface MockResultReturn<T> {\n  type: 'return'\n  value: T\n}\ninterface MockResultIncomplete {\n  type: 'incomplete'\n  value: undefined\n}\ninterface MockResultThrow {\n  type: 'throw'\n  value: any\n}\n\ntype MockResult<T> = MockResultReturn<T> | MockResultThrow | MockResultIncomplete\n\nexport interface JestMockCompatContext<TArgs, TReturns> {\n  calls: TArgs[]\n  instances: TReturns[]\n  // TODO: doesn't work\n  invocationCallOrder: number[]\n  results: MockResult<TReturns>[]\n}\n\ntype Procedure = (...args: any[]) => any\n\ntype Methods<T> = {\n  [K in keyof T]: T[K] extends Procedure ? K : never\n}[keyof T] & string\ntype Properties<T> = {\n  [K in keyof T]: T[K] extends Procedure ? never : K\n}[keyof T] & string\ntype Classes<T> = {\n  [K in keyof T]: T[K] extends new (...args: any[]) => any ? K : never\n}[keyof T] & string\n\nexport interface JestMockCompat<TArgs extends any[] = any[], TReturns = any> {\n  getMockName(): string\n  mockName(n: string): this\n  mock: JestMockCompatContext<TArgs, TReturns>\n  mockClear(): this\n  mockReset(): this\n  mockRestore(): void\n  getMockImplementation(): ((...args: TArgs) => TReturns) | undefined\n  mockImplementation(fn: ((...args: TArgs) => TReturns) | (() => Promise<TReturns>)): this\n  mockImplementationOnce(fn: ((...args: TArgs) => TReturns) | (() => Promise<TReturns>)): this\n  mockReturnThis(): this\n  mockReturnValue(obj: TReturns): this\n  mockReturnValueOnce(obj: TReturns): this\n  mockResolvedValue(obj: Awaited<TReturns>): this\n  mockResolvedValueOnce(obj: Awaited<TReturns>): this\n  mockRejectedValue(obj: any): this\n  mockRejectedValueOnce(obj: any): this\n}\n\nexport interface JestMockCompatFn<TArgs extends any[] = any, TReturns = any> extends JestMockCompat<TArgs, TReturns> {\n  (...args: TArgs): TReturns\n}\n\nexport type MaybeMockedConstructor<T> = T extends new (\n  ...args: Array<any>\n) => infer R\n  ? JestMockCompatFn<ConstructorParameters<T>, R>\n  : T\nexport type MockedFunction<T extends Procedure> = MockWithArgs<T> & {\n  [K in keyof T]: T[K];\n}\nexport type MockedFunctionDeep<T extends Procedure> = MockWithArgs<T> & MockedObjectDeep<T>\nexport type MockedObject<T> = MaybeMockedConstructor<T> & {\n  [K in Methods<T>]: T[K] extends Procedure\n    ? MockedFunction<T[K]>\n    : T[K];\n} & { [K in Properties<T>]: T[K] }\nexport type MockedObjectDeep<T> = MaybeMockedConstructor<T> & {\n  [K in Methods<T>]: T[K] extends Procedure\n    ? MockedFunctionDeep<T[K]>\n    : T[K];\n} & { [K in Properties<T>]: MaybeMockedDeep<T[K]> }\n\nexport type MaybeMockedDeep<T> = T extends Procedure\n  ? MockedFunctionDeep<T>\n  : T extends object\n    ? MockedObjectDeep<T>\n    : T\n\nexport type MaybeMocked<T> = T extends Procedure\n  ? MockedFunction<T>\n  : T extends object\n    ? MockedObject<T>\n    : T\n\nexport type EnhancedSpy<TArgs extends any[] = any[], TReturns = any> = JestMockCompat<TArgs, TReturns> & SpyImpl<TArgs, TReturns>\n\nexport interface MockWithArgs<T extends Procedure>\n  extends JestMockCompatFn<Parameters<T>, ReturnType<T>> {\n  new (...args: T extends new (...args: any) => any ? ConstructorParameters<T> : never): T\n  (...args: Parameters<T>): ReturnType<T>\n}\n\nexport const spies = new Set<JestMockCompat>()\n\nexport function isMockFunction(fn: any): fn is EnhancedSpy {\n  return typeof fn === 'function'\n  && '__isSpy' in fn\n  && fn.__isSpy\n}\n\nexport function spyOn<T, S extends Properties<Required<T>>>(\n  obj: T,\n  methodName: S,\n  accesType: 'get',\n): JestMockCompat<[T[S]], void>\nexport function spyOn<T, G extends Properties<Required<T>>>(\n  obj: T,\n  methodName: G,\n  accesType: 'set',\n): JestMockCompat<[], T[G]>\nexport function spyOn<T, M extends Classes<Required<T>>>(\n  object: T,\n  method: M\n): Required<T>[M] extends new (...args: infer A) => infer R\n  ? JestMockCompat<A, R>\n  : never\nexport function spyOn<T, M extends Methods<Required<T>>>(\n  obj: T,\n  methodName: M,\n  mock?: T[M]\n): Required<T>[M] extends (...args: infer A) => infer R ? JestMockCompat<A, R> : never\nexport function spyOn<T, K extends keyof T>(\n  obj: T,\n  method: K,\n  accessType?: 'get' | 'set',\n): JestMockCompat {\n  const dictionary = {\n    get: 'getter',\n    set: 'setter',\n  } as const\n  const objMethod = accessType ? { [dictionary[accessType]]: method } : method\n\n  const stub = tinyspy.spyOn(obj, objMethod as any)\n\n  return enhanceSpy(stub) as JestMockCompat\n}\n\nfunction enhanceSpy<TArgs extends any[], TReturns>(\n  spy: SpyImpl<TArgs, TReturns>,\n): JestMockCompat<TArgs, TReturns> {\n  const stub = spy as unknown as EnhancedSpy<TArgs, TReturns>\n\n  let implementation: ((...args: TArgs) => TReturns) | undefined\n\n  let instances: any[] = []\n\n  const mockContext = {\n    get calls() {\n      return stub.calls\n    },\n    get instances() {\n      return instances\n    },\n    // not supported\n    get invocationCallOrder() {\n      return []\n    },\n    get results() {\n      return stub.results.map(([callType, value]) => {\n        const type = callType === 'error' ? 'throw' : 'return'\n        return { type, value }\n      })\n    },\n  }\n\n  let onceImplementations: ((...args: TArgs) => TReturns)[] = []\n\n  let name: string = (stub as any).name\n\n  stub.getMockName = () => name || 'vi.fn()'\n  stub.mockName = (n) => {\n    name = n\n    return stub\n  }\n\n  stub.mockClear = () => {\n    stub.reset()\n    instances = []\n    return stub\n  }\n\n  stub.mockReset = () => {\n    stub.mockClear()\n    implementation = () => undefined as unknown as TReturns\n    onceImplementations = []\n    return stub\n  }\n\n  stub.mockRestore = () => {\n    stub.mockReset()\n    implementation = undefined\n    return stub\n  }\n\n  stub.getMockImplementation = () => implementation\n  stub.mockImplementation = (fn: (...args: TArgs) => TReturns) => {\n    implementation = fn\n    return stub\n  }\n\n  stub.mockImplementationOnce = (fn: (...args: TArgs) => TReturns) => {\n    onceImplementations.push(fn)\n    return stub\n  }\n\n  stub.mockReturnThis = () =>\n    stub.mockImplementation(function(this: TReturns) {\n      return this\n    })\n\n  stub.mockReturnValue = (val: TReturns) => stub.mockImplementation(() => val)\n  stub.mockReturnValueOnce = (val: TReturns) => stub.mockImplementationOnce(() => val)\n\n  stub.mockResolvedValue = (val: Awaited<TReturns>) =>\n    stub.mockImplementation(() => Promise.resolve(val as TReturns))\n\n  stub.mockResolvedValueOnce = (val: Awaited<TReturns>) =>\n    stub.mockImplementationOnce(() => Promise.resolve(val as TReturns))\n\n  stub.mockRejectedValue = (val: unknown) =>\n    stub.mockImplementation(() => Promise.reject(val))\n\n  stub.mockRejectedValueOnce = (val: unknown) =>\n    stub.mockImplementationOnce(() => Promise.reject(val))\n\n  util.addProperty(stub, 'mock', () => mockContext)\n\n  stub.willCall(function(this: unknown, ...args) {\n    instances.push(this)\n    const impl = onceImplementations.shift() || implementation || stub.getOriginal() || (() => {})\n    return impl.apply(this, args)\n  })\n\n  spies.add(stub)\n\n  return stub as any\n}\n\nexport function fn<TArgs extends any[] = any[], R = any>(): JestMockCompatFn<TArgs, R>\nexport function fn<TArgs extends any[] = any[], R = any>(\n  implementation: (...args: TArgs) => R\n): JestMockCompatFn<TArgs, R>\nexport function fn<TArgs extends any[] = any[], R = any>(\n  implementation?: (...args: TArgs) => R,\n): JestMockCompatFn<TArgs, R> {\n  return enhanceSpy(tinyspy.spyOn({ fn: implementation || (() => {}) }, 'fn')) as unknown as JestMockCompatFn\n}\n"],"names":[],"mappings":"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"}
package/dist/node.d.ts CHANGED
@@ -1,4 +1,5 @@
1
- import { CommonServerOptions, ViteDevServer, UserConfig as UserConfig$1 } from 'vite';
1
+ import { CommonServerOptions, ViteDevServer, UserConfig as UserConfig$1, Plugin as Plugin$1 } from 'vite';
2
+ import { ViteNodeServer } from 'vite-node/server';
2
3
 
3
4
  interface StartOfSourceMap {
4
5
  file?: string;
@@ -382,11 +383,11 @@ declare type Plugin = NewPlugin | OldPlugin;
382
383
  declare type Plugins = Array<Plugin>;
383
384
 
384
385
  declare type SnapshotUpdateState = 'all' | 'new' | 'none';
385
- declare type SnapshotStateOptions = {
386
+ interface SnapshotStateOptions {
386
387
  updateSnapshot: SnapshotUpdateState;
387
388
  expand?: boolean;
388
389
  snapshotFormat?: OptionsReceived;
389
- };
390
+ }
390
391
  interface SnapshotResult {
391
392
  filepath: string;
392
393
  added: number;
@@ -553,6 +554,10 @@ interface InlineConfig {
553
554
  * Path to setup files
554
555
  */
555
556
  setupFiles?: string | string[];
557
+ /**
558
+ * Path to global setup files
559
+ */
560
+ globalSetup?: string | string[];
556
561
  /**
557
562
  * Pattern of file paths to be ignore from triggering watch rerun
558
563
  *
@@ -607,6 +612,26 @@ interface InlineConfig {
607
612
  * @default '/__vitest__/'
608
613
  */
609
614
  uiBase?: string;
615
+ /**
616
+ * Determine the transform method of modules
617
+ */
618
+ transformMode?: {
619
+ /**
620
+ * Use SSR transform pipeline for the specified files.
621
+ * Vite plugins will receive `ssr: true` flag when processing those files.
622
+ *
623
+ * @default [/\.([cm]?[jt]sx?|json)$/]
624
+ */
625
+ ssr?: RegExp[];
626
+ /**
627
+ * First do a normal transform pipeline (targeting browser),
628
+ * then then do a SSR rewrite to run the code in Node.
629
+ * Vite plugins will receive `ssr: false` flag when processing those files.
630
+ *
631
+ * @default other than `ssr`
632
+ */
633
+ web?: RegExp[];
634
+ };
610
635
  }
611
636
  interface UserConfig extends InlineConfig {
612
637
  /**
@@ -642,10 +667,6 @@ interface ResolvedConfig extends Omit<Required<UserConfig>, 'config' | 'filters'
642
667
  filters?: string[];
643
668
  testNamePattern?: RegExp;
644
669
  related?: string[];
645
- depsInline: (string | RegExp)[];
646
- depsExternal: (string | RegExp)[];
647
- fallbackCJS: boolean;
648
- interpretDefault: boolean;
649
670
  coverage: ResolvedC8Options;
650
671
  snapshotOptions: SnapshotStateOptions;
651
672
  api?: ApiConfig;
@@ -690,6 +711,7 @@ declare class Vitest {
690
711
  errorStream: NodeJS.WriteStream & {
691
712
  fd: 2;
692
713
  };
714
+ vitenode: ViteNodeServer;
693
715
  invalidates: Set<string>;
694
716
  changedTests: Set<string>;
695
717
  visitedFilesMap: Map<string, RawSourceMap>;
@@ -718,6 +740,7 @@ declare class Vitest {
718
740
  onServerRestarted(fn: () => void): void;
719
741
  }
720
742
 
743
+ declare function VitestPlugin(options?: UserConfig, viteOverrides?: UserConfig$1, ctx?: Vitest): Promise<Plugin$1[]>;
721
744
  declare function createVitest(options: UserConfig, viteOverrides?: UserConfig$1): Promise<Vitest>;
722
745
 
723
- export { Vitest, createVitest };
746
+ export { Vitest, VitestPlugin, createVitest };
package/dist/node.js CHANGED
@@ -1,9 +1,6 @@
1
- export { c as createVitest } from './index-0b823579.js';
1
+ export { V as VitestPlugin, c as createVitest } from './index-3faf3d6e.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-53aca3c1.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-04ac7bc9.js';
21
+ import './diff-deb11fa7.js';
18
22
  import './index-648e7ab2.js';
19
23
  import './_commonjsHelpers-c9e3b764.js';
20
- import 'assert';
21
- import 'module';
22
24
  import 'worker_threads';
23
25
  import 'tinypool';
24
- import './index-e909c175.js';
25
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9kZS5qcyIsInNvdXJjZXMiOltdLCJzb3VyY2VzQ29udGVudCI6W10sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OyJ9
26
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9kZS5qcyIsInNvdXJjZXMiOltdLCJzb3VyY2VzQ29udGVudCI6W10sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OzsifQ==