vitest 0.2.2 → 0.2.6

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.
@@ -0,0 +1,99 @@
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
+ let callOrder = 0;
18
+ function enhanceSpy(spy) {
19
+ const stub = spy;
20
+ let implementation;
21
+ let instances = [];
22
+ let invocations = [];
23
+ const mockContext = {
24
+ get calls() {
25
+ return stub.calls;
26
+ },
27
+ get instances() {
28
+ return instances;
29
+ },
30
+ get invocationCallOrder() {
31
+ return invocations;
32
+ },
33
+ get results() {
34
+ return stub.results.map(([callType, value]) => {
35
+ const type = callType === "error" ? "throw" : "return";
36
+ return { type, value };
37
+ });
38
+ }
39
+ };
40
+ let onceImplementations = [];
41
+ let name = stub.name;
42
+ stub.getMockName = () => name || "vi.fn()";
43
+ stub.mockName = (n) => {
44
+ name = n;
45
+ return stub;
46
+ };
47
+ stub.mockClear = () => {
48
+ stub.reset();
49
+ instances = [];
50
+ invocations = [];
51
+ return stub;
52
+ };
53
+ stub.mockReset = () => {
54
+ stub.mockClear();
55
+ implementation = () => void 0;
56
+ onceImplementations = [];
57
+ return stub;
58
+ };
59
+ stub.mockRestore = () => {
60
+ stub.mockReset();
61
+ implementation = void 0;
62
+ return stub;
63
+ };
64
+ stub.getMockImplementation = () => implementation;
65
+ stub.mockImplementation = (fn2) => {
66
+ implementation = fn2;
67
+ return stub;
68
+ };
69
+ stub.mockImplementationOnce = (fn2) => {
70
+ onceImplementations.push(fn2);
71
+ return stub;
72
+ };
73
+ stub.mockReturnThis = () => stub.mockImplementation(function() {
74
+ return this;
75
+ });
76
+ stub.mockReturnValue = (val) => stub.mockImplementation(() => val);
77
+ stub.mockReturnValueOnce = (val) => stub.mockImplementationOnce(() => val);
78
+ stub.mockResolvedValue = (val) => stub.mockImplementation(() => Promise.resolve(val));
79
+ stub.mockResolvedValueOnce = (val) => stub.mockImplementationOnce(() => Promise.resolve(val));
80
+ stub.mockRejectedValue = (val) => stub.mockImplementation(() => Promise.reject(val));
81
+ stub.mockRejectedValueOnce = (val) => stub.mockImplementationOnce(() => Promise.reject(val));
82
+ util.addProperty(stub, "mock", () => mockContext);
83
+ stub.willCall(function(...args) {
84
+ instances.push(this);
85
+ invocations.push(++callOrder);
86
+ const impl = onceImplementations.shift() || implementation || stub.getOriginal() || (() => {
87
+ });
88
+ return impl.apply(this, args);
89
+ });
90
+ spies.add(stub);
91
+ return stub;
92
+ }
93
+ function fn(implementation) {
94
+ return enhanceSpy(tinyspy.spyOn({ fn: implementation || (() => {
95
+ }) }, "fn"));
96
+ }
97
+
98
+ export { fn, isMockFunction, spies, spyOn };
99
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"jest-mock.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  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 SpyInstance<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 SpyInstanceFn<TArgs extends any[] = any, TReturns = any> extends SpyInstance<TArgs, TReturns> {\n  (...args: TArgs): TReturns\n}\n\nexport type MaybeMockedConstructor<T> = T extends new (\n  ...args: Array<any>\n) => infer R\n  ? SpyInstanceFn<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> = SpyInstance<TArgs, TReturns> & SpyImpl<TArgs, TReturns>\n\nexport interface MockWithArgs<T extends Procedure>\n  extends SpyInstanceFn<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<SpyInstance>()\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): SpyInstance<[], T[S]>\nexport function spyOn<T, G extends Properties<Required<T>>>(\n  obj: T,\n  methodName: G,\n  accesType: 'set',\n): SpyInstance<[T[G]], void>\nexport function spyOn<T, M extends (Methods<Required<T>> | Classes<Required<T>>)>(\n  obj: T,\n  methodName: M,\n): Required<T>[M] extends (...args: infer A) => infer R | (new (...args: infer A) => infer R) ? SpyInstance<A, R> : never\nexport function spyOn<T, K extends keyof T>(\n  obj: T,\n  method: K,\n  accessType?: 'get' | 'set',\n): SpyInstance {\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 SpyInstance\n}\n\nlet callOrder = 0\n\nfunction enhanceSpy<TArgs extends any[], TReturns>(\n  spy: SpyImpl<TArgs, TReturns>,\n): SpyInstance<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  let invocations: number[] = []\n\n  const mockContext = {\n    get calls() {\n      return stub.calls\n    },\n    get instances() {\n      return instances\n    },\n    get invocationCallOrder() {\n      return invocations\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    invocations = []\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    invocations.push(++callOrder)\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>(): SpyInstanceFn<TArgs, R>\nexport function fn<TArgs extends any[] = any[], R = any>(\n  implementation: (...args: TArgs) => R\n): SpyInstanceFn<TArgs, R>\nexport function fn<TArgs extends any[] = any[], R = any>(\n  implementation?: (...args: TArgs) => R,\n): SpyInstanceFn<TArgs, R> {\n  return enhanceSpy(tinyspy.spyOn({ fn: implementation || (() => {}) }, 'fn')) as unknown as SpyInstanceFn\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,IAAI,SAAS,GAAG,CAAC,CAAC;AAClB,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,IAAI,WAAW,GAAG,EAAE,CAAC;AACvB,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,WAAW,CAAC;AACzB,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,WAAW,GAAG,EAAE,CAAC;AACrB,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,WAAW,CAAC,IAAI,CAAC,EAAE,SAAS,CAAC,CAAC;AAClC,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;;"}
package/dist/node.d.ts CHANGED
@@ -1,11 +1,5 @@
1
- import { Profiler } from 'inspector';
2
1
  import { ViteDevServer, TransformResult, CommonServerOptions, UserConfig as UserConfig$1, Plugin as Plugin$1 } from 'vite';
