Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 2 additions & 0 deletions src/controllers/controllers.ts
Original file line number Diff line number Diff line change
Expand Up @@ -46,3 +46,5 @@ export function createController<
},
};
}

export const controller = createController;
83 changes: 83 additions & 0 deletions src/factory-aliases.test.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,83 @@
import { describe, test, TestContext } from "node:test";
import {
adapter,
controller,
createApp,
hooks,
installer,
mod,
provider,
} from "./index";

describe("factory aliases", () => {
test("compose modules using shorthand helpers", async (t: TestContext) => {
const users = provider({
name: "alias-users",
expose: async () => ({
find: () => "Jean",
}),
});

const versionAdapter = adapter({
name: "alias-version",
expose: async ({ fastify }) => fastify.version,
});

const httpHooks = hooks({
type: "http",
deps: { users },
adaps: { version: versionAdapter },
build: async ({ builder, deps, adaps }) => {
builder.addHook("onRequest", async (_req, reply) => {
reply.header(
"x-alias-hooks",
`${deps.users.find()}@${adaps.version}`,
);
});
},
});

const decorators = installer({
deps: { users },
install: async ({ fastify, deps }) => {
fastify.decorate("aliasLookup", () => deps.users.find());
},
});

const aliasController = controller({
deps: { users },
build: ({ builder, deps }) => {
builder.addRoute({
url: "/",
method: "GET",
handler: async (req) => {
const lookup = req.server.getDecorator<() => string>("aliasLookup");
return {
viaController: deps.users.find(),
viaInstaller: lookup(),
};
},
});
},
});

const root = mod({
name: "alias-root",
hooks: [httpHooks],
installers: [decorators],
controllers: [aliasController],
});

const app = await createApp({ root });
const res = await app.inject({ method: "GET", url: "/" });
const json = res.json();

t.assert.deepStrictEqual(json, {
viaController: "Jean",
viaInstaller: "Jean",
});
t.assert.strictEqual(res.headers["x-alias-hooks"], `Jean@${app.version}`);

await app.close();
});
});
2 changes: 2 additions & 0 deletions src/fastify/adapters.ts
Original file line number Diff line number Diff line change
Expand Up @@ -42,3 +42,5 @@ export async function resolveAdapterMap<AMap extends AdapterMap>(

return out as AdapterValues<AMap>;
}

export const adapter = createAdapter;
2 changes: 2 additions & 0 deletions src/fastify/installers.ts
Original file line number Diff line number Diff line change
Expand Up @@ -28,3 +28,5 @@ export function createInstaller<Providers extends ProvidersMap>(
},
};
}

export const installer = createInstaller;
2 changes: 2 additions & 0 deletions src/hooks/hooks.ts
Original file line number Diff line number Diff line change
Expand Up @@ -72,3 +72,5 @@ export function createHooks<
},
};
}

export const hooks = createHooks;
2 changes: 2 additions & 0 deletions src/modules/module.ts
Original file line number Diff line number Diff line change
Expand Up @@ -97,3 +97,5 @@ export async function resolveProviderMap(

return out;
}

export const mod = createModule;
2 changes: 2 additions & 0 deletions src/providers/providers.ts
Original file line number Diff line number Diff line change
Expand Up @@ -68,6 +68,8 @@ export function createProvider<
return self;
}

export const provider = createProvider;

export async function resolveDeps(
container: Container,
prov: ProviderAny,
Expand Down