openclaw/extensions/imessage/src/monitor/reflection-guard.test.ts

108 lines
4.0 KiB
TypeScript

import { describe, expect, it } from "vitest";
import { detectReflectedContent } from "./reflection-guard.js";
describe("detectReflectedContent", () => {
it("returns false for empty text", () => {
expect(detectReflectedContent("").isReflection).toBe(false);
});
it("returns false for normal user text", () => {
const result = detectReflectedContent("Hey, what's the weather today?");
expect(result.isReflection).toBe(false);
expect(result.matchedLabels).toEqual([]);
});
it("detects +#+#+#+# separator pattern", () => {
const result = detectReflectedContent("NO_REPLY +#+#+#+#+#+assistant to=final");
expect(result.isReflection).toBe(true);
expect(result.matchedLabels).toContain("internal-separator");
});
it("detects assistant to=final marker", () => {
const result = detectReflectedContent("some text assistant to=final rest");
expect(result.isReflection).toBe(true);
expect(result.matchedLabels).toContain("assistant-role-marker");
});
it("detects <thinking> tags", () => {
const result = detectReflectedContent("<thinking>internal reasoning</thinking>");
expect(result.isReflection).toBe(true);
expect(result.matchedLabels).toContain("thinking-tag");
});
it("detects <thought> tags", () => {
const result = detectReflectedContent("<thought>secret</thought>");
expect(result.isReflection).toBe(true);
expect(result.matchedLabels).toContain("thinking-tag");
});
it("detects <relevant_memories> tags", () => {
const result = detectReflectedContent("<relevant_memories>data</relevant_memories>");
expect(result.isReflection).toBe(true);
expect(result.matchedLabels).toContain("relevant-memories-tag");
});
it("detects <final> tags", () => {
const result = detectReflectedContent("<final>visible</final>");
expect(result.isReflection).toBe(true);
expect(result.matchedLabels).toContain("final-tag");
});
it("returns multiple matched labels for combined markers", () => {
const text = "NO_REPLY +#+#+#+# <thinking>step</thinking> assistant to=final";
const result = detectReflectedContent(text);
expect(result.isReflection).toBe(true);
expect(result.matchedLabels.length).toBeGreaterThanOrEqual(3);
});
it("ignores reflection markers inside inline code", () => {
const result = detectReflectedContent(
"Please keep `<thinking>debug trace</thinking>` in the example output",
);
expect(result.isReflection).toBe(false);
expect(result.matchedLabels).toEqual([]);
});
it("ignores reflection markers inside fenced code blocks", () => {
const result = detectReflectedContent(
[
"User pasted a repro snippet:",
"```xml",
"<relevant_memories>cached</relevant_memories>",
"assistant to=final",
"```",
].join("\n"),
);
expect(result.isReflection).toBe(false);
expect(result.matchedLabels).toEqual([]);
});
it("still flags markers that appear outside code blocks", () => {
const result = detectReflectedContent(
["```xml", "<thinking>inside code</thinking>", "```", "", "assistant to=final"].join("\n"),
);
expect(result.isReflection).toBe(true);
expect(result.matchedLabels).toContain("assistant-role-marker");
});
it("does not flag normal code discussion about thinking", () => {
const result = detectReflectedContent("I was thinking about your question");
expect(result.isReflection).toBe(false);
});
it("flags '<final answer>' as reflection when it forms a complete tag", () => {
const result = detectReflectedContent("Here is my <final answer>");
expect(result.isReflection).toBe(true);
});
it("does not flag partial tag without closing bracket", () => {
const result = detectReflectedContent("I sent a <final draft, see below");
expect(result.isReflection).toBe(false);
});
it("does not flag '<thought experiment>' phrase without closing bracket", () => {
const result = detectReflectedContent("This is a <thought experiment I ran");
expect(result.isReflection).toBe(false);
});
});