@opencode-trace/cli 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.
- package/README.md +2 -3
- package/dist/formatter.d.ts.map +1 -1
- package/dist/formatter.js +16 -6
- package/dist/formatter.js.map +1 -1
- package/dist/formatter.test.d.ts +2 -0
- package/dist/formatter.test.d.ts.map +1 -0
- package/dist/formatter.test.js +232 -0
- package/dist/formatter.test.js.map +1 -0
- package/dist/handlers/disable.test.d.ts +2 -0
- package/dist/handlers/disable.test.d.ts.map +1 -0
- package/dist/handlers/disable.test.js +115 -0
- package/dist/handlers/disable.test.js.map +1 -0
- package/dist/handlers/enable.d.ts.map +1 -1
- package/dist/handlers/enable.js +26 -17
- package/dist/handlers/enable.js.map +1 -1
- package/dist/handlers/enable.test.d.ts +2 -0
- package/dist/handlers/enable.test.d.ts.map +1 -0
- package/dist/handlers/enable.test.js +125 -0
- package/dist/handlers/enable.test.js.map +1 -0
- package/dist/handlers/export.d.ts.map +1 -1
- package/dist/handlers/export.js +8 -6
- package/dist/handlers/export.js.map +1 -1
- package/dist/handlers/export.test.d.ts +2 -0
- package/dist/handlers/export.test.d.ts.map +1 -0
- package/dist/handlers/export.test.js +492 -0
- package/dist/handlers/export.test.js.map +1 -0
- package/dist/handlers/list.d.ts.map +1 -1
- package/dist/handlers/list.js +4 -1
- package/dist/handlers/list.js.map +1 -1
- package/dist/handlers/list.test.d.ts +2 -0
- package/dist/handlers/list.test.d.ts.map +1 -0
- package/dist/handlers/list.test.js +154 -0
- package/dist/handlers/list.test.js.map +1 -0
- package/dist/handlers/show.d.ts.map +1 -1
- package/dist/handlers/show.js +1 -1
- package/dist/handlers/show.js.map +1 -1
- package/dist/handlers/show.test.d.ts +2 -0
- package/dist/handlers/show.test.d.ts.map +1 -0
- package/dist/handlers/show.test.js +322 -0
- package/dist/handlers/show.test.js.map +1 -0
- package/dist/handlers/status.d.ts.map +1 -1
- package/dist/handlers/status.js +23 -17
- package/dist/handlers/status.js.map +1 -1
- package/dist/handlers/status.test.d.ts +2 -0
- package/dist/handlers/status.test.d.ts.map +1 -0
- package/dist/handlers/status.test.js +141 -0
- package/dist/handlers/status.test.js.map +1 -0
- package/dist/handlers/sync.d.ts.map +1 -1
- package/dist/handlers/sync.js +5 -5
- package/dist/handlers/sync.js.map +1 -1
- package/dist/handlers/sync.test.d.ts +2 -0
- package/dist/handlers/sync.test.d.ts.map +1 -0
- package/dist/handlers/sync.test.js +120 -0
- package/dist/handlers/sync.test.js.map +1 -0
- package/dist/handlers/viewer.js +7 -7
- package/dist/handlers/viewer.js.map +1 -1
- package/dist/handlers/viewer.test.js +27 -23
- package/dist/handlers/viewer.test.js.map +1 -1
- package/dist/index.js +24 -16
- package/dist/index.js.map +1 -1
- package/dist/index.test.js +4 -4
- package/dist/index.test.js.map +1 -1
- package/dist/utils.d.ts.map +1 -1
- package/dist/utils.js +20 -3
- package/dist/utils.js.map +1 -1
- package/dist/utils.test.d.ts +2 -0
- package/dist/utils.test.d.ts.map +1 -0
- package/dist/utils.test.js +250 -0
- package/dist/utils.test.js.map +1 -0
- package/package.json +3 -2
package/README.md
CHANGED
|
@@ -36,9 +36,8 @@ opencode-trace status -s <id> # View status for specific session
|
|
|
36
36
|
#### Session Management
|
|
37
37
|
|
|
38
38
|
```bash
|
|
39
|
+
opencode-trace sync # Rebuild ndjinx index from JSON files
|
|
39
40
|
opencode-trace list # List all sessions
|
|
40
|
-
opencode-trace sync # Sync SQLite with filesystem
|
|
41
|
-
opencode-trace sync --repair # Rebuild corrupted state.db
|
|
42
41
|
```
|
|
43
42
|
|
|
44
43
|
#### Data Viewing
|
|
@@ -103,7 +102,7 @@ opencode-trace viewer --no-open # Don't auto-open browser
|
|
|
103
102
|
| `--collapse-blocks <types>` | Collapse Block types (text,thinking,td,tc,tr,image,other) |
|
|
104
103
|
| `--port <num>` | Viewer port |
|
|
105
104
|
| `--no-open` | Don't auto-open browser |
|
|
106
|
-
| `--repair` |
|
|
105
|
+
| `--repair` | Delete `config.json` and rebuild from filesystem |
|
|
107
106
|
|
|
108
107
|
## Examples
|
|
109
108
|
|
package/dist/formatter.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"formatter.d.ts","sourceRoot":"","sources":["../src/formatter.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAEtD,wBAAgB,UAAU,
|
|
1
|
+
{"version":3,"file":"formatter.d.ts","sourceRoot":"","sources":["../src/formatter.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAEtD,wBAAgB,UAAU,CACxB,IAAI,EAAE,OAAO,EACb,UAAU,EAAE,MAAM,EAClB,OAAO,EAAE,OAAO,GACf,IAAI,CAgBN;AAYD,wBAAgB,kBAAkB,CAAC,IAAI,EAAE,OAAO,GAAG,OAAO,CAEzD;AAED,wBAAgB,WAAW,CAAC,IAAI,EAAE,OAAO,GAAG,OAAO,CAIlD;AAED,wBAAgB,cAAc,CAAC,IAAI,EAAE,OAAO,GAAG,OAAO,CAOrD;AAED,wBAAgB,UAAU,CAAC,IAAI,EAAE,OAAO,GAAG,OAAO,CAOjD;AAoBD,wBAAgB,aAAa,CAC3B,KAAK,EAAE,MAAM,GAAG,SAAS,GACxB,CAAC,KAAK,GAAG,MAAM,GAAG,MAAM,CAAC,EAAE,GAAG,SAAS,CAEzC;AAED,wBAAgB,mBAAmB,CACjC,KAAK,EAAE,MAAM,GAAG,SAAS,GACxB,SAAS,EAAE,GAAG,SAAS,CAMzB;AAED,wBAAgB,oBAAoB,CAClC,UAAU,EAAE,MAAM,EAClB,MAAM,EAAE;IAAE,IAAI,EAAE,MAAM,CAAC;IAAC,MAAM,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;CAAE,EACrD,UAAU,EAAE,MAAM,GACjB,IAAI,CAsBN"}
|
package/dist/formatter.js
CHANGED
|
@@ -26,24 +26,30 @@ function isMapWithProperty(data, property) {
|
|
|
26
26
|
if (keys.length === 0)
|
|
27
27
|
return false;
|
|
28
28
|
const firstVal = data[keys[0]];
|
|
29
|
-
return typeof firstVal === "object" && firstVal !== null && property in firstVal;
|
|
29
|
+
return (typeof firstVal === "object" && firstVal !== null && property in firstVal);
|
|
30
30
|
}
|
|
31
31
|
export function isConversationsMap(data) {
|
|
32
32
|
return isMapWithProperty(data, "provider") && isMapWithProperty(data, "msgs");
|
|
33
33
|
}
|
|
34
34
|
export function isDeltasMap(data) {
|
|
35
|
-
return isMapWithProperty(data, "msgs") && !isMapWithProperty(data, "provider");
|
|
35
|
+
return (isMapWithProperty(data, "msgs") && !isMapWithProperty(data, "provider"));
|
|
36
36
|
}
|
|
37
37
|
export function isConversation(data) {
|
|
38
|
-
return typeof data === "object" &&
|
|
38
|
+
return (typeof data === "object" &&
|
|
39
|
+
data !== null &&
|
|
40
|
+
"provider" in data &&
|
|
41
|
+
"msgs" in data);
|
|
39
42
|
}
|
|
40
43
|
export function isTimeline(data) {
|
|
41
|
-
return typeof data === "object" &&
|
|
44
|
+
return (typeof data === "object" &&
|
|
45
|
+
data !== null &&
|
|
46
|
+
"sessionId" in data &&
|
|
47
|
+
"changes" in data);
|
|
42
48
|
}
|
|
43
49
|
function parseList(value, valid, errorPrefix) {
|
|
44
50
|
if (!value)
|
|
45
51
|
return undefined;
|
|
46
|
-
const items = value.split(",").map(s => s.trim());
|
|
52
|
+
const items = value.split(",").map((s) => s.trim());
|
|
47
53
|
for (const item of items) {
|
|
48
54
|
if (!valid.includes(item)) {
|
|
49
55
|
console.error(`Error: ${errorPrefix}: ${item}. Valid: ${valid.join(", ")}`);
|
|
@@ -69,6 +75,10 @@ export function writeCollapsedExport(outputPath, result, formatType) {
|
|
|
69
75
|
writeFileSync(join(outputPath, path), content, "utf-8");
|
|
70
76
|
}
|
|
71
77
|
}
|
|
72
|
-
console.log(JSON.stringify({
|
|
78
|
+
console.log(JSON.stringify({
|
|
79
|
+
success: true,
|
|
80
|
+
path: outputPath,
|
|
81
|
+
files: result.blocks.size + 1,
|
|
82
|
+
}));
|
|
73
83
|
}
|
|
74
84
|
//# sourceMappingURL=formatter.js.map
|
package/dist/formatter.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"formatter.js","sourceRoot":"","sources":["../src/formatter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AACnD,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AACjC,OAAO,EAAE,MAAM,EAAE,MAAM,sBAAsB,CAAC;AAG9C,MAAM,UAAU,UAAU,
|
|
1
|
+
{"version":3,"file":"formatter.js","sourceRoot":"","sources":["../src/formatter.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"formatter.test.d.ts","sourceRoot":"","sources":["../src/formatter.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,232 @@
|
|
|
1
|
+
import { describe, it, expect, beforeEach, afterEach, vi } from "vitest";
|
|
2
|
+
import { writeFileSync, mkdirSync } from "node:fs";
|
|
3
|
+
import { tmpdir } from "node:os";
|
|
4
|
+
import { join } from "node:path";
|
|
5
|
+
vi.mock("node:fs", async (importOriginal) => {
|
|
6
|
+
const original = await importOriginal();
|
|
7
|
+
return {
|
|
8
|
+
...original,
|
|
9
|
+
writeFileSync: vi.fn(),
|
|
10
|
+
mkdirSync: vi.fn(),
|
|
11
|
+
};
|
|
12
|
+
});
|
|
13
|
+
import { outputData, isConversationsMap, isDeltasMap, isConversation, isTimeline, parseCollapse, parseCollapseBlocks, writeCollapsedExport, } from "./formatter.js";
|
|
14
|
+
let logSpy;
|
|
15
|
+
let errSpy;
|
|
16
|
+
let exitSpy;
|
|
17
|
+
beforeEach(() => {
|
|
18
|
+
vi.mocked(writeFileSync).mockClear();
|
|
19
|
+
vi.mocked(mkdirSync).mockClear();
|
|
20
|
+
exitSpy = vi.spyOn(process, "exit").mockImplementation(((code) => {
|
|
21
|
+
throw new Error(`exit_${code}`);
|
|
22
|
+
}));
|
|
23
|
+
logSpy = vi.spyOn(console, "log").mockImplementation(() => { });
|
|
24
|
+
errSpy = vi.spyOn(console, "error").mockImplementation(() => { });
|
|
25
|
+
});
|
|
26
|
+
afterEach(() => {
|
|
27
|
+
vi.restoreAllMocks();
|
|
28
|
+
});
|
|
29
|
+
describe("isConversationsMap", () => {
|
|
30
|
+
it("returns true for map with provider+msgs on first value", () => {
|
|
31
|
+
expect(isConversationsMap({ 1: { provider: "openai", msgs: [] } })).toBe(true);
|
|
32
|
+
});
|
|
33
|
+
it("returns false for empty map", () => {
|
|
34
|
+
expect(isConversationsMap({})).toBe(false);
|
|
35
|
+
});
|
|
36
|
+
it("returns false when first value is missing provider", () => {
|
|
37
|
+
expect(isConversationsMap({ 1: { msgs: [] } })).toBe(false);
|
|
38
|
+
});
|
|
39
|
+
it("returns false when first value is missing msgs", () => {
|
|
40
|
+
expect(isConversationsMap({ 1: { provider: "openai" } })).toBe(false);
|
|
41
|
+
});
|
|
42
|
+
it("returns false for null", () => {
|
|
43
|
+
expect(isConversationsMap(null)).toBe(false);
|
|
44
|
+
});
|
|
45
|
+
it("returns false for undefined", () => {
|
|
46
|
+
expect(isConversationsMap(undefined)).toBe(false);
|
|
47
|
+
});
|
|
48
|
+
it("returns false for non-object inputs", () => {
|
|
49
|
+
expect(isConversationsMap("hello")).toBe(false);
|
|
50
|
+
expect(isConversationsMap(42)).toBe(false);
|
|
51
|
+
expect(isConversationsMap([])).toBe(false);
|
|
52
|
+
});
|
|
53
|
+
});
|
|
54
|
+
describe("isDeltasMap", () => {
|
|
55
|
+
it("returns true for map with msgs but no provider on first value", () => {
|
|
56
|
+
expect(isDeltasMap({ 1: { msgs: [] } })).toBe(true);
|
|
57
|
+
});
|
|
58
|
+
it("returns false for conversations map (has both provider and msgs)", () => {
|
|
59
|
+
expect(isDeltasMap({ 1: { provider: "openai", msgs: [] } })).toBe(false);
|
|
60
|
+
});
|
|
61
|
+
it("returns false for empty map", () => {
|
|
62
|
+
expect(isDeltasMap({})).toBe(false);
|
|
63
|
+
});
|
|
64
|
+
it("returns false for null", () => {
|
|
65
|
+
expect(isDeltasMap(null)).toBe(false);
|
|
66
|
+
});
|
|
67
|
+
it("returns false for object with no msgs", () => {
|
|
68
|
+
expect(isDeltasMap({ 1: { foo: "bar" } })).toBe(false);
|
|
69
|
+
});
|
|
70
|
+
});
|
|
71
|
+
describe("isConversation", () => {
|
|
72
|
+
it("returns true for object with provider+msgs", () => {
|
|
73
|
+
expect(isConversation({ provider: "openai", msgs: [] })).toBe(true);
|
|
74
|
+
});
|
|
75
|
+
it("returns false when provider is missing", () => {
|
|
76
|
+
expect(isConversation({ msgs: [] })).toBe(false);
|
|
77
|
+
});
|
|
78
|
+
it("returns false when msgs is missing", () => {
|
|
79
|
+
expect(isConversation({ provider: "openai" })).toBe(false);
|
|
80
|
+
});
|
|
81
|
+
it("returns false for null", () => {
|
|
82
|
+
expect(isConversation(null)).toBe(false);
|
|
83
|
+
});
|
|
84
|
+
it("returns false for undefined", () => {
|
|
85
|
+
expect(isConversation(undefined)).toBe(false);
|
|
86
|
+
});
|
|
87
|
+
it("returns false for non-object inputs", () => {
|
|
88
|
+
expect(isConversation("string")).toBe(false);
|
|
89
|
+
expect(isConversation(123)).toBe(false);
|
|
90
|
+
});
|
|
91
|
+
});
|
|
92
|
+
describe("isTimeline", () => {
|
|
93
|
+
it("returns true for object with sessionId+changes", () => {
|
|
94
|
+
expect(isTimeline({ sessionId: "abc", changes: [] })).toBe(true);
|
|
95
|
+
});
|
|
96
|
+
it("returns false when sessionId is missing", () => {
|
|
97
|
+
expect(isTimeline({ changes: [] })).toBe(false);
|
|
98
|
+
});
|
|
99
|
+
it("returns false when changes is missing", () => {
|
|
100
|
+
expect(isTimeline({ sessionId: "abc" })).toBe(false);
|
|
101
|
+
});
|
|
102
|
+
it("returns false for null", () => {
|
|
103
|
+
expect(isTimeline(null)).toBe(false);
|
|
104
|
+
});
|
|
105
|
+
it("returns false for non-object inputs", () => {
|
|
106
|
+
expect(isTimeline("string")).toBe(false);
|
|
107
|
+
});
|
|
108
|
+
});
|
|
109
|
+
describe("parseCollapse", () => {
|
|
110
|
+
it("returns undefined for undefined", () => {
|
|
111
|
+
expect(parseCollapse(undefined)).toBeUndefined();
|
|
112
|
+
});
|
|
113
|
+
it("returns undefined for empty string", () => {
|
|
114
|
+
expect(parseCollapse("")).toBeUndefined();
|
|
115
|
+
});
|
|
116
|
+
it("parses single value 'sys'", () => {
|
|
117
|
+
expect(parseCollapse("sys")).toEqual(["sys"]);
|
|
118
|
+
});
|
|
119
|
+
it("parses comma list 'sys,tool,msgs'", () => {
|
|
120
|
+
expect(parseCollapse("sys,tool,msgs")).toEqual(["sys", "tool", "msgs"]);
|
|
121
|
+
});
|
|
122
|
+
it("trims whitespace around tokens", () => {
|
|
123
|
+
expect(parseCollapse("sys , tool , msgs")).toEqual([
|
|
124
|
+
"sys",
|
|
125
|
+
"tool",
|
|
126
|
+
"msgs",
|
|
127
|
+
]);
|
|
128
|
+
});
|
|
129
|
+
it("throws exit_1 for unknown value 'foo'", () => {
|
|
130
|
+
expect(() => parseCollapse("foo")).toThrow("exit_1");
|
|
131
|
+
});
|
|
132
|
+
it("throws exit_1 when one of the comma-separated values is invalid", () => {
|
|
133
|
+
expect(() => parseCollapse("sys,bogus")).toThrow("exit_1");
|
|
134
|
+
});
|
|
135
|
+
});
|
|
136
|
+
describe("parseCollapseBlocks", () => {
|
|
137
|
+
it("returns undefined for undefined", () => {
|
|
138
|
+
expect(parseCollapseBlocks(undefined)).toBeUndefined();
|
|
139
|
+
});
|
|
140
|
+
it("returns undefined for empty string", () => {
|
|
141
|
+
expect(parseCollapseBlocks("")).toBeUndefined();
|
|
142
|
+
});
|
|
143
|
+
it("parses a single block type", () => {
|
|
144
|
+
expect(parseCollapseBlocks("text")).toEqual(["text"]);
|
|
145
|
+
});
|
|
146
|
+
it("parses all valid block types in one list", () => {
|
|
147
|
+
expect(parseCollapseBlocks("text,thinking,td,tc,tr,image,other")).toEqual(["text", "thinking", "td", "tc", "tr", "image", "other"]);
|
|
148
|
+
});
|
|
149
|
+
it("throws exit_1 for invalid value 'foo'", () => {
|
|
150
|
+
expect(() => parseCollapseBlocks("foo")).toThrow("exit_1");
|
|
151
|
+
});
|
|
152
|
+
it("throws exit_1 when one of the comma-separated values is invalid", () => {
|
|
153
|
+
expect(() => parseCollapseBlocks("text,banana")).toThrow("exit_1");
|
|
154
|
+
});
|
|
155
|
+
});
|
|
156
|
+
describe("outputData", () => {
|
|
157
|
+
it("emits pretty-printed JSON when format=json + compact=false", () => {
|
|
158
|
+
outputData({ a: 1 }, "json", false);
|
|
159
|
+
expect(logSpy).toHaveBeenCalledWith(JSON.stringify({ a: 1 }, null, 2));
|
|
160
|
+
});
|
|
161
|
+
it("emits compact JSON when format=json + compact=true", () => {
|
|
162
|
+
outputData({ a: 1 }, "json", true);
|
|
163
|
+
expect(logSpy).toHaveBeenCalledWith(JSON.stringify({ a: 1 }, null, 0));
|
|
164
|
+
});
|
|
165
|
+
it("emits XML for a conversations map when format=xml", () => {
|
|
166
|
+
const map = { 1: { provider: "openai", msgs: [] } };
|
|
167
|
+
outputData(map, "xml", false);
|
|
168
|
+
const out = logSpy.mock.calls[0]?.[0];
|
|
169
|
+
expect(out).toContain("<conversations>");
|
|
170
|
+
expect(out).toContain("</conversations>");
|
|
171
|
+
expect(out).toContain('reqId="1"');
|
|
172
|
+
});
|
|
173
|
+
it("emits XML for a deltas map when format=xml", () => {
|
|
174
|
+
const map = { 1: { msgs: [] } };
|
|
175
|
+
outputData(map, "xml", false);
|
|
176
|
+
const out = logSpy.mock.calls[0]?.[0];
|
|
177
|
+
expect(out).toContain("<deltas>");
|
|
178
|
+
expect(out).toContain("</deltas>");
|
|
179
|
+
expect(out).toContain('reqId="1"');
|
|
180
|
+
});
|
|
181
|
+
it("falls back to JSON for non-map data when format=xml", () => {
|
|
182
|
+
outputData({ foo: "bar" }, "xml", false);
|
|
183
|
+
expect(logSpy).toHaveBeenCalledWith(JSON.stringify({ foo: "bar" }, null, 2));
|
|
184
|
+
});
|
|
185
|
+
it("falls back to compact JSON for non-map data when format=xml + compact", () => {
|
|
186
|
+
outputData({ foo: "bar" }, "xml", true);
|
|
187
|
+
expect(logSpy).toHaveBeenCalledWith(JSON.stringify({ foo: "bar" }, null, 0));
|
|
188
|
+
});
|
|
189
|
+
});
|
|
190
|
+
describe("writeCollapsedExport", () => {
|
|
191
|
+
const TMP_OUT = join(tmpdir(), "out");
|
|
192
|
+
const TMP_OUT_MAIN_JSON = join(TMP_OUT, "main.json");
|
|
193
|
+
const TMP_OUT_BLOCKS = join(TMP_OUT, "blocks");
|
|
194
|
+
const TMP_OUT_BLOCKS_A = join(TMP_OUT, "blocks", "a.json");
|
|
195
|
+
const TMP_OUT_BLOCKS_B = join(TMP_OUT, "blocks", "b.json");
|
|
196
|
+
const TMP_OUT_MAIN_XML = join(TMP_OUT, "main.xml");
|
|
197
|
+
it("writes only the main file when blocks Map is empty", () => {
|
|
198
|
+
const result = { main: "<root/>", blocks: new Map() };
|
|
199
|
+
writeCollapsedExport(TMP_OUT, result, "json");
|
|
200
|
+
expect(mkdirSync).toHaveBeenCalledTimes(1);
|
|
201
|
+
expect(mkdirSync).toHaveBeenCalledWith(TMP_OUT, { recursive: true });
|
|
202
|
+
expect(writeFileSync).toHaveBeenCalledTimes(1);
|
|
203
|
+
expect(writeFileSync).toHaveBeenCalledWith(TMP_OUT_MAIN_JSON, "<root/>", "utf-8");
|
|
204
|
+
expect(logSpy).toHaveBeenCalledWith(JSON.stringify({ success: true, path: TMP_OUT, files: 1 }));
|
|
205
|
+
});
|
|
206
|
+
it("writes main file + blocks dir + block files when blocks Map is non-empty", () => {
|
|
207
|
+
const blocks = new Map([
|
|
208
|
+
["blocks/a.json", "{\"id\":\"a\"}"],
|
|
209
|
+
["blocks/b.json", "{\"id\":\"b\"}"],
|
|
210
|
+
]);
|
|
211
|
+
const result = { main: "<root/>", blocks };
|
|
212
|
+
writeCollapsedExport(TMP_OUT, result, "json");
|
|
213
|
+
expect(mkdirSync).toHaveBeenCalledTimes(2);
|
|
214
|
+
expect(mkdirSync).toHaveBeenNthCalledWith(1, TMP_OUT, {
|
|
215
|
+
recursive: true,
|
|
216
|
+
});
|
|
217
|
+
expect(mkdirSync).toHaveBeenNthCalledWith(2, TMP_OUT_BLOCKS, {
|
|
218
|
+
recursive: true,
|
|
219
|
+
});
|
|
220
|
+
expect(writeFileSync).toHaveBeenCalledTimes(3);
|
|
221
|
+
expect(writeFileSync).toHaveBeenCalledWith(TMP_OUT_MAIN_JSON, "<root/>", "utf-8");
|
|
222
|
+
expect(writeFileSync).toHaveBeenCalledWith(TMP_OUT_BLOCKS_A, '{"id":"a"}', "utf-8");
|
|
223
|
+
expect(writeFileSync).toHaveBeenCalledWith(TMP_OUT_BLOCKS_B, '{"id":"b"}', "utf-8");
|
|
224
|
+
expect(logSpy).toHaveBeenCalledWith(JSON.stringify({ success: true, path: TMP_OUT, files: 3 }));
|
|
225
|
+
});
|
|
226
|
+
it("uses xml extension for the main file when format=xml", () => {
|
|
227
|
+
const result = { main: "<root/>", blocks: new Map() };
|
|
228
|
+
writeCollapsedExport(TMP_OUT, result, "xml");
|
|
229
|
+
expect(writeFileSync).toHaveBeenCalledWith(TMP_OUT_MAIN_XML, "<root/>", "utf-8");
|
|
230
|
+
});
|
|
231
|
+
});
|
|
232
|
+
//# sourceMappingURL=formatter.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"formatter.test.js","sourceRoot":"","sources":["../src/formatter.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"disable.test.d.ts","sourceRoot":"","sources":["../../src/handlers/disable.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,115 @@
|
|
|
1
|
+
import { describe, it, expect, beforeEach, afterEach, vi } from "vitest";
|
|
2
|
+
import { mkdtempSync, rmSync } from "node:fs";
|
|
3
|
+
import { tmpdir } from "node:os";
|
|
4
|
+
import { join } from "node:path";
|
|
5
|
+
vi.mock("node:os", async (importOriginal) => {
|
|
6
|
+
const original = await importOriginal();
|
|
7
|
+
return {
|
|
8
|
+
...original,
|
|
9
|
+
homedir: () => {
|
|
10
|
+
const testDir = process.env._TEST_DIR_;
|
|
11
|
+
if (testDir)
|
|
12
|
+
return testDir;
|
|
13
|
+
return original.homedir();
|
|
14
|
+
},
|
|
15
|
+
};
|
|
16
|
+
});
|
|
17
|
+
vi.mock("@opencode-trace/core", async (importOriginal) => {
|
|
18
|
+
const original = await importOriginal();
|
|
19
|
+
return {
|
|
20
|
+
...original,
|
|
21
|
+
record: {
|
|
22
|
+
initStateManager: vi.fn().mockResolvedValue(undefined),
|
|
23
|
+
setGlobalTraceEnabled: vi.fn(),
|
|
24
|
+
setStoragePreference: vi.fn(),
|
|
25
|
+
setSessionEnabled: vi.fn(),
|
|
26
|
+
setSessionStoragePreference: vi.fn(),
|
|
27
|
+
getGlobalTraceEnabled: vi.fn().mockReturnValue(false),
|
|
28
|
+
getStoragePreference: vi.fn().mockReturnValue("global"),
|
|
29
|
+
getSessionEnabled: vi.fn().mockReturnValue(false),
|
|
30
|
+
getSessionStoragePreference: vi.fn().mockReturnValue(null),
|
|
31
|
+
},
|
|
32
|
+
};
|
|
33
|
+
});
|
|
34
|
+
import { cmdDisable } from "./disable.js";
|
|
35
|
+
import { GLOBAL_TRACE_DIR, LOCAL_TRACE_DIR } from "../utils.js";
|
|
36
|
+
import { record } from "@opencode-trace/core";
|
|
37
|
+
let testDir;
|
|
38
|
+
let logSpy;
|
|
39
|
+
let errSpy;
|
|
40
|
+
let exitSpy;
|
|
41
|
+
beforeEach(() => {
|
|
42
|
+
testDir = mkdtempSync(join(tmpdir(), "cli-handler-test-"));
|
|
43
|
+
process.env._TEST_DIR_ = testDir;
|
|
44
|
+
vi.clearAllMocks();
|
|
45
|
+
logSpy = vi.spyOn(console, "log").mockImplementation(() => { });
|
|
46
|
+
errSpy = vi.spyOn(console, "error").mockImplementation(() => { });
|
|
47
|
+
exitSpy = vi.spyOn(process, "exit").mockImplementation(((code) => {
|
|
48
|
+
throw new Error(`exit_${code}`);
|
|
49
|
+
}));
|
|
50
|
+
});
|
|
51
|
+
afterEach(() => {
|
|
52
|
+
rmSync(testDir, { recursive: true, force: true });
|
|
53
|
+
delete process.env._TEST_DIR_;
|
|
54
|
+
vi.restoreAllMocks();
|
|
55
|
+
});
|
|
56
|
+
describe("cmdDisable", () => {
|
|
57
|
+
it("no flags disables global scope", async () => {
|
|
58
|
+
await cmdDisable([]);
|
|
59
|
+
expect(record.initStateManager).toHaveBeenCalledWith(GLOBAL_TRACE_DIR);
|
|
60
|
+
expect(record.setGlobalTraceEnabled).toHaveBeenCalledWith(false, GLOBAL_TRACE_DIR);
|
|
61
|
+
expect(record.setStoragePreference).toHaveBeenCalledWith("global", GLOBAL_TRACE_DIR);
|
|
62
|
+
expect(logSpy).toHaveBeenCalledWith("Trace disabled (scope: global)");
|
|
63
|
+
});
|
|
64
|
+
it("-g flag disables global scope", async () => {
|
|
65
|
+
await cmdDisable(["-g"]);
|
|
66
|
+
expect(record.setGlobalTraceEnabled).toHaveBeenCalledWith(false, GLOBAL_TRACE_DIR);
|
|
67
|
+
expect(record.setGlobalTraceEnabled).not.toHaveBeenCalledWith(false, LOCAL_TRACE_DIR);
|
|
68
|
+
expect(logSpy).toHaveBeenCalledWith("Trace disabled (scope: global)");
|
|
69
|
+
});
|
|
70
|
+
it("-l flag disables local scope", async () => {
|
|
71
|
+
await cmdDisable(["-l"]);
|
|
72
|
+
expect(record.setGlobalTraceEnabled).toHaveBeenCalledWith(false, LOCAL_TRACE_DIR);
|
|
73
|
+
expect(record.setGlobalTraceEnabled).not.toHaveBeenCalledWith(false, GLOBAL_TRACE_DIR);
|
|
74
|
+
expect(logSpy).toHaveBeenCalledWith("Trace disabled (scope: local)");
|
|
75
|
+
});
|
|
76
|
+
it("-g -l flags disable both global and local", async () => {
|
|
77
|
+
await cmdDisable(["-g", "-l"]);
|
|
78
|
+
expect(record.setGlobalTraceEnabled).toHaveBeenCalledWith(false, GLOBAL_TRACE_DIR);
|
|
79
|
+
expect(record.setGlobalTraceEnabled).toHaveBeenCalledWith(false, LOCAL_TRACE_DIR);
|
|
80
|
+
expect(record.setGlobalTraceEnabled).toHaveBeenCalledTimes(2);
|
|
81
|
+
expect(logSpy).toHaveBeenCalledWith("Trace disabled (scope: global, local)");
|
|
82
|
+
});
|
|
83
|
+
it("-s without sessionId exits with code 1", async () => {
|
|
84
|
+
await expect(cmdDisable(["-s"])).rejects.toThrow("exit_1");
|
|
85
|
+
expect(errSpy).toHaveBeenCalledWith("Error: session-id is required when using -s");
|
|
86
|
+
});
|
|
87
|
+
it("-s with sessionId disables session scope", async () => {
|
|
88
|
+
await cmdDisable(["-s", "my-session"]);
|
|
89
|
+
expect(record.setSessionEnabled).toHaveBeenCalledWith("my-session", false, GLOBAL_TRACE_DIR);
|
|
90
|
+
expect(logSpy).toHaveBeenCalledWith("Trace disabled (scope: session)");
|
|
91
|
+
});
|
|
92
|
+
it("-d local sets storage preference to local", async () => {
|
|
93
|
+
await cmdDisable(["-d", "local"]);
|
|
94
|
+
expect(record.setStoragePreference).toHaveBeenCalledWith("local", GLOBAL_TRACE_DIR);
|
|
95
|
+
expect(logSpy).toHaveBeenCalledWith("Trace disabled (scope: global, storage: local)");
|
|
96
|
+
});
|
|
97
|
+
it("-d invalid exits with code 1", async () => {
|
|
98
|
+
await expect(cmdDisable(["-d", "invalid"])).rejects.toThrow("exit_1");
|
|
99
|
+
expect(errSpy).toHaveBeenCalledWith("Error: Invalid dir value: invalid. Valid: global, local");
|
|
100
|
+
});
|
|
101
|
+
it("all flags combined - disables all three scopes and sets storage", async () => {
|
|
102
|
+
await cmdDisable(["-g", "-l", "-s", "my-session", "-d", "local"]);
|
|
103
|
+
expect(record.setGlobalTraceEnabled).toHaveBeenCalledWith(false, GLOBAL_TRACE_DIR);
|
|
104
|
+
expect(record.setGlobalTraceEnabled).toHaveBeenCalledWith(false, LOCAL_TRACE_DIR);
|
|
105
|
+
expect(record.setSessionEnabled).toHaveBeenCalledWith("my-session", false, GLOBAL_TRACE_DIR);
|
|
106
|
+
expect(record.setSessionStoragePreference).toHaveBeenCalledWith("my-session", "local", GLOBAL_TRACE_DIR);
|
|
107
|
+
expect(logSpy).toHaveBeenCalledWith("Trace disabled (scope: global, local, session, storage: local)");
|
|
108
|
+
});
|
|
109
|
+
it("-s with -d sets session storage preference", async () => {
|
|
110
|
+
await cmdDisable(["-s", "my-session", "-d", "local"]);
|
|
111
|
+
expect(record.setSessionStoragePreference).toHaveBeenCalledWith("my-session", "local", GLOBAL_TRACE_DIR);
|
|
112
|
+
expect(record.setSessionStoragePreference).toHaveBeenCalledTimes(1);
|
|
113
|
+
});
|
|
114
|
+
});
|
|
115
|
+
//# sourceMappingURL=disable.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"disable.test.js","sourceRoot":"","sources":["../../src/handlers/disable.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"enable.d.ts","sourceRoot":"","sources":["../../src/handlers/enable.ts"],"names":[],"mappings":"AAGA,wBAAsB,SAAS,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC,CAE7D;AAED,wBAAsB,aAAa,
|
|
1
|
+
{"version":3,"file":"enable.d.ts","sourceRoot":"","sources":["../../src/handlers/enable.ts"],"names":[],"mappings":"AAGA,wBAAsB,SAAS,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC,CAE7D;AAED,wBAAsB,aAAa,CACjC,IAAI,EAAE,MAAM,EAAE,EACd,MAAM,EAAE,OAAO,GACd,OAAO,CAAC,IAAI,CAAC,CAyCf"}
|
package/dist/handlers/enable.js
CHANGED
|
@@ -5,29 +5,38 @@ export async function cmdEnable(args) {
|
|
|
5
5
|
}
|
|
6
6
|
export async function cmdSetEnabled(args, enable) {
|
|
7
7
|
const { positional, flags } = parseFlags(args);
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
8
|
+
const hasGlobal = flags.global === true;
|
|
9
|
+
const hasLocal = flags.local === true;
|
|
10
|
+
const hasSession = flags.session === true;
|
|
11
|
+
const anyScope = hasGlobal || hasLocal || hasSession;
|
|
12
|
+
const dir = typeof flags.dir === "string" ? flags.dir : "global";
|
|
13
|
+
const enabled = [];
|
|
14
|
+
if (hasGlobal || !anyScope) {
|
|
15
|
+
await record.initStateManager(GLOBAL_TRACE_DIR);
|
|
16
|
+
record.setGlobalTraceEnabled(enable, GLOBAL_TRACE_DIR);
|
|
17
|
+
record.setStoragePreference(dir, GLOBAL_TRACE_DIR);
|
|
18
|
+
enabled.push("global");
|
|
13
19
|
}
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
20
|
+
if (hasLocal) {
|
|
21
|
+
await record.initStateManager(LOCAL_TRACE_DIR);
|
|
22
|
+
record.setGlobalTraceEnabled(enable, LOCAL_TRACE_DIR);
|
|
23
|
+
enabled.push("local");
|
|
17
24
|
}
|
|
18
|
-
|
|
19
|
-
if (flags.session) {
|
|
25
|
+
if (hasSession) {
|
|
20
26
|
const sessionId = positional[0];
|
|
21
27
|
if (!sessionId) {
|
|
22
|
-
console.error(
|
|
28
|
+
console.error("Error: session-id is required when using -s");
|
|
23
29
|
process.exit(1);
|
|
24
30
|
}
|
|
25
|
-
record.
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
+
await record.initStateManager(GLOBAL_TRACE_DIR);
|
|
32
|
+
record.setSessionEnabled(sessionId, enable, GLOBAL_TRACE_DIR);
|
|
33
|
+
if (flags.dir) {
|
|
34
|
+
record.setSessionStoragePreference(sessionId, dir, GLOBAL_TRACE_DIR);
|
|
35
|
+
}
|
|
36
|
+
enabled.push("session");
|
|
31
37
|
}
|
|
38
|
+
const action = enable ? "enabled" : "disabled";
|
|
39
|
+
const storageInfo = flags.dir ? `, storage: ${dir}` : "";
|
|
40
|
+
console.log(`Trace ${action} (scope: ${enabled.join(", ")}${storageInfo})`);
|
|
32
41
|
}
|
|
33
42
|
//# sourceMappingURL=enable.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"enable.js","sourceRoot":"","sources":["../../src/handlers/enable.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,sBAAsB,CAAC;AAC9C,OAAO,EAAE,UAAU,EAAE,gBAAgB,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AAE5E,MAAM,CAAC,KAAK,UAAU,SAAS,CAAC,IAAc;IAC5C,MAAM,aAAa,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;AAClC,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,aAAa,
|
|
1
|
+
{"version":3,"file":"enable.js","sourceRoot":"","sources":["../../src/handlers/enable.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,sBAAsB,CAAC;AAC9C,OAAO,EAAE,UAAU,EAAE,gBAAgB,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AAE5E,MAAM,CAAC,KAAK,UAAU,SAAS,CAAC,IAAc;IAC5C,MAAM,aAAa,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;AAClC,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,aAAa,CACjC,IAAc,EACd,MAAe;IAEf,MAAM,EAAE,UAAU,EAAE,KAAK,EAAE,GAAG,UAAU,CAAC,IAAI,CAAC,CAAC;IAE/C,MAAM,SAAS,GAAG,KAAK,CAAC,MAAM,KAAK,IAAI,CAAC;IACxC,MAAM,QAAQ,GAAG,KAAK,CAAC,KAAK,KAAK,IAAI,CAAC;IACtC,MAAM,UAAU,GAAG,KAAK,CAAC,OAAO,KAAK,IAAI,CAAC;IAC1C,MAAM,QAAQ,GAAG,SAAS,IAAI,QAAQ,IAAI,UAAU,CAAC;IACrD,MAAM,GAAG,GAAG,OAAO,KAAK,CAAC,GAAG,KAAK,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,QAAQ,CAAC;IAEjE,MAAM,OAAO,GAAa,EAAE,CAAC;IAE7B,IAAI,SAAS,IAAI,CAAC,QAAQ,EAAE,CAAC;QAC3B,MAAM,MAAM,CAAC,gBAAgB,CAAC,gBAAgB,CAAC,CAAC;QAChD,MAAM,CAAC,qBAAqB,CAAC,MAAM,EAAE,gBAAgB,CAAC,CAAC;QACvD,MAAM,CAAC,oBAAoB,CAAC,GAAyB,EAAE,gBAAgB,CAAC,CAAC;QACzE,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACzB,CAAC;IAED,IAAI,QAAQ,EAAE,CAAC;QACb,MAAM,MAAM,CAAC,gBAAgB,CAAC,eAAe,CAAC,CAAC;QAC/C,MAAM,CAAC,qBAAqB,CAAC,MAAM,EAAE,eAAe,CAAC,CAAC;QACtD,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACxB,CAAC;IAED,IAAI,UAAU,EAAE,CAAC;QACf,MAAM,SAAS,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC;QAChC,IAAI,CAAC,SAAS,EAAE,CAAC;YACf,OAAO,CAAC,KAAK,CAAC,6CAA6C,CAAC,CAAC;YAC7D,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAClB,CAAC;QACD,MAAM,MAAM,CAAC,gBAAgB,CAAC,gBAAgB,CAAC,CAAC;QAChD,MAAM,CAAC,iBAAiB,CAAC,SAAS,EAAE,MAAM,EAAE,gBAAgB,CAAC,CAAC;QAC9D,IAAI,KAAK,CAAC,GAAG,EAAE,CAAC;YACd,MAAM,CAAC,2BAA2B,CAAC,SAAS,EAAE,GAAyB,EAAE,gBAAgB,CAAC,CAAC;QAC7F,CAAC;QACD,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IAC1B,CAAC;IAED,MAAM,MAAM,GAAG,MAAM,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,UAAU,CAAC;IAC/C,MAAM,WAAW,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,cAAc,GAAG,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;IACzD,OAAO,CAAC,GAAG,CAAC,SAAS,MAAM,YAAY,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,WAAW,GAAG,CAAC,CAAC;AAC9E,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"enable.test.d.ts","sourceRoot":"","sources":["../../src/handlers/enable.test.ts"],"names":[],"mappings":""}
|