feat(marketing-pages): add ui/query + barrel + feature test
This commit is contained in:
@@ -1 +1,4 @@
|
||||
export {};
|
||||
export type { Page, PageStatus, Hero } from "./entities/page";
|
||||
export type { SiteSettings } from "./entities/site-settings";
|
||||
export { PageNotFoundError, InputParseError } from "./entities/errors";
|
||||
export { pageBySlugQuery, siteSettingsQuery } from "./ui/query";
|
||||
|
||||
14
packages/marketing-pages/src/ui/query.ts
Normal file
14
packages/marketing-pages/src/ui/query.ts
Normal file
@@ -0,0 +1,14 @@
|
||||
type TrpcClient = {
|
||||
marketingPages: {
|
||||
pageBySlug: { queryOptions: (input: { slug: string }) => unknown };
|
||||
siteSettings: { queryOptions: () => unknown };
|
||||
};
|
||||
};
|
||||
|
||||
export function pageBySlugQuery(client: TrpcClient, slug: string) {
|
||||
return client.marketingPages.pageBySlug.queryOptions({ slug });
|
||||
}
|
||||
|
||||
export function siteSettingsQuery(client: TrpcClient) {
|
||||
return client.marketingPages.siteSettings.queryOptions();
|
||||
}
|
||||
33
packages/marketing-pages/tests/page-by-slug.feature.test.ts
Normal file
33
packages/marketing-pages/tests/page-by-slug.feature.test.ts
Normal file
@@ -0,0 +1,33 @@
|
||||
import { beforeEach, describe, expect, it } from "vitest";
|
||||
import { marketingPagesContainer } from "../src/di/container";
|
||||
import { MARKETING_PAGES_SYMBOLS } from "../src/di/symbols";
|
||||
import { MockPagesRepository } from "../src/infrastructure/repositories/mock-pages.repository";
|
||||
import { MockSiteSettingsRepository } from "../src/infrastructure/repositories/mock-site-settings.repository";
|
||||
import type { IPagesRepository } from "../src/application/repositories/pages-repository.interface";
|
||||
import type { ISiteSettingsRepository } from "../src/application/repositories/site-settings-repository.interface";
|
||||
import { marketingPagesRouter } from "../src/integrations/api/router";
|
||||
|
||||
describe("marketing-pages feature: page-by-slug end-to-end", () => {
|
||||
beforeEach(() => {
|
||||
if (marketingPagesContainer.isBound(MARKETING_PAGES_SYMBOLS.IPagesRepository)) {
|
||||
marketingPagesContainer.unbind(MARKETING_PAGES_SYMBOLS.IPagesRepository);
|
||||
}
|
||||
if (marketingPagesContainer.isBound(MARKETING_PAGES_SYMBOLS.ISiteSettingsRepository)) {
|
||||
marketingPagesContainer.unbind(MARKETING_PAGES_SYMBOLS.ISiteSettingsRepository);
|
||||
}
|
||||
marketingPagesContainer
|
||||
.bind<IPagesRepository>(MARKETING_PAGES_SYMBOLS.IPagesRepository)
|
||||
.toConstantValue(new MockPagesRepository());
|
||||
marketingPagesContainer
|
||||
.bind<ISiteSettingsRepository>(MARKETING_PAGES_SYMBOLS.ISiteSettingsRepository)
|
||||
.toConstantValue(new MockSiteSettingsRepository());
|
||||
});
|
||||
|
||||
it("fetches a page by slug via tRPC and returns the domain entity", async () => {
|
||||
const caller = marketingPagesRouter.createCaller({});
|
||||
const page = await caller.pageBySlug({ slug: "about" });
|
||||
expect(page?.title).toBe("About");
|
||||
expect(page?.hero.heading).toBe("About us");
|
||||
expect(page?.status).toBe("published");
|
||||
});
|
||||
});
|
||||
Reference in New Issue
Block a user