mirror of
https://github.com/openclaw/openclaw.git
synced 2026-03-16 12:30:49 +00:00
* BlueBubbles: drop reflected self-chat duplicates * Changelog: add BlueBubbles self-chat echo dedupe entry * BlueBubbles: gate self-chat cache and expand coverage * BlueBubbles: require explicit sender ids for self-chat dedupe * BlueBubbles: harden self-chat cache * BlueBubbles: move self-chat cache identity into cache * BlueBubbles: gate self-chat cache to confirmed outbound sends * Update CHANGELOG.md * BlueBubbles: bound self-chat cache input work * Tests: cover BlueBubbles cache cap under cleanup throttle * BlueBubbles: canonicalize self-chat DM scope * Tests: cover BlueBubbles mixed self-chat scope aliases
99 lines
2.7 KiB
TypeScript
99 lines
2.7 KiB
TypeScript
import { describe, expect, it } from "vitest";
|
|
import { normalizeWebhookMessage, normalizeWebhookReaction } from "./monitor-normalize.js";
|
|
|
|
describe("normalizeWebhookMessage", () => {
|
|
it("falls back to DM chatGuid handle when sender handle is missing", () => {
|
|
const result = normalizeWebhookMessage({
|
|
type: "new-message",
|
|
data: {
|
|
guid: "msg-1",
|
|
text: "hello",
|
|
isGroup: false,
|
|
isFromMe: false,
|
|
handle: null,
|
|
chatGuid: "iMessage;-;+15551234567",
|
|
},
|
|
});
|
|
|
|
expect(result).not.toBeNull();
|
|
expect(result?.senderId).toBe("+15551234567");
|
|
expect(result?.senderIdExplicit).toBe(false);
|
|
expect(result?.chatGuid).toBe("iMessage;-;+15551234567");
|
|
});
|
|
|
|
it("marks explicit sender handles as explicit identity", () => {
|
|
const result = normalizeWebhookMessage({
|
|
type: "new-message",
|
|
data: {
|
|
guid: "msg-explicit-1",
|
|
text: "hello",
|
|
isGroup: false,
|
|
isFromMe: true,
|
|
handle: { address: "+15551234567" },
|
|
chatGuid: "iMessage;-;+15551234567",
|
|
},
|
|
});
|
|
|
|
expect(result).not.toBeNull();
|
|
expect(result?.senderId).toBe("+15551234567");
|
|
expect(result?.senderIdExplicit).toBe(true);
|
|
});
|
|
|
|
it("does not infer sender from group chatGuid when sender handle is missing", () => {
|
|
const result = normalizeWebhookMessage({
|
|
type: "new-message",
|
|
data: {
|
|
guid: "msg-1",
|
|
text: "hello group",
|
|
isGroup: true,
|
|
isFromMe: false,
|
|
handle: null,
|
|
chatGuid: "iMessage;+;chat123456",
|
|
},
|
|
});
|
|
|
|
expect(result).toBeNull();
|
|
});
|
|
|
|
it("accepts array-wrapped payload data", () => {
|
|
const result = normalizeWebhookMessage({
|
|
type: "new-message",
|
|
data: [
|
|
{
|
|
guid: "msg-1",
|
|
text: "hello",
|
|
handle: { address: "+15551234567" },
|
|
isGroup: false,
|
|
isFromMe: false,
|
|
},
|
|
],
|
|
});
|
|
|
|
expect(result).not.toBeNull();
|
|
expect(result?.senderId).toBe("+15551234567");
|
|
});
|
|
});
|
|
|
|
describe("normalizeWebhookReaction", () => {
|
|
it("falls back to DM chatGuid handle when reaction sender handle is missing", () => {
|
|
const result = normalizeWebhookReaction({
|
|
type: "updated-message",
|
|
data: {
|
|
guid: "msg-2",
|
|
associatedMessageGuid: "p:0/msg-1",
|
|
associatedMessageType: 2000,
|
|
isGroup: false,
|
|
isFromMe: false,
|
|
handle: null,
|
|
chatGuid: "iMessage;-;+15551234567",
|
|
},
|
|
});
|
|
|
|
expect(result).not.toBeNull();
|
|
expect(result?.senderId).toBe("+15551234567");
|
|
expect(result?.senderIdExplicit).toBe(false);
|
|
expect(result?.messageId).toBe("p:0/msg-1");
|
|
expect(result?.action).toBe("added");
|
|
});
|
|
});
|