mirror of
https://github.com/openclaw/openclaw.git
synced 2026-05-03 16:30:23 +00:00
test: dedupe fixtures and test harness setup
This commit is contained in:
@@ -26,6 +26,23 @@ describe("web monitor inbox", () => {
|
||||
});
|
||||
}
|
||||
|
||||
async function runSingleUpsertAndCapture(upsert: unknown) {
|
||||
const onMessage = vi.fn();
|
||||
const listener = await openMonitor(onMessage);
|
||||
const sock = getSock();
|
||||
sock.ev.emit("messages.upsert", upsert);
|
||||
await new Promise((resolve) => setImmediate(resolve));
|
||||
return { onMessage, listener };
|
||||
}
|
||||
|
||||
function expectSingleGroupMessage(
|
||||
onMessage: ReturnType<typeof vi.fn>,
|
||||
expected: Record<string, unknown>,
|
||||
) {
|
||||
expect(onMessage).toHaveBeenCalledTimes(1);
|
||||
expect(onMessage).toHaveBeenCalledWith(expect.objectContaining(expected));
|
||||
}
|
||||
|
||||
it("captures media path for image messages", async () => {
|
||||
const onMessage = vi.fn();
|
||||
const listener = await openMonitor(onMessage);
|
||||
@@ -203,10 +220,7 @@ describe("web monitor inbox", () => {
|
||||
});
|
||||
|
||||
it("unwraps ephemeral messages, preserves mentions, and still delivers group pings", async () => {
|
||||
const onMessage = vi.fn();
|
||||
const listener = await openMonitor(onMessage);
|
||||
const sock = getSock();
|
||||
const upsert = {
|
||||
const { onMessage, listener } = await runSingleUpsertAndCapture({
|
||||
type: "notify",
|
||||
messages: [
|
||||
{
|
||||
@@ -228,22 +242,14 @@ describe("web monitor inbox", () => {
|
||||
},
|
||||
},
|
||||
],
|
||||
};
|
||||
|
||||
sock.ev.emit("messages.upsert", upsert);
|
||||
await new Promise((resolve) => setImmediate(resolve));
|
||||
|
||||
expect(onMessage).toHaveBeenCalledTimes(1);
|
||||
expect(onMessage).toHaveBeenCalledWith(
|
||||
expect.objectContaining({
|
||||
chatType: "group",
|
||||
conversationId: "424242@g.us",
|
||||
body: "oh hey @Clawd UK !",
|
||||
mentionedJids: ["123@s.whatsapp.net"],
|
||||
senderE164: "+888",
|
||||
}),
|
||||
);
|
||||
|
||||
});
|
||||
expectSingleGroupMessage(onMessage, {
|
||||
chatType: "group",
|
||||
conversationId: "424242@g.us",
|
||||
body: "oh hey @Clawd UK !",
|
||||
mentionedJids: ["123@s.whatsapp.net"],
|
||||
senderE164: "+888",
|
||||
});
|
||||
await listener.close();
|
||||
});
|
||||
|
||||
@@ -262,10 +268,7 @@ describe("web monitor inbox", () => {
|
||||
},
|
||||
});
|
||||
|
||||
const onMessage = vi.fn();
|
||||
const listener = await openMonitor(onMessage);
|
||||
const sock = getSock();
|
||||
const upsert = {
|
||||
const { onMessage, listener } = await runSingleUpsertAndCapture({
|
||||
type: "notify",
|
||||
messages: [
|
||||
{
|
||||
@@ -283,24 +286,16 @@ describe("web monitor inbox", () => {
|
||||
},
|
||||
},
|
||||
],
|
||||
};
|
||||
|
||||
sock.ev.emit("messages.upsert", upsert);
|
||||
await new Promise((resolve) => setImmediate(resolve));
|
||||
|
||||
expect(onMessage).toHaveBeenCalledTimes(1);
|
||||
expect(onMessage).toHaveBeenCalledWith(
|
||||
expect.objectContaining({
|
||||
chatType: "group",
|
||||
from: "55555@g.us",
|
||||
senderE164: "+777",
|
||||
senderJid: "777@s.whatsapp.net",
|
||||
mentionedJids: ["123@s.whatsapp.net"],
|
||||
selfE164: "+123",
|
||||
selfJid: "123@s.whatsapp.net",
|
||||
}),
|
||||
);
|
||||
|
||||
});
|
||||
expectSingleGroupMessage(onMessage, {
|
||||
chatType: "group",
|
||||
from: "55555@g.us",
|
||||
senderE164: "+777",
|
||||
senderJid: "777@s.whatsapp.net",
|
||||
mentionedJids: ["123@s.whatsapp.net"],
|
||||
selfE164: "+123",
|
||||
selfJid: "123@s.whatsapp.net",
|
||||
});
|
||||
await listener.close();
|
||||
});
|
||||
});
|
||||
|
||||
Reference in New Issue
Block a user