@opencode-trace/plugin 0.0.4 → 0.0.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,8 +1,30 @@
1
- import { describe, test, expect, beforeEach, afterEach } from "vitest";
1
+ import { describe, test, expect, beforeEach, afterEach, vi } from "vitest";
2
2
  import { AsyncWriteQueue } from "./write-queue.js";
3
- import { mkdtempSync, rmSync, existsSync, readFileSync, promises as fs } from "node:fs";
3
+ import { logger } from "@opencode-trace/core";
4
+ import { mkdtempSync, rmSync, existsSync, readFileSync, readdirSync, promises as fs, } from "node:fs";
4
5
  import { tmpdir } from "node:os";
5
6
  import { join } from "node:path";
7
+ function makeRecord(seq, label = "test") {
8
+ return {
9
+ id: seq,
10
+ purpose: label,
11
+ requestAt: "2026-05-07T00:00:00Z",
12
+ responseAt: "2026-05-07T00:00:01Z",
13
+ request: {
14
+ method: "GET",
15
+ url: `https://example.com/${seq}`,
16
+ headers: {},
17
+ body: null,
18
+ },
19
+ response: { status: 200, statusText: "OK", headers: {}, body: null },
20
+ error: null,
21
+ };
22
+ }
23
+ function makeErrnoError(code, message) {
24
+ const err = new Error(message ?? code);
25
+ err.code = code;
26
+ return err;
27
+ }
6
28
  describe("AsyncWriteQueue", () => {
7
29
  let tempDir;
8
30
  let queue;
@@ -19,7 +41,12 @@ describe("AsyncWriteQueue", () => {
19
41
  purpose: "test",
20
42
  requestAt: "2026-05-07T00:00:00Z",
21
43
  responseAt: "2026-05-07T00:00:01Z",
22
- request: { method: "GET", url: "https://example.com", headers: {}, body: null },
44
+ request: {
45
+ method: "GET",
46
+ url: "https://example.com",
47
+ headers: {},
48
+ body: null,
49
+ },
23
50
  response: { status: 200, statusText: "OK", headers: {}, body: null },
24
51
  error: null,
25
52
  };
@@ -36,7 +63,12 @@ describe("AsyncWriteQueue", () => {
36
63
  purpose: `test-${i}`,
37
64
  requestAt: `2026-05-07T00:00:${i.toString().padStart(2, "0")}Z`,
38
65
  responseAt: `2026-05-07T00:00:${(i + 1).toString().padStart(2, "0")}Z`,
39
- request: { method: "GET", url: `https://example.com/${i}`, headers: {}, body: null },
66
+ request: {
67
+ method: "GET",
68
+ url: `https://example.com/${i}`,
69
+ headers: {},
70
+ body: null,
71
+ },
40
72
  response: { status: 200, statusText: "OK", headers: {}, body: null },
41
73
  error: null,
42
74
  }));
@@ -55,7 +87,12 @@ describe("AsyncWriteQueue", () => {
55
87
  purpose: "fallback-test",
56
88
  requestAt: "2026-05-07T00:00:00Z",
57
89
  responseAt: "2026-05-07T00:00:01Z",
58
- request: { method: "GET", url: "https://example.com", headers: {}, body: null },
90
+ request: {
91
+ method: "GET",
92
+ url: "https://example.com",
93
+ headers: {},
94
+ body: null,
95
+ },
59
96
  response: { status: 200, statusText: "OK", headers: {}, body: null },
60
97
  error: null,
61
98
  };
@@ -75,7 +112,12 @@ describe("AsyncWriteQueue", () => {
75
112
  purpose: `flush-test-${i}`,
76
113
  requestAt: "2026-05-07T00:00:00Z",
77
114
  responseAt: "2026-05-07T00:00:01Z",
78
- request: { method: "GET", url: "https://example.com", headers: {}, body: null },
115
+ request: {
116
+ method: "GET",
117
+ url: "https://example.com",
118
+ headers: {},
119
+ body: null,
120
+ },
79
121
  response: { status: 200, statusText: "OK", headers: {}, body: null },
80
122
  error: null,
81
123
  }));
@@ -89,4 +131,445 @@ describe("AsyncWriteQueue", () => {
89
131
  }
90
132
  });
91
133
  });
