@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
TypeScript
/**
* @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;