@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,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
@@ -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,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=state-queue.test.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"state-queue.test.d.ts","sourceRoot":"","sources":["../src/state-queue.test.ts"],"names":[],"mappings":""}
@@ -1,99 +0,0 @@
1
- import { describe, test, expect, beforeEach, afterEach, vi } from "vitest";
2
- import { AsyncStateQueue } from "./state-queue.js";
3
- import { StateManager } from "@opencode-trace/core/state";
4
- import { logger } from "@opencode-trace/core";
5
- import { mkdtempSync, rmSync } from "node:fs";
6
- import { tmpdir } from "node:os";
7
- import { join } from "node:path";
8
- describe("AsyncStateQueue", () => {
9
- let tempDir;
10
- let queue;
11
- let stateManager;
12
- beforeEach(async () => {
13
- tempDir = mkdtempSync(join(tmpdir(), "state-queue-test-"));
14
- queue = new AsyncStateQueue();
15
- stateManager = new StateManager(tempDir);
16
- await stateManager.init();
17
- queue.setStateManager(stateManager);
18
- });
19
- afterEach(() => {
20
- rmSync(tempDir, { recursive: true, force: true });
21
- });
22
- test("enqueue calls StateManager.writeRecord asynchronously", async () => {
23
- const sessionId = "test-session";
24
- stateManager.startSession(sessionId);
25
- const record = {
26
- id: 1,
27
- purpose: "test",
28
- requestAt: "2026-05-07T00:00:00Z",
29
- responseAt: "2026-05-07T00:00:01Z",
30
- request: { method: "GET", url: "https://example.com", headers: {}, body: null },
31
- response: { status: 200, statusText: "OK", headers: {}, body: null },
32
- error: null,
33
- };
34
- queue.enqueue(sessionId, 1, record);
35
- await queue.flush();
36
- const session = stateManager.getSession(sessionId);
37
- expect(session?.requestCount).toBe(1);
38
- });
39
- test("enqueue processes items in batches", async () => {
40
- const sessionId = "batch-test";
41
- stateManager.startSession(sessionId);
42
- const records = Array.from({ length: 25 }, (_, i) => ({
43
- id: i + 1,
44
- purpose: `test-${i}`,
45
- requestAt: new Date().toISOString(),
46
- responseAt: new Date().toISOString(),
47
- request: { method: "GET", url: `https://example.com/${i}`, headers: {}, body: null },
48
- response: { status: 200, statusText: "OK", headers: {}, body: null },
49
- error: null,
50
- }));
51
- for (let i = 0; i < 25; i++) {
52
- queue.enqueue(sessionId, i + 1, records[i]);
53
- }
54
- await queue.flush();
55
- const session = stateManager.getSession(sessionId);
56
- expect(session?.requestCount).toBe(25);
57
- });
58
- test("enqueue handles errors gracefully", async () => {
59
- const sessionId = "error-test";
60
- stateManager.startSession(sessionId);
61
- const loggerErrorSpy = vi.spyOn(logger, 'error').mockImplementation(() => logger);
62
- const record = {
63
- id: 1,
64
- purpose: "test",
65
- requestAt: new Date().toISOString(),
66
- responseAt: new Date().toISOString(),
67
- request: { method: "GET", url: "https://example.com", headers: {}, body: null },
68
- response: { status: 200, statusText: "OK", headers: {}, body: null },
69
- error: null,
70
- };
71
- vi.spyOn(stateManager, 'writeRecord').mockImplementationOnce(() => {
72
- throw new Error("Test error");
73
- });
74
- queue.enqueue(sessionId, 1, record);
75
- await queue.flush();
76
- expect(loggerErrorSpy).toHaveBeenCalledWith("SQLite update failed", { error: "Error: Test error" });
77
- loggerErrorSpy.mockRestore();
78
- vi.restoreAllMocks();
79
- });
80
- test("flush waits for queue to drain", async () => {
81
- const sessionId = "flush-test";
82
- stateManager.startSession(sessionId);
83
- for (let i = 0; i < 5; i++) {
84
- queue.enqueue(sessionId, i + 1, {
85
- id: i + 1,
86
- purpose: `test-${i}`,
87
- requestAt: new Date().toISOString(),
88
- responseAt: new Date().toISOString(),
89
- request: { method: "GET", url: "https://example.com", headers: {}, body: null },
90
- response: { status: 200, statusText: "OK", headers: {}, body: null },
91
- error: null,
92
- });
93
- }
94
- await queue.flush();
95
- const session = stateManager.getSession(sessionId);
96
- expect(session?.requestCount).toBe(5);
97
- });
98
- });
99
- //# sourceMappingURL=state-queue.test.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"state-queue.test.js","sourceRoot":"","sources":["../src/state-queue.test.ts"],"names":[],"mappings":"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"}