134
+ describe("AsyncWriteQueue.safeRename retry logic", () => {
135
+ let tempDir;
136
+ let queue;
137
+ beforeEach(() => {
138
+ tempDir = mkdtempSync(join(tmpdir(), "write-queue-retry-"));
139
+ queue = new AsyncWriteQueue(tempDir);
140
+ });
141
+ afterEach(() => {
142
+ vi.restoreAllMocks();
143
+ rmSync(tempDir, { recursive: true, force: true });
144
+ });
145
+ test("retries rename on EPERM and succeeds on 3rd attempt", async () => {
146
+ const realRename = fs.rename.bind(fs);
147
+ let calls = 0;
148
+ const renameSpy = vi
149
+ .spyOn(fs, "rename")
150
+ .mockImplementation(async (...args) => {
151
+ calls++;
152
+ if (calls <= 2) {
153
+ throw makeErrnoError("EPERM", "EPERM: operation not permitted");
154
+ }
155
+ return realRename(...args);
156
+ });
157
+ queue.enqueue("retry-success", 1, makeRecord(1, "retry-success"));
158
+ await queue.flush();
159
+ // 3 rename calls: 2 EPERM failures + 1 success
160
+ expect(renameSpy).toHaveBeenCalledTimes(3);
161
+ // The final .json file ended up at destination (3rd rename succeeded)
162
+ const finalPath = join(tempDir, "retry-success", "1.json");
163
+ expect(existsSync(finalPath)).toBe(true);
164
+ // No fallback file should have been written
165
+ const fallbackDir = join(tempDir, "fallback");
166
+ expect(existsSync(fallbackDir)).toBe(false);
167
+ const content = JSON.parse(readFileSync(finalPath, "utf-8"));
168
+ expect(content.purpose).toBe("retry-success");
169
+ });
170
+ test("retries rename on EACCES and succeeds on 3rd attempt", async () => {
171
+ const realRename = fs.rename.bind(fs);
172
+ let calls = 0;
173
+ const renameSpy = vi
174
+ .spyOn(fs, "rename")
175
+ .mockImplementation(async (...args) => {
176
+ calls++;
177
+ if (calls <= 2) {
178
+ throw makeErrnoError("EACCES", "EACCES: permission denied");
179
+ }
180
+ return realRename(...args);
181
+ });
182
+ queue.enqueue("retry-eacces", 1, makeRecord(1, "retry-eacces"));
183
+ await queue.flush();
184
+ expect(renameSpy).toHaveBeenCalledTimes(3);
185
+ const finalPath = join(tempDir, "retry-eacces", "1.json");
186
+ expect(existsSync(finalPath)).toBe(true);
187
+ });
188
+ test("exhausts 3 retries on persistent EPERM and falls back", async () => {
189
+ const renameSpy = vi
190
+ .spyOn(fs, "rename")
191
+ .mockImplementation(async () => {
192
+ throw makeErrnoError("EPERM", "EPERM: operation not permitted");
193
+ });
194
+ queue.enqueue("retry-exhaust", 1, makeRecord(1, "retry-exhaust"));
195
+ await queue.flush();
196
+ // Exactly 3 rename attempts (max retries)
197
+ expect(renameSpy).toHaveBeenCalledTimes(3);
198
+ // Final .json was NOT renamed
199
+ const finalPath = join(tempDir, "retry-exhaust", "1.json");
200
+ expect(existsSync(finalPath)).toBe(false);
201
+ // The .tmp file was left behind (rename never completed)
202
+ const tmpPath = join(tempDir, "retry-exhaust", "1.json.tmp");
203
+ expect(existsSync(tmpPath)).toBe(true);
204
+ // The record was preserved via the fallback path
205
+ const fallbackDir = join(tempDir, "fallback");
206
+ expect(existsSync(fallbackDir)).toBe(true);
207
+ const fallbackEntries = readdirSync(fallbackDir);
208
+ expect(fallbackEntries.length).toBeGreaterThan(0);
209
+ const fallbackRecord = JSON.parse(readFileSync(join(fallbackDir, fallbackEntries[0]), "utf-8"));
210
+ expect(fallbackRecord.record.purpose).toBe("retry-exhaust");
211
+ expect(fallbackRecord.error).toBeDefined();
212
+ });
213
+ test("does not retry on non-retriable error code (ENOENT)", async () => {
214
+ const renameSpy = vi
215
+ .spyOn(fs, "rename")
216
+ .mockImplementation(async () => {
217
+ throw makeErrnoError("ENOENT", "ENOENT: no such file or directory");
218
+ });
219
+ queue.enqueue("no-retry-enoent", 1, makeRecord(1, "no-retry-enoent"));
220
+ await queue.flush();
221
+ // Only 1 attempt — ENOENT is not retriable
222
+ expect(renameSpy).toHaveBeenCalledTimes(1);
223
+ // Falls back
224
+ const fallbackDir = join(tempDir, "fallback");
225
+ expect(existsSync(fallbackDir)).toBe(true);
226
+ });
227
+ test("does not retry when a non-Error value is thrown (string throw)", async () => {
228
+ const renameSpy = vi
229
+ .spyOn(fs, "rename")
230
+ .mockImplementation(async () => {
231
+ // String throw — has no `.code` property, so retry condition is false
232
+ throw "rename-blew-up";
233
+ });
234
+ queue.enqueue("string-throw", 1, makeRecord(1, "string-throw"));
235
+ await queue.flush();
236
+ // Only 1 attempt — `.code` is undefined for a string throw
237
+ expect(renameSpy).toHaveBeenCalledTimes(1);
238
+ // The write was preserved via the fallback path
239
+ const fallbackDir = join(tempDir, "fallback");
240
+ expect(existsSync(fallbackDir)).toBe(true);
241
+ });
242
+ test("backoff sleeps progressively between retries (50ms, 100ms)", async () => {
243
+ const realRename = fs.rename.bind(fs);
244
+ const timestamps = [];
245
+ let calls = 0;
246
+ vi.spyOn(fs, "rename").mockImplementation(async (...args) => {
247
+ timestamps.push(Date.now());
248
+ calls++;
249
+ if (calls <= 2) {
250
+ throw makeErrnoError("EPERM");
251
+ }
252
+ return realRename(...args);
253
+ });
254
+ queue.enqueue("backoff", 1, makeRecord(1, "backoff"));
255
+ await queue.flush();
256
+ expect(timestamps).toHaveLength(3);
257
+ const gap1 = timestamps[1] - timestamps[0];
258
+ const gap2 = timestamps[2] - timestamps[1];
259
+ // 50ms backoff for first retry, 100ms for second (with some slack)
260
+ expect(gap1).toBeGreaterThanOrEqual(45);
261
+ expect(gap2).toBeGreaterThanOrEqual(95);
262
+ // The second gap is roughly double the first
263
+ expect(gap2).toBeGreaterThan(gap1);
264
+ });
265
+ });
266
+ describe("AsyncWriteQueue.flush ordering", () => {
267
+ let tempDir;
268
+ let queue;
269
+ beforeEach(() => {
270
+ tempDir = mkdtempSync(join(tmpdir(), "write-queue-flush-order-"));
271
+ queue = new AsyncWriteQueue(tempDir);
272
+ });
273
+ afterEach(() => {
274
+ rmSync(tempDir, { recursive: true, force: true });
275
+ });
276
+ test("flush returns only after all enqueued writes are durable on disk", async () => {
277
+ const count = 12;
278
+ for (let i = 1; i <= count; i++) {
279
+ queue.enqueue("order", i, makeRecord(i, `order-${i}`));
280
+ }
281
+ await queue.flush();
282
+ for (let i = 1; i <= count; i++) {
283
+ const filePath = join(tempDir, "order", `${i}.json`);
284
+ expect(existsSync(filePath)).toBe(true);
285
+ const content = JSON.parse(readFileSync(filePath, "utf-8"));
286
+ expect(content.id).toBe(i);
287
+ expect(content.purpose).toBe(`order-${i}`);
288
+ }
289
+ });
290
+ test("flush on an empty queue returns immediately without error", async () => {
291
+ const start = Date.now();
292
+ await queue.flush();
293
+ const elapsed = Date.now() - start;
294
+ // Should resolve almost instantly (well under the 10ms poll interval)
295
+ expect(elapsed).toBeLessThan(50);
296
+ });
297
+ test("flush is safe to call multiple times in sequence", async () => {
298
+ queue.enqueue("multiflush", 1, makeRecord(1, "first"));
299
+ await queue.flush();
300
+ queue.enqueue("multiflush", 2, makeRecord(2, "second"));
301
+ await queue.flush();
302
+ await queue.flush(); // no-op flush
303
+ expect(existsSync(join(tempDir, "multiflush", "1.json"))).toBe(true);
304
+ expect(existsSync(join(tempDir, "multiflush", "2.json"))).toBe(true);
305
+ });
306
+ });
307
+ describe("AsyncWriteQueue.writeParsedCache", () => {
308
+ let tempDir;
309
+ let queue;
310
+ beforeEach(() => {
311
+ tempDir = mkdtempSync(join(tmpdir(), "write-queue-parsed-"));
312
+ queue = new AsyncWriteQueue(tempDir);
313
+ });
314
+ afterEach(() => {
315
+ rmSync(tempDir, { recursive: true, force: true });
316
+ });
317
+ test("writeParsedCache writes .parsed file fire-and-forget", async () => {
318
+ queue.writeParsedCache("session-pc", 1, { hello: "world", _pcv: 1 });
319
+ // Fire-and-forget uses setImmediate — wait for it to settle
320
+ const cachePath = join(tempDir, "session-pc", "1.parsed");
321
+ for (let i = 0; i < 50; i++) {
322
+ if (existsSync(cachePath))
323
+ break;
324
+ await new Promise((r) => setTimeout(r, 20));
325
+ }
326
+ expect(existsSync(cachePath)).toBe(true);
327
+ const content = JSON.parse(readFileSync(cachePath, "utf-8"));
328
+ expect(content).toEqual({ hello: "world", _pcv: 1 });
329
+ });
330
+ test("writeParsedCache honors an explicit traceDir override", async () => {
331
+ const overrideDir = mkdtempSync(join(tmpdir(), "write-queue-parsed-override-"));
332
+ try {
333
+ queue.writeParsedCache("session-pc2", 1, { overridden: true }, overrideDir);
334
+ const cachePath = join(overrideDir, "session-pc2", "1.parsed");
335
+ for (let i = 0; i < 50; i++) {
336
+ if (existsSync(cachePath))
337
+ break;
338
+ await new Promise((r) => setTimeout(r, 20));
339
+ }
340
+ expect(existsSync(cachePath)).toBe(true);
341
+ // Should NOT appear in the default tempDir
342
+ expect(existsSync(join(tempDir, "session-pc2", "1.parsed"))).toBe(false);
343
+ }
344
+ finally {
345
+ rmSync(overrideDir, { recursive: true, force: true });
346
+ }
347
+ });
348
+ });
349
+ describe("AsyncWriteQueue.safeRename retry logging", () => {
350
+ let tempDir;
351
+ let queue;
352
+ beforeEach(() => {
353
+ tempDir = mkdtempSync(join(tmpdir(), "write-queue-retry-log-"));
354
+ queue = new AsyncWriteQueue(tempDir);
355
+ });
356
+ afterEach(() => {
357
+ vi.restoreAllMocks();
358
+ rmSync(tempDir, { recursive: true, force: true });
359
+ });
360
+ test("logs warn on intermediate EPERM retry then succeeds on 2nd attempt", async () => {
361
+ const realRename = fs.rename.bind(fs);
362
+ const renameSpy = vi
363
+ .spyOn(fs, "rename")
364
+ .mockImplementationOnce(async () => {
365
+ throw makeErrnoError("EPERM", "EPERM: operation not permitted");
366
+ })
367
+ .mockImplementation(async (...args) => realRename(...args));
368
+ const warnSpy = vi.spyOn(logger, "warn");
369
+ queue.enqueue("retry-log-eperm", 1, makeRecord(1, "retry-log-eperm"));
370
+ await queue.flush();
371
+ expect(renameSpy).toHaveBeenCalledTimes(2);
372
+ expect(warnSpy).toHaveBeenCalledWith(expect.stringContaining("safeRename retry"), expect.objectContaining({ attempt: 1, code: "EPERM" }));
373
+ const finalPath = join(tempDir, "retry-log-eperm", "1.json");
374
+ expect(existsSync(finalPath)).toBe(true);
375
+ const fallbackDir = join(tempDir, "fallback");
376
+ expect(existsSync(fallbackDir)).toBe(false);
377
+ });
378
+ test("logs warn on intermediate EACCES retry", async () => {
379
+ const realRename = fs.rename.bind(fs);
380
+ const renameSpy = vi
381
+ .spyOn(fs, "rename")
382
+ .mockImplementationOnce(async () => {
383
+ throw makeErrnoError("EACCES", "EACCES: permission denied");
384
+ })
385
+ .mockImplementation(async (...args) => realRename(...args));
386
+ const warnSpy = vi.spyOn(logger, "warn");
387
+ queue.enqueue("retry-log-eacces", 1, makeRecord(1, "retry-log-eacces"));
388
+ await queue.flush();
389
+ expect(renameSpy).toHaveBeenCalledTimes(2);
390
+ expect(warnSpy).toHaveBeenCalledWith(expect.stringContaining("safeRename retry"), expect.objectContaining({ attempt: 1, code: "EACCES" }));
391
+ const finalPath = join(tempDir, "retry-log-eacces", "1.json");
392
+ expect(existsSync(finalPath)).toBe(true);
393
+ });
394
+ test("does NOT log warn on first-attempt success", async () => {
395
+ const renameSpy = vi.spyOn(fs, "rename");
396
+ const warnSpy = vi.spyOn(logger, "warn");
397
+ queue.enqueue("retry-log-success", 1, makeRecord(1, "retry-log-success"));
398
+ await queue.flush();
399
+ expect(renameSpy).toHaveBeenCalledTimes(1);
400
+ const retryWarnings = warnSpy.mock.calls.filter((call) => typeof call[0] === "string" && call[0].includes("safeRename retry"));
401
+ expect(retryWarnings).toHaveLength(0);
402
+ const finalPath = join(tempDir, "retry-log-success", "1.json");
403
+ expect(existsSync(finalPath)).toBe(true);
404
+ });
405
+ test("after 3 EPERM failures, throws and lands in writeFallback (logger.error called)", async () => {
406
+ const renameSpy = vi
407
+ .spyOn(fs, "rename")
408
+ .mockImplementation(async () => {
409
+ throw makeErrnoError("EPERM", "EPERM: operation not permitted");
410
+ });
411
+ const errorSpy = vi.spyOn(logger, "error");
412
+ queue.enqueue("retry-log-fallback", 1, makeRecord(1, "retry-log-fallback"));
413
+ await queue.flush();
414
+ expect(renameSpy).toHaveBeenCalledTimes(3);
415
+ expect(errorSpy).toHaveBeenCalledWith(expect.stringContaining("Write failed"), expect.any(Object));
416
+ const finalPath = join(tempDir, "retry-log-fallback", "1.json");
417
+ expect(existsSync(finalPath)).toBe(false);
418
+ const fallbackDir = join(tempDir, "fallback");
419
+ expect(existsSync(fallbackDir)).toBe(true);
420
+ const entries = readdirSync(fallbackDir);
421
+ expect(entries.length).toBeGreaterThan(0);
422
+ });
423
+ });
424
+ describe("AsyncWriteQueue.close()", () => {
425
+ let tempDir;
426
+ let queue;
427
+ beforeEach(() => {
428
+ tempDir = mkdtempSync(join(tmpdir(), "write-queue-close-"));
429
+ queue = new AsyncWriteQueue(tempDir);
430
+ });
431
+ afterEach(() => {
432
+ vi.restoreAllMocks();
433
+ rmSync(tempDir, { recursive: true, force: true });
434
+ });
435
+ test("drains the queue and sets closed flag", async () => {
436
+ queue.enqueue("close-drain", 1, makeRecord(1, "close-drain-1"));
437
+ queue.enqueue("close-drain", 2, makeRecord(2, "close-drain-2"));
438
+ await queue.close();
439
+ expect(existsSync(join(tempDir, "close-drain", "1.json"))).toBe(true);
440
+ expect(existsSync(join(tempDir, "close-drain", "2.json"))).toBe(true);
441
+ });
442
+ test("enqueue after close routes to writeFallback and logs warn", async () => {
443
+ await queue.close();
444
+ const warnSpy = vi.spyOn(logger, "warn");
445
+ const errorSpy = vi.spyOn(logger, "error");
446
+ queue.enqueue("close-after", 99, makeRecord(99, "close-after-99"));
447
+ await queue.flush();
448
+ expect(warnSpy).toHaveBeenCalledWith(expect.stringContaining("enqueue after close"), expect.any(Object));
449
+ const fallbackDir = join(tempDir, "fallback");
450
+ expect(existsSync(fallbackDir)).toBe(true);
451
+ const entries = readdirSync(fallbackDir);
452
+ expect(entries.length).toBeGreaterThan(0);
453
+ });
454
+ test("close() is idempotent — second call is a no-op", async () => {
455
+ await queue.close();
456
+ await expect(queue.close()).resolves.toBeUndefined();
457
+ });
458
+ });
459
+ describe("AsyncWriteQueue: remaining coverage gaps", () => {
460
+ let tempDir;
461
+ let queue;
462
+ beforeEach(() => {
463
+ tempDir = mkdtempSync(join(tmpdir(), "write-queue-gaps-"));
464
+ queue = new AsyncWriteQueue(tempDir);
465
+ });
466
+ afterEach(() => {
467
+ vi.restoreAllMocks();
468
+ rmSync(tempDir, { recursive: true, force: true });
469
+ });
470
+ test("enqueue with custom traceDir writes files to override directory", async () => {
471
+ const overrideDir = mkdtempSync(join(tmpdir(), "write-queue-tracedir-override-"));
472
+ try {
473
+ const record = makeRecord(1, "override-tracedir");
474
+ queue.enqueue("session-override", 1, record, undefined, overrideDir);
475
+ await queue.flush();
476
+ expect(existsSync(join(overrideDir, "session-override", "1.json"))).toBe(true);
477
+ expect(existsSync(join(tempDir, "session-override", "1.json"))).toBe(false);
478
+ const content = JSON.parse(readFileSync(join(overrideDir, "session-override", "1.json"), "utf-8"));
479
+ expect(content).toEqual(record);
480
+ }
481
+ finally {
482
+ rmSync(overrideDir, { recursive: true, force: true });
483
+ }
484
+ });
485
+ test("enqueue with timelineEntry appends to timeline.ndjson with correct line format", async () => {
486
+ const record = makeRecord(1, "timeline-test");
487
+ const entry = {
488
+ seq: 1,
489
+ url: "https://example.com/timeline",
490
+ method: "POST",
491
+ purpose: "timeline-test",
492
+ requestAt: "2026-05-07T00:00:00Z",
493
+ responseAt: "2026-05-07T00:00:01Z",
494
+ status: 200,
495
+ provider: "openai",
496
+ model: "gpt-4",
497
+ inputTokens: 100,
498
+ outputTokens: 50,
499
+ totalDurationMs: 1500,
500
+ };
501
+ queue.enqueue("session-tl", 1, record, entry);
502
+ await queue.flush();
503
+ const timelinePath = join(tempDir, "session-tl", "timeline.ndjson");
504
+ expect(existsSync(timelinePath)).toBe(true);
505
+ const content = readFileSync(timelinePath, "utf-8");
506
+ expect(content.endsWith("\n")).toBe(true);
507
+ const lines = content.trim().split("\n");
508
+ expect(lines.length).toBe(1);
509
+ expect(JSON.parse(lines[0])).toEqual(entry);
510
+ });
511
+ test("multiple enqueue calls with timelineEntries append multiple ndjson lines", async () => {
512
+ const entry1 = {
513
+ seq: 1,
514
+ url: "https://example.com/1",
515
+ method: "POST",
516
+ purpose: "tl-multi-1",
517
+ requestAt: "2026-05-07T00:00:00Z",
518
+ responseAt: "2026-05-07T00:00:01Z",
519
+ status: 200,
520
+ provider: "openai",
521
+ model: "gpt-4",
522
+ inputTokens: 100,
523
+ outputTokens: 50,
524
+ totalDurationMs: 1500,
525
+ };
526
+ const entry2 = {
527
+ seq: 2,
528
+ url: "https://example.com/2",
529
+ method: "GET",
530
+ purpose: "tl-multi-2",
531
+ requestAt: "2026-05-07T00:00:02Z",
532
+ responseAt: "2026-05-07T00:00:03Z",
533
+ status: 200,
534
+ provider: "anthropic",
535
+ model: "claude-3",
536
+ inputTokens: 200,
537
+ outputTokens: 80,
538
+ totalDurationMs: 2500,
539
+ };
540
+ queue.enqueue("session-multi-tl", 1, makeRecord(1, "tl-multi-1"), entry1);
541
+ queue.enqueue("session-multi-tl", 2, makeRecord(2, "tl-multi-2"), entry2);
542
+ await queue.flush();
543
+ const timelinePath = join(tempDir, "session-multi-tl", "timeline.ndjson");
544
+ const content = readFileSync(timelinePath, "utf-8");
545
+ const lines = content.trim().split("\n");
546
+ expect(lines.length).toBe(2);
547
+ expect(JSON.parse(lines[0])).toEqual(entry1);
548
+ expect(JSON.parse(lines[1])).toEqual(entry2);
549
+ });
550
+ test("writing flag prevents double-processing when enqueue is called during active writeBatch", async () => {
551
+ const realWriteFile = fs.writeFile.bind(fs);
552
+ let writeCalls = 0;
553
+ const writeFileSpy = vi
554
+ .spyOn(fs, "writeFile")
555
+ .mockImplementation(async (...args) => {
556
+ writeCalls++;
557
+ if (writeCalls === 1) {
558
+ await new Promise((r) => setTimeout(r, 100));
559
+ }
560
+ return realWriteFile(...args);
561
+ });
562
+ queue.enqueue("reentry-guard", 1, makeRecord(1, "reentry-first"));
563
+ await new Promise((r) => setTimeout(r, 20));
564
+ queue.enqueue("reentry-guard", 2, makeRecord(2, "reentry-second"));
565
+ await queue.flush();
566
+ expect(existsSync(join(tempDir, "reentry-guard", "1.json"))).toBe(true);
567
+ expect(existsSync(join(tempDir, "reentry-guard", "2.json"))).toBe(true);
568
+ const content1 = JSON.parse(readFileSync(join(tempDir, "reentry-guard", "1.json"), "utf-8"));
569
+ expect(content1.id).toBe(1);
570
+ const content2 = JSON.parse(readFileSync(join(tempDir, "reentry-guard", "2.json"), "utf-8"));
571
+ expect(content2.id).toBe(2);
572
+ expect(writeFileSpy).toHaveBeenCalledTimes(2);
573
+ });
574
+ });
92
575
  //# sourceMappingURL=write-queue.test.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"write-queue.test.js","sourceRoot":"","sources":["../src/write-queue.test.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"write-queue.test.js","sourceRoot":"","sources":["../src/write-queue.test.ts"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@opencode-trace/plugin",
