@opencode-trace/plugin 0.0.4 → 0.0.5
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.
- package/README.md +4 -11
- package/dist/__tests__/tracer.test.d.ts +2 -0
- package/dist/__tests__/tracer.test.d.ts.map +1 -0
- package/dist/__tests__/tracer.test.js +276 -0
- package/dist/__tests__/tracer.test.js.map +1 -0
- package/dist/integration.test.js +508 -11
- package/dist/integration.test.js.map +1 -1
- package/dist/plugin-instance.d.ts +31 -17
- package/dist/plugin-instance.d.ts.map +1 -1
- package/dist/plugin-instance.js +249 -78
- package/dist/plugin-instance.js.map +1 -1
- package/dist/plugin-instance.test.js +672 -25
- package/dist/plugin-instance.test.js.map +1 -1
- package/dist/trace.d.ts.map +1 -1
- package/dist/trace.js +209 -54
- package/dist/trace.js.map +1 -1
- package/dist/trace.test.js +630 -47
- package/dist/trace.test.js.map +1 -1
- package/dist/tracer.d.ts +20 -0
- package/dist/tracer.d.ts.map +1 -0
- package/dist/tracer.js +12 -0
- package/dist/tracer.js.map +1 -0
- package/dist/write-queue.d.ts +27 -2
- package/dist/write-queue.d.ts.map +1 -1
- package/dist/write-queue.js +99 -14
- package/dist/write-queue.js.map +1 -1
- package/dist/write-queue.test.js +373 -6
- package/dist/write-queue.test.js.map +1 -1
- package/package.json +11 -4
- package/dist/state-queue.d.ts +0 -14
- package/dist/state-queue.d.ts.map +0 -1
- package/dist/state-queue.js +0 -44
- package/dist/state-queue.js.map +0 -1
- package/dist/state-queue.test.d.ts +0 -2
- package/dist/state-queue.test.d.ts.map +0 -1
- package/dist/state-queue.test.js +0 -99
- package/dist/state-queue.test.js.map +0 -1
package/dist/write-queue.test.js
CHANGED
|
@@ -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 {
|
|
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: {
|
|
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: {
|
|
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: {
|
|
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: {
|
|
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,329 @@ 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
|
+
});
|
|
92
459
|
//# 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.
|
|
3
|
+
"version": "0.0.5",
|
|
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.5"
|
|
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
|
},
|
|
@@ -45,4 +52,4 @@
|
|
|
45
52
|
"plugin"
|
|
46
53
|
],
|
|
47
54
|
"license": "MIT"
|
|
48
|
-
}
|
|
55
|
+
}
|
package/dist/state-queue.d.ts
DELETED
|
@@ -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"}
|
package/dist/state-queue.js
DELETED
|
@@ -1,44 +0,0 @@
|
|
|
1
|
-
import { logger } from "@opencode-trace/core";
|
|
2
|
-
export class AsyncStateQueue {
|
|
3
|
-
queue = [];
|
|
4
|
-
stateManager = null;
|
|
5
|
-
writing = false;
|
|
6
|
-
batchSize;
|
|
7
|
-
constructor(batchSize = 10) {
|
|
8
|
-
this.batchSize = batchSize;
|
|
9
|
-
}
|
|
10
|
-
setStateManager(manager) {
|
|
11
|
-
this.stateManager = manager;
|
|
12
|
-
}
|
|
13
|
-
enqueue(session, seq, record) {
|
|
14
|
-
this.queue.push({ session, seq, record });
|
|
15
|
-
if (!this.writing && this.stateManager) {
|
|
16
|
-
this.processQueue();
|
|
17
|
-
}
|
|
18
|
-
}
|
|
19
|
-
async processQueue() {
|
|
20
|
-
this.writing = true;
|
|
21
|
-
while (this.queue.length > 0) {
|
|
22
|
-
const batch = this.queue.splice(0, this.batchSize);
|
|
23
|
-
for (const { session, seq, record } of batch) {
|
|
24
|
-
try {
|
|
25
|
-
// NOTE: StateManager.writeRecord is currently sync (Task 3 will convert to async)
|
|
26
|
-
await this.stateManager.writeRecord(session, seq, record);
|
|
27
|
-
}
|
|
28
|
-
catch (err) {
|
|
29
|
-
logger.error("SQLite update failed", { error: String(err) });
|
|
30
|
-
}
|
|
31
|
-
}
|
|
32
|
-
}
|
|
33
|
-
this.writing = false;
|
|
34
|
-
if (this.queue.length > 0 && !this.writing && this.stateManager) {
|
|
35
|
-
this.processQueue();
|
|
36
|
-
}
|
|
37
|
-
}
|
|
38
|
-
async flush() {
|
|
39
|
-
while (this.writing || this.queue.length > 0) {
|
|
40
|
-
await new Promise(resolve => setTimeout(resolve, 10));
|
|
41
|
-
}
|
|
42
|
-
}
|
|
43
|
-
}
|
|
44
|
-
//# sourceMappingURL=state-queue.js.map
|
package/dist/state-queue.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"state-queue.js","sourceRoot":"","sources":["../src/state-queue.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAE,MAAM,sBAAsB,CAAC;AAG9C,MAAM,OAAO,eAAe;IAClB,KAAK,GAAiE,EAAE,CAAC;IACzE,YAAY,GAAwB,IAAI,CAAC;IACzC,OAAO,GAAY,KAAK,CAAC;IACzB,SAAS,CAAS;IAE1B,YAAY,YAAoB,EAAE;QAChC,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;IAC7B,CAAC;IAED,eAAe,CAAC,OAAqB;QACnC,IAAI,CAAC,YAAY,GAAG,OAAO,CAAC;IAC9B,CAAC;IAED,OAAO,CAAC,OAAe,EAAE,GAAW,EAAE,MAAmB;QACvD,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,GAAG,EAAE,MAAM,EAAE,CAAC,CAAC;QAC1C,IAAI,CAAC,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACvC,IAAI,CAAC,YAAY,EAAE,CAAC;QACtB,CAAC;IACH,CAAC;IAEO,KAAK,CAAC,YAAY;QACxB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACpB,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC7B,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;YACnD,KAAK,MAAM,EAAE,OAAO,EAAE,GAAG,EAAE,MAAM,EAAE,IAAI,KAAK,EAAE,CAAC;gBAC7C,IAAI,CAAC;oBACH,kFAAkF;oBAClF,MAAM,IAAI,CAAC,YAAa,CAAC,WAAW,CAAC,OAAO,EAAE,GAAG,EAAE,MAAM,CAAC,CAAC;gBAC7D,CAAC;gBAAC,OAAO,GAAG,EAAE,CAAC;oBACb,MAAM,CAAC,KAAK,CAAC,sBAAsB,EAAE,EAAE,KAAK,EAAE,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;gBAC/D,CAAC;YACH,CAAC;QACH,CAAC;QACD,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QAErB,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YAChE,IAAI,CAAC,YAAY,EAAE,CAAC;QACtB,CAAC;IACH,CAAC;IAED,KAAK,CAAC,KAAK;QACT,OAAO,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC7C,MAAM,IAAI,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,CAAC;QACxD,CAAC;IACH,CAAC;CACF"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"state-queue.test.d.ts","sourceRoot":"","sources":["../src/state-queue.test.ts"],"names":[],"mappings":""}
|