test(gateway): cover internal provider defaults
This commit is contained in:
@@ -268,7 +268,10 @@ describe("sessions tools", () => {
|
|||||||
);
|
);
|
||||||
expect(agentCalls).toHaveLength(8);
|
expect(agentCalls).toHaveLength(8);
|
||||||
for (const call of agentCalls) {
|
for (const call of agentCalls) {
|
||||||
expect(call.params).toMatchObject({ lane: "nested" });
|
expect(call.params).toMatchObject({
|
||||||
|
lane: "nested",
|
||||||
|
provider: "webchat",
|
||||||
|
});
|
||||||
}
|
}
|
||||||
expect(
|
expect(
|
||||||
agentCalls.some(
|
agentCalls.some(
|
||||||
@@ -394,6 +397,15 @@ describe("sessions tools", () => {
|
|||||||
await new Promise((resolve) => setTimeout(resolve, 0));
|
await new Promise((resolve) => setTimeout(resolve, 0));
|
||||||
await new Promise((resolve) => setTimeout(resolve, 0));
|
await new Promise((resolve) => setTimeout(resolve, 0));
|
||||||
|
|
||||||
|
const agentCalls = calls.filter((call) => call.method === "agent");
|
||||||
|
expect(agentCalls).toHaveLength(4);
|
||||||
|
for (const call of agentCalls) {
|
||||||
|
expect(call.params).toMatchObject({
|
||||||
|
lane: "nested",
|
||||||
|
provider: "webchat",
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
const replySteps = calls.filter(
|
const replySteps = calls.filter(
|
||||||
(call) =>
|
(call) =>
|
||||||
call.method === "agent" &&
|
call.method === "agent" &&
|
||||||
|
|||||||
@@ -169,6 +169,12 @@ describe("subagents", () => {
|
|||||||
expect(first?.provider).toBe("discord");
|
expect(first?.provider).toBe("discord");
|
||||||
expect(first?.sessionKey?.startsWith("agent:main:subagent:")).toBe(true);
|
expect(first?.sessionKey?.startsWith("agent:main:subagent:")).toBe(true);
|
||||||
expect(childSessionKey?.startsWith("agent:main:subagent:")).toBe(true);
|
expect(childSessionKey?.startsWith("agent:main:subagent:")).toBe(true);
|
||||||
|
const second = agentCalls[1]?.params as
|
||||||
|
| { provider?: string; deliver?: boolean; lane?: string }
|
||||||
|
| undefined;
|
||||||
|
expect(second?.lane).toBe("nested");
|
||||||
|
expect(second?.deliver).toBe(false);
|
||||||
|
expect(second?.provider).toBe("webchat");
|
||||||
|
|
||||||
expect(sendParams.provider).toBe("discord");
|
expect(sendParams.provider).toBe("discord");
|
||||||
expect(sendParams.to).toBe("channel:req");
|
expect(sendParams.to).toBe("channel:req");
|
||||||
|
|||||||
@@ -375,6 +375,50 @@ describe("gateway server agent", () => {
|
|||||||
await server.close();
|
await server.close();
|
||||||
});
|
});
|
||||||
|
|
||||||
|
test("agent uses webchat for internal runs when last provider is webchat", async () => {
|
||||||
|
const dir = await fs.mkdtemp(path.join(os.tmpdir(), "clawdbot-gw-"));
|
||||||
|
testState.sessionStorePath = path.join(dir, "sessions.json");
|
||||||
|
await fs.writeFile(
|
||||||
|
testState.sessionStorePath,
|
||||||
|
JSON.stringify(
|
||||||
|
{
|
||||||
|
main: {
|
||||||
|
sessionId: "sess-main-webchat-internal",
|
||||||
|
updatedAt: Date.now(),
|
||||||
|
lastProvider: "webchat",
|
||||||
|
lastTo: "+1555",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
null,
|
||||||
|
2,
|
||||||
|
),
|
||||||
|
"utf-8",
|
||||||
|
);
|
||||||
|
|
||||||
|
const { server, ws } = await startServerWithClient();
|
||||||
|
await connectOk(ws);
|
||||||
|
|
||||||
|
const res = await rpcReq(ws, "agent", {
|
||||||
|
message: "hi",
|
||||||
|
sessionKey: "main",
|
||||||
|
provider: "last",
|
||||||
|
deliver: false,
|
||||||
|
idempotencyKey: "idem-agent-webchat-internal",
|
||||||
|
});
|
||||||
|
expect(res.ok).toBe(true);
|
||||||
|
|
||||||
|
const spy = vi.mocked(agentCommand);
|
||||||
|
const call = spy.mock.calls.at(-1)?.[0] as Record<string, unknown>;
|
||||||
|
expectProviders(call, "webchat");
|
||||||
|
expect(call.to).toBeUndefined();
|
||||||
|
expect(call.deliver).toBe(false);
|
||||||
|
expect(call.bestEffortDeliver).toBe(true);
|
||||||
|
expect(call.sessionId).toBe("sess-main-webchat-internal");
|
||||||
|
|
||||||
|
ws.close();
|
||||||
|
await server.close();
|
||||||
|
});
|
||||||
|
|
||||||
test(
|
test(
|
||||||
"agent ack response then final response",
|
"agent ack response then final response",
|
||||||
{ timeout: 8000 },
|
{ timeout: 8000 },
|
||||||
|
|||||||
12
src/utils/message-provider.test.ts
Normal file
12
src/utils/message-provider.test.ts
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
import { describe, expect, it } from "vitest";
|
||||||
|
|
||||||
|
import { resolveGatewayMessageProvider } from "./message-provider.js";
|
||||||
|
|
||||||
|
describe("message-provider", () => {
|
||||||
|
it("normalizes gateway message providers and rejects unknown values", () => {
|
||||||
|
expect(resolveGatewayMessageProvider("discord")).toBe("discord");
|
||||||
|
expect(resolveGatewayMessageProvider(" imsg ")).toBe("imessage");
|
||||||
|
expect(resolveGatewayMessageProvider("teams")).toBe("msteams");
|
||||||
|
expect(resolveGatewayMessageProvider("nope")).toBeUndefined();
|
||||||
|
});
|
||||||
|
});
|
||||||
Reference in New Issue
Block a user