Files
oh-my-openagent/src/cli/run/completion-verbose-logging.test.ts
YeonGyu-Kim a717a95e13 fix: clear spy call history in completion-verbose-logging test
spyOn(console, 'log') accumulates calls across test files in bun:test.
Add mockClear() after spy creation to prevent cross-file contamination
when run in the same bun test batch as completion.test.ts.
2026-02-18 17:43:16 +09:00

79 lines
2.3 KiB
TypeScript

import { describe, it, expect, mock, spyOn } from "bun:test"
import type { RunContext, ChildSession, SessionStatus } from "./types"
const createMockContext = (overrides: {
childrenBySession?: Record<string, ChildSession[]>
statuses?: Record<string, SessionStatus>
verbose?: boolean
} = {}): RunContext => {
const {
childrenBySession = { "test-session": [] },
statuses = {},
verbose = false,
} = overrides
return {
client: {
session: {
todo: mock(() => Promise.resolve({ data: [] })),
children: mock((opts: { path: { id: string } }) =>
Promise.resolve({ data: childrenBySession[opts.path.id] ?? [] })
),
status: mock(() => Promise.resolve({ data: statuses })),
},
} as unknown as RunContext["client"],
sessionID: "test-session",
directory: "/test",
abortController: new AbortController(),
verbose,
}
}
describe("checkCompletionConditions verbose waiting logs", () => {
it("does not print busy waiting line when verbose is disabled", async () => {
// given
const consoleLogSpy = spyOn(console, "log").mockImplementation(() => {})
consoleLogSpy.mockClear()
const ctx = createMockContext({
childrenBySession: {
"test-session": [{ id: "child-1" }],
"child-1": [],
},
statuses: { "child-1": { type: "busy" } },
verbose: false,
})
const { checkCompletionConditions } = await import("./completion")
// when
const result = await checkCompletionConditions(ctx)
// then
expect(result).toBe(false)
expect(consoleLogSpy).not.toHaveBeenCalled()
})
it("prints busy waiting line when verbose is enabled", async () => {
// given
const consoleLogSpy = spyOn(console, "log").mockImplementation(() => {})
consoleLogSpy.mockClear()
const ctx = createMockContext({
childrenBySession: {
"test-session": [{ id: "child-1" }],
"child-1": [],
},
statuses: { "child-1": { type: "busy" } },
verbose: true,
})
const { checkCompletionConditions } = await import("./completion")
// when
const result = await checkCompletionConditions(ctx)
// then
expect(result).toBe(false)
expect(consoleLogSpy).toHaveBeenCalledWith(
expect.stringContaining("Waiting: session child-1... is busy")
)
})
})