Total 1465 LOC + 616 test LOC, 78/78 tests pass. - @keisei/mcp-server (25 tests) — Rust-CLI bridge via execa, stdio+HTTP, HMAC auth, kei() meta-tool - @keisei/telegram-adapter (16 tests) — grammy Bot, 7 tools - @keisei/recall-adapter (8 tests) — Zoom via Recall.ai, 5 tools - @keisei/grok-adapter (6 tests) — xAI OpenAI-compatible, 2 tools - @keisei/gmail-adapter (11 tests) — googleapis OAuth2, 6 tools (new — LBM gap) - @keisei/youtube-adapter (12 tests) — YouTube Data API v3, 5 tools (new — LBM gap) RULE 0.2 exception #4 (TS for MCP/API layer documented in _ts_packages/README.md). RULE 0.8 — env vars only (TELEGRAM_BOT_TOKEN, XAI_API_KEY, GMAIL_*, YOUTUBE_API_KEY). Strict TypeScript: strict + exactOptionalPropertyTypes + noUncheckedIndexedAccess. Genesis-scan clean (0 hits).
31 lines
1 KiB
TypeScript
31 lines
1 KiB
TypeScript
import { describe, it, expect } from "vitest";
|
|
import { buildRegistry, lookupTool, RUST_PRIMITIVE_TOOLS } from "../src/tool-registry.js";
|
|
import { RustBridge } from "../src/rust-bridge.js";
|
|
import { ToolNotFoundError } from "../src/errors.js";
|
|
|
|
describe("tool registry", () => {
|
|
const bridge = new RustBridge({ binDir: "/tmp/stub" });
|
|
const registry = buildRegistry(bridge);
|
|
|
|
it("registers one tool per Rust primitive", () => {
|
|
for (const t of RUST_PRIMITIVE_TOOLS) {
|
|
expect(registry.has(t.binary)).toBe(true);
|
|
}
|
|
});
|
|
|
|
it("registers the kei meta-tool", () => {
|
|
const t = lookupTool(registry, "kei");
|
|
expect(t.name).toBe("kei");
|
|
expect(t.description).toContain("Meta-tool");
|
|
});
|
|
|
|
it("lookupTool throws ToolNotFoundError for unknown names", () => {
|
|
expect(() => lookupTool(registry, "nonexistent-tool")).toThrow(ToolNotFoundError);
|
|
});
|
|
|
|
it("tool description is non-empty for each primitive", () => {
|
|
for (const t of RUST_PRIMITIVE_TOOLS) {
|
|
expect(t.desc.length).toBeGreaterThan(10);
|
|
}
|
|
});
|
|
});
|