Media is now a complete vertical-feature package mirroring auth/blog structure: entities (models + errors), application (repositories + use-cases), infrastructure (real Payload-backed + mock siblings), interface-adapters (per-use-case controllers), DI (symbols + module + container + bind-production), integrations/api (mediaRouter), factory, contract suite, and feature integration tests. Wired into: - packages/core-api/src/root.ts (added `media: mediaRouter`) - apps/web-next/src/server/bind-production.ts (calls bindProductionMedia) - tsconfig.base.json (added @repo/media/api and ./di/bind-production aliases) 56 new tests in @repo/media (13 test files); core-api router test updated to assert media. procedures. All 26 turbo tasks green. Refactor log: §2, §4.1, §4.2, §5.1, §6.1 Spec: §6.5 Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
42 lines
1.4 KiB
TypeScript
42 lines
1.4 KiB
TypeScript
import { describe, it, expect } from "vitest";
|
|
import { listMediaController } from "@/interface-adapters/controllers/list-media.controller";
|
|
import { listMediaUseCase } from "@/application/use-cases/list-media.use-case";
|
|
import { MockMediaRepository } from "@/infrastructure/repositories/media.repository.mock";
|
|
import { mediaFactory } from "@/__factories__/media.factory";
|
|
|
|
describe("listMediaController", () => {
|
|
it("returns empty array when no media exists", async () => {
|
|
const repo = new MockMediaRepository();
|
|
const useCase = listMediaUseCase(repo);
|
|
const controller = listMediaController(useCase);
|
|
|
|
const result = await controller({});
|
|
expect(result).toHaveLength(0);
|
|
});
|
|
|
|
it("returns all media", async () => {
|
|
const repo = new MockMediaRepository();
|
|
await repo._store(mediaFactory.build());
|
|
await repo._store(mediaFactory.build());
|
|
|
|
const useCase = listMediaUseCase(repo);
|
|
const controller = listMediaController(useCase);
|
|
|
|
const result = await controller({});
|
|
expect(result).toHaveLength(2);
|
|
});
|
|
|
|
it("passes limit and offset to use case", async () => {
|
|
const repo = new MockMediaRepository();
|
|
for (let i = 0; i < 5; i++) {
|
|
await repo._store(mediaFactory.build());
|
|
}
|
|
|
|
const useCase = listMediaUseCase(repo);
|
|
const controller = listMediaController(useCase);
|
|
|
|
const result = await controller({ limit: 2, offset: 1 });
|
|
expect(result).toHaveLength(2);
|
|
});
|
|
});
|