mirror of https://github.com/openclaw/openclaw.git
53 lines
1.6 KiB
TypeScript
53 lines
1.6 KiB
TypeScript
import { afterEach, describe, expect, it, vi } from "vitest";
|
|
import { emitSessionTranscriptUpdate, onSessionTranscriptUpdate } from "./transcript-events.js";
|
|
|
|
const cleanup: Array<() => void> = [];
|
|
|
|
afterEach(() => {
|
|
while (cleanup.length > 0) {
|
|
cleanup.pop()?.();
|
|
}
|
|
});
|
|
|
|
describe("transcript events", () => {
|
|
it("emits trimmed session file updates", () => {
|
|
const listener = vi.fn();
|
|
cleanup.push(onSessionTranscriptUpdate(listener));
|
|
|
|
emitSessionTranscriptUpdate(" /tmp/session.jsonl ");
|
|
|
|
expect(listener).toHaveBeenCalledTimes(1);
|
|
expect(listener).toHaveBeenCalledWith({ sessionFile: "/tmp/session.jsonl" });
|
|
});
|
|
|
|
it("includes optional session metadata when provided", () => {
|
|
const listener = vi.fn();
|
|
cleanup.push(onSessionTranscriptUpdate(listener));
|
|
|
|
emitSessionTranscriptUpdate({
|
|
sessionFile: " /tmp/session.jsonl ",
|
|
sessionKey: " agent:main:main ",
|
|
message: { role: "assistant", content: "hi" },
|
|
});
|
|
|
|
expect(listener).toHaveBeenCalledWith({
|
|
sessionFile: "/tmp/session.jsonl",
|
|
sessionKey: "agent:main:main",
|
|
message: { role: "assistant", content: "hi" },
|
|
});
|
|
});
|
|
|
|
it("continues notifying other listeners when one throws", () => {
|
|
const first = vi.fn(() => {
|
|
throw new Error("boom");
|
|
});
|
|
const second = vi.fn();
|
|
cleanup.push(onSessionTranscriptUpdate(first));
|
|
cleanup.push(onSessionTranscriptUpdate(second));
|
|
|
|
expect(() => emitSessionTranscriptUpdate("/tmp/session.jsonl")).not.toThrow();
|
|
expect(first).toHaveBeenCalledTimes(1);
|
|
expect(second).toHaveBeenCalledTimes(1);
|
|
});
|
|
});
|