d9476abecb
Co-Authored-By: Paperclip <noreply@paperclip.ing>
74 lines
2.5 KiB
TypeScript
74 lines
2.5 KiB
TypeScript
import { describe, expect, it } from "vitest";
|
|
import { buildTranscript, type RunLogChunk } from "./transcript";
|
|
import type { UIAdapterModule } from "./types";
|
|
|
|
describe("buildTranscript", () => {
|
|
const ts = "2026-03-20T13:00:00.000Z";
|
|
const chunks: RunLogChunk[] = [
|
|
{ ts, stream: "stdout", chunk: "opened /Users/dotta/project\n" },
|
|
{ ts, stream: "stderr", chunk: "stderr /Users/dotta/project" },
|
|
];
|
|
|
|
it("defaults username censoring to off when options are omitted", () => {
|
|
const entries = buildTranscript(chunks, (line, entryTs) => [{ kind: "stdout", ts: entryTs, text: line }]);
|
|
|
|
expect(entries).toEqual([
|
|
{ kind: "stdout", ts, text: "opened /Users/dotta/project" },
|
|
{ kind: "stderr", ts, text: "stderr /Users/dotta/project" },
|
|
]);
|
|
});
|
|
|
|
it("still redacts usernames when explicitly enabled", () => {
|
|
const entries = buildTranscript(chunks, (line, entryTs) => [{ kind: "stdout", ts: entryTs, text: line }], {
|
|
censorUsernameInLogs: true,
|
|
});
|
|
|
|
expect(entries).toEqual([
|
|
{ kind: "stdout", ts, text: "opened /Users/d****/project" },
|
|
{ kind: "stderr", ts, text: "stderr /Users/d****/project" },
|
|
]);
|
|
});
|
|
|
|
it("creates a fresh stateful parser for each transcript build", () => {
|
|
const statefulAdapter: UIAdapterModule = {
|
|
type: "stateful_test",
|
|
label: "Stateful Test",
|
|
parseStdoutLine: (line, entryTs) => [{ kind: "stdout", ts: entryTs, text: line }],
|
|
createStdoutParser: () => {
|
|
let pending: string | null = null;
|
|
return {
|
|
parseLine: (line, entryTs) => {
|
|
if (line.startsWith("begin:")) {
|
|
pending = line.slice("begin:".length);
|
|
return [];
|
|
}
|
|
if (line === "finish" && pending) {
|
|
const text = `completed:${pending}`;
|
|
pending = null;
|
|
return [{ kind: "stdout", ts: entryTs, text }];
|
|
}
|
|
return [{ kind: "stdout", ts: entryTs, text: `literal:${line}` }];
|
|
},
|
|
reset: () => {
|
|
pending = null;
|
|
},
|
|
};
|
|
},
|
|
ConfigFields: () => null,
|
|
buildAdapterConfig: () => ({}),
|
|
};
|
|
|
|
const first = buildTranscript(
|
|
[{ ts, stream: "stdout", chunk: "begin:task-a\n" }],
|
|
statefulAdapter,
|
|
);
|
|
const second = buildTranscript(
|
|
[{ ts, stream: "stdout", chunk: "finish\n" }],
|
|
statefulAdapter,
|
|
);
|
|
|
|
expect(first).toEqual([]);
|
|
expect(second).toEqual([{ kind: "stdout", ts, text: "literal:finish" }]);
|
|
});
|
|
});
|