3
- "version": "0.0.4",
3
+ "version": "0.0.6",
4
4
  "type": "module",
5
5
  "description": "OpenCode plugin for trace recording",
6
6
  "main": "./dist/trace.js",
@@ -9,6 +9,10 @@
9
9
  ".": {
10
10
  "import": "./dist/trace.js",
11
11
  "types": "./dist/trace.d.ts"
12
+ },
13
+ "./tracer": {
14
+ "import": "./dist/tracer.js",
15
+ "types": "./dist/tracer.d.ts"
12
16
  }
13
17
  },
14
18
  "files": [
@@ -18,15 +22,18 @@
18
22
  "scripts": {
19
23
  "build": "tsc",
20
24
  "test": "vitest run",
25
+ "debug:plugin:create": "node ../../scripts/test-plugin.mjs create",
26
+ "debug:plugin:remove": "node ../../scripts/test-plugin.mjs remove",
21
27
  "test:watch": "vitest watch",
22
28
  "clean": "node ../../scripts/clean.mjs"
23
29
  },
24
30
  "dependencies": {
25
- "@opencode-trace/core": "0.0.4",
26
31
  "@opencode-ai/plugin": "^1.14.22",
27
- "@opencode-ai/sdk": "^1.14.41"
32
+ "@opencode-ai/sdk": "^1.14.41",
33
+ "@opencode-trace/core": "0.0.6"
28
34
  },
29
35
  "devDependencies": {
36
+ "@vitest/coverage-v8": "^4.1.8",
30
37
  "typescript": "^5.3.0",
31
38
  "vitest": "^4.1.5"
32
39
  },
@@ -1,14 +0,0 @@
1
- import type { StateManager } from "@opencode-trace/core/state";
2
- import type { TraceRecord } from "./trace.js";
3
- export declare class AsyncStateQueue {
4
- private queue;
5
- private stateManager;
6
- private writing;
7
- private batchSize;
8
- constructor(batchSize?: number);
9
- setStateManager(manager: StateManager): void;
10
- enqueue(session: string, seq: number, record: TraceRecord): void;
11
- private processQueue;
12
- flush(): Promise<void>;
13
- }
14
- //# sourceMappingURL=state-queue.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"state-queue.d.ts","sourceRoot":"","sources":["../src/state-queue.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAC;AAE/D,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAE9C,qBAAa,eAAe;IAC1B,OAAO,CAAC,KAAK,CAAoE;IACjF,OAAO,CAAC,YAAY,CAA6B;IACjD,OAAO,CAAC,OAAO,CAAkB;IACjC,OAAO,CAAC,SAAS,CAAS;gBAEd,SAAS,GAAE,MAAW;IAIlC,eAAe,CAAC,OAAO,EAAE,YAAY,GAAG,IAAI;IAI5C,OAAO,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,MAAM,EAAE,WAAW,GAAG,IAAI;YAOlD,YAAY;IAoBpB,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;CAK7B"}