3
2
 
4
- interface FetchResult {
5
- code?: string;
6
- externalize?: string;
7
- }
8
-
9
3
  interface DepsHandlingOptions {
10
4
  external?: (string | RegExp)[];
11
5
  inline?: (string | RegExp)[];
@@ -15,6 +9,22 @@ interface DepsHandlingOptions {
15
9
  */
16
10
  fallbackCJS?: boolean;
17
11
  }
12
+ interface StartOfSourceMap {
13
+ file?: string;
14
+ sourceRoot?: string;
15
+ }
16
+ interface RawSourceMap extends StartOfSourceMap {
17
+ version: string;
18
+ sources: string[];
19
+ names: string[];
20
+ sourcesContent?: string[];
21
+ mappings: string;
22
+ }
23
+ interface FetchResult {
24
+ code?: string;
25
+ externalize?: string;
26
+ map?: RawSourceMap;
27
+ }
18
28
  interface ViteNodeResolveId {
19
29
  external?: boolean | 'absolute' | 'relative';
20
30
  id: string;
@@ -25,9 +35,9 @@ interface ViteNodeResolveId {
25
35
  interface ViteNodeServerOptions {
26
36
  /**
27
37
  * Inject inline sourcemap to modules
28
- * @default true
38
+ * @default 'inline'
29
39
  */
30
- sourcemap?: boolean;
40
+ sourcemap?: 'inline' | boolean;
31
41
  /**
32
42
  * Deps handling
33
43
  */
@@ -46,7 +56,10 @@ declare class ViteNodeServer {
46
56
  options: ViteNodeServerOptions;
47
57
  private fetchPromiseMap;
48
58
  private transformPromiseMap;
49
- private fetchCache;
59
+ fetchCache: Map<string, {
60
+ timestamp: number;
61
+ result: FetchResult;
62
+ }>;
50
63
  constructor(server: ViteDevServer, options?: ViteNodeServerOptions);
51
64
  shouldExternalize(id: string): Promise<string | false>;
52
65
  resolveId(id: string, importer?: string): Promise<ViteNodeResolveId | null>;
@@ -251,6 +264,38 @@ declare const ReportersMap: {
251
264
  };
252
265
  declare type BuiltinReporters = keyof typeof ReportersMap;
253
266
 
267
+ declare type Awaitable<T> = T | PromiseLike<T>;
268
+ declare type Arrayable<T> = T | Array<T>;
269
+ declare type ArgumentsType<T> = T extends (...args: infer U) => any ? U : never;
270
+ interface UserConsoleLog {
271
+ content: string;
272
+ type: 'stdout' | 'stderr';
273
+ taskId?: string;
274
+ time: number;
275
+ }
276
+ interface Position {
277
+ line: number;
278
+ column: number;
279
+ }
280
+ interface ParsedStack {
281
+ method: string;
282
+ file: string;
283
+ line: number;
284
+ column: number;
285
+ sourcePos?: Position;
286
+ }
287
+ interface ErrorWithDiff extends Error {
288
+ name: string;
289
+ nameStr?: string;
290
+ stack?: string;
291
+ stackStr?: string;
292
+ stacks?: ParsedStack[];
293
+ showDiff?: boolean;
294
+ actual?: any;
295
+ expected?: any;
296
+ operator?: string;
297
+ }
298
+
254
299
  declare type CoverageReporter = 'clover' | 'cobertura' | 'html-spa' | 'html' | 'json-summary' | 'json' | 'lcov' | 'lcovonly' | 'none' | 'teamcity' | 'text-lcov' | 'text-summary' | 'text';
255
300
  interface C8Options {
256
301
  /**
@@ -300,6 +345,7 @@ interface C8Options {
300
345
  all?: boolean;
301
346
  }
302
347
  interface ResolvedC8Options extends Required<C8Options> {
348
+ tempDirectory: string;
303
349
  }
304
350
 
305
351
  interface JSDOMOptions {
@@ -382,49 +428,6 @@ interface JSDOMOptions {
382
428
  resources?: 'usable' | any;
383
429
  }
384
430
 
385
- declare type Awaitable<T> = T | PromiseLike<T>;
386
- declare type Arrayable<T> = T | Array<T>;
387
- declare type ArgumentsType<T> = T extends (...args: infer U) => any ? U : never;
388
- interface UserConsoleLog {
389
- content: string;
390
- type: 'stdout' | 'stderr';
391
- taskId?: string;
392
- time: number;
393
- }
394
- interface Position {
395
- line: number;
396
- column: number;
397
- }
398
- interface ParsedStack {
399
- method: string;
400
- file: string;
401
- line: number;
402
- column: number;
403
- sourcePos?: Position;
404
- }
405
- interface ErrorWithDiff extends Error {
406
- name: string;
407
- nameStr?: string;
408
- stack?: string;
409
- stackStr?: string;
410
- stacks?: ParsedStack[];
411
- showDiff?: boolean;
412
- actual?: any;
413
- expected?: any;
414
- operator?: string;
415
- }
416
- interface StartOfSourceMap {
417
- file?: string;
418
- sourceRoot?: string;
419
- }
420
- interface RawSourceMap extends StartOfSourceMap {
421
- version: string;
422
- sources: string[];
423
- names: string[];
424
- sourcesContent?: string[];
425
- mappings: string;
426
- }
427
-
428
431
  declare type RunMode = 'run' | 'skip' | 'only' | 'todo';
429
432
  declare type TaskState = RunMode | 'pass' | 'fail';
430
433
  interface TaskBase {
@@ -698,10 +701,16 @@ interface InlineConfig {
698
701
  */
699
702
  api?: boolean | number | ApiConfig;
700
703
  /**
701
- * Open Vitest UI
704
+ * Enable Vitest UI
702
705
  * @internal WIP
703
706
  */
704
707
  ui?: boolean;
708
+ /**
709
+ * Open UI automatically.
710
+ *
711
+ * @default true
712
+ */
713
+ open?: boolean;
705
714
  /**
706
715
  * Base url for the UI
707
716
  *
@@ -756,6 +765,10 @@ interface UserConfig extends InlineConfig {
756
765
  * Pass with no tests
757
766
  */
758
767
  passWithNoTests?: boolean;
768
+ /**
769
+ * Allow tests and suites that are marked as only
770
+ */
771
+ allowOnly?: boolean;
759
772
  /**
760
773
  * Run tests that cover a list of source files
761
774
  */
@@ -806,7 +819,6 @@ declare class Vitest {
806
819
  server: ViteDevServer;
807
820
  state: StateManager;
808
821
  snapshot: SnapshotManager;
809
- coverage: Profiler.TakePreciseCoverageReturnType[];
810
822
  reporters: Reporter[];
811
823
  console: Console;
812
824
  pool: WorkerPool | undefined;
@@ -819,7 +831,6 @@ declare class Vitest {
819
831
  vitenode: ViteNodeServer;
820
832
  invalidates: Set<string>;
821
833
  changedTests: Set<string>;
822
- visitedFilesMap: Map<string, RawSourceMap>;
823
834
  runningPromise?: Promise<void>;
824
835
  closingPromise?: Promise<void>;
825
836
  isFirstRun: boolean;
@@ -855,6 +866,6 @@ declare class Vitest {
855
866
 
856
867
  declare function createVitest(options: UserConfig, viteOverrides?: UserConfig$1): Promise<Vitest>;
857
868
 
858
- declare function VitestPlugin(options?: UserConfig, viteOverrides?: UserConfig$1, ctx?: Vitest): Promise<Plugin$1[]>;
869
+ declare function VitestPlugin(options?: UserConfig, ctx?: Vitest): Promise<Plugin$1[]>;
859
870
 
860
871
  export { Vitest, VitestPlugin, createVitest };
package/dist/node.js CHANGED
@@ -1,4 +1,4 @@
1
- export { V as VitestPlugin, c as createVitest } from './create-0d7ef684.js';
1
+ export { V as VitestPlugin, c as createVitest } from './create-a1bc541a.js';
2
2
  import './index-1964368a.js';
3
3
  import 'path';
4
4
  import 'vite';
@@ -10,18 +10,20 @@ import 'os';
10
10
  import 'util';
11
11
  import 'stream';
12
12
  import 'events';
13
- import './index-a2ff0e29.js';
13
+ import './index-fcd4a465.js';
14
14
  import 'tty';
15
15
  import 'local-pkg';
16
- import './index-1085cee5.js';
16
+ import './client-f15310bf.js';
17
17
  import 'module';
18
18
  import 'assert';
19
+ import 'vm';
20
+ import 'v8';
19
21
  import 'perf_hooks';
20
- import './diff-f479c2ad.js';
21
- import './source-map-f7a4da05.js';
22
- import './index-825cb54c.js';
23
- import './_commonjsHelpers-bdec4bbd.js';
22
+ import './diff-192d8dc6.js';
23
+ import './source-map-a9204b39.js';
24
+ import './index-648e7ab2.js';
25
+ import './_commonjsHelpers-c9e3b764.js';
24
26
  import 'worker_threads';
25
27
  import 'tinypool';
26
28
  import './magic-string.es-94000aea.js';
27
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9kZS5qcyIsInNvdXJjZXMiOltdLCJzb3VyY2VzQ29udGVudCI6W10sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7In0=
29
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9kZS5qcyIsInNvdXJjZXMiOltdLCJzb3VyY2VzQ29udGVudCI6W10sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OzsifQ==