|
| 1 | +import test from "brittle"; |
| 2 | +import { SDK_ALL_LOG_ID, SDK_LOG_ID } from "@/logging"; |
| 3 | +import { |
| 4 | + registerLoggingStream, |
| 5 | + unregisterLoggingStream, |
| 6 | + sendLogToStreams, |
| 7 | + startLogBuffering, |
| 8 | + clearAllLoggingStreams, |
| 9 | +} from "@/server/bare/registry/logging-stream-registry"; |
| 10 | + |
| 11 | +test("global stream receives logs from every source id", (t) => { |
| 12 | + clearAllLoggingStreams(); |
| 13 | + |
| 14 | + const received: string[] = []; |
| 15 | + const handler = (_level: string, _ns: string, message: string) => |
| 16 | + received.push(message); |
| 17 | + registerLoggingStream(SDK_ALL_LOG_ID, handler); |
| 18 | + |
| 19 | + sendLogToStreams(SDK_LOG_ID, "info", "sdk:server", "from sdk"); |
| 20 | + sendLogToStreams("model-123", "debug", "llamacpp-completion", "from model"); |
| 21 | + |
| 22 | + t.alike(received, ["from sdk", "from model"], "captures logs across ids"); |
| 23 | + |
| 24 | + unregisterLoggingStream(SDK_ALL_LOG_ID, handler); |
| 25 | + sendLogToStreams(SDK_LOG_ID, "info", "sdk:server", "after unsubscribe"); |
| 26 | + t.alike(received, ["from sdk", "from model"], "stops after unsubscribe"); |
| 27 | + |
| 28 | + clearAllLoggingStreams(); |
| 29 | +}); |
| 30 | + |
| 31 | +test("per-id stream still receives only its own logs", (t) => { |
| 32 | + clearAllLoggingStreams(); |
| 33 | + |
| 34 | + const global: string[] = []; |
| 35 | + const model: string[] = []; |
| 36 | + const globalHandler = (_l: string, _n: string, m: string) => global.push(m); |
| 37 | + const modelHandler = (_l: string, _n: string, m: string) => model.push(m); |
| 38 | + |
| 39 | + registerLoggingStream(SDK_ALL_LOG_ID, globalHandler); |
| 40 | + registerLoggingStream("model-123", modelHandler); |
| 41 | + |
| 42 | + sendLogToStreams("model-123", "info", "llamacpp-completion", "a"); |
| 43 | + sendLogToStreams("model-456", "info", "llamacpp-completion", "b"); |
| 44 | + |
| 45 | + t.alike(model, ["a"], "model stream only sees its own id"); |
| 46 | + t.alike(global, ["a", "b"], "global stream sees both"); |
| 47 | + |
| 48 | + clearAllLoggingStreams(); |
| 49 | +}); |
| 50 | + |
| 51 | +test("global stream flushes startup logs buffered before subscribe", (t) => { |
| 52 | + clearAllLoggingStreams(); |
| 53 | + startLogBuffering(SDK_ALL_LOG_ID); |
| 54 | + |
| 55 | + sendLogToStreams(SDK_LOG_ID, "info", "sdk:server", "early"); |
| 56 | + |
| 57 | + const received: string[] = []; |
| 58 | + registerLoggingStream(SDK_ALL_LOG_ID, (_l, _n, m) => received.push(m)); |
| 59 | + |
| 60 | + t.alike(received, ["early"], "buffered log delivered on subscribe"); |
| 61 | + |
| 62 | + clearAllLoggingStreams(); |
| 63 | +}); |
0 commit comments