Spaces:
Running
Running
File size: 1,275 Bytes
98c9143 | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | import { afterEach, expect, mock, test } from "bun:test"
import { debugJson, debugJsonTail } from "../src/lib/logger"
import { state } from "../src/lib/state"
afterEach(() => {
state.verbose = false
})
test("debugJson skips serialization when verbose logging is disabled", () => {
state.verbose = false
const logger = {
debug: mock(() => {}),
}
const toJSON = mock(() => ({ ok: true }))
debugJson(logger as never, "payload", { toJSON })
expect(toJSON).not.toHaveBeenCalled()
expect(logger.debug).not.toHaveBeenCalled()
})
test("debugJson logs the serialized payload when verbose logging is enabled", () => {
state.verbose = true
const logger = {
debug: mock(() => {}),
}
const payload = { ok: true }
debugJson(logger as never, "payload", payload)
expect(logger.debug).toHaveBeenCalledWith("payload", JSON.stringify(payload))
})
test("debugJsonTail preserves tail truncation behavior", () => {
state.verbose = true
const logger = {
debug: mock(() => {}),
}
const payload = { text: "abcdefghijklmnopqrstuvwxyz" }
const expected = JSON.stringify(payload).slice(-10)
debugJsonTail(logger as never, "payload", { value: payload, tailLength: 10 })
expect(logger.debug).toHaveBeenCalledWith("payload", expected)
})
|