@opencode-trace/plugin 0.0.3 → 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.
@@ -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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"}