UNPKG

@daiso-tech/core

Version:

The library offers flexible, framework-agnostic solutions for modern web applications, built on adaptable components that integrate seamlessly with popular frameworks like Next Js.

68 lines (67 loc) 2.35 kB
/** * @module Lock */ import { type TestAPI, type SuiteAPI, type ExpectStatic, type beforeEach } from "vitest"; import type { ILockProvider } from "../../../lock/contracts/_module-exports.js"; import { type Promisable } from "../../../utilities/_module-exports.js"; import type { ISerde } from "../../../serde/contracts/_module-exports.js"; /** * * IMPORT_PATH: `"@daiso-tech/core/lock/test-utilities"` * @group Utilities */ export type LockProviderTestSuiteSettings = { expect: ExpectStatic; test: TestAPI; describe: SuiteAPI; beforeEach: typeof beforeEach; createLockProvider: () => Promisable<{ lockProvider: ILockProvider; serde: ISerde; }>; /** * @default true */ excludeSerdeTests?: boolean; /** * @default true */ excludeEventTests?: boolean; }; /** * The `lockProviderTestSuite` function simplifies the process of testing your custom implementation of {@link ILock | `ILock`} with `vitest`. * * IMPORT_PATH: `"@daiso-tech/core/lock/test-utilities"` * @group Utilities * @example * ```ts * import { describe, expect, test, beforeEach } from "vitest"; * import { MemoryLockAdapter } from "@daiso-tech/core/lock/memory-lock-adapter"; * import { LockProvider } from "@daiso-tech/core/lock"; * import { EventBus } from "@daiso-tech/core/event-bus"; * import { MemoryEventBusAdapter } from "@daiso-tech/core/event-bus/memory-event-bus-adapter"; * import { lockProviderTestSuite } from "@daiso-tech/core/lock/test-utilities"; * import { Serde } from "@daiso-tech/core/serde"; * import { SuperJsonSerdeAdapter } from "@daiso-tech/core/serde/super-json-serde-adapter"; * import type { ILockData } from "@daiso-tech/core/lock/contracts"; * * describe("class: LockProvider", () => { * lockProviderTestSuite({ * createLockProvider: () => { * const serde = new Serde(new SuperJsonSerdeAdapter()); * const lockProvider = new LockProvider({ * serde, * adapter: new MemoryLockAdapter(), * }); * return { lockProvider, serde }; * }, * beforeEach, * describe, * expect, * test, * serde, * }); * }); * ``` */ export declare function lockProviderTestSuite(settings: LockProviderTestSuiteSettings): void;