@opencode-trace/cli 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 +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 +4 -3
|
@@ -0,0 +1,125 @@
|
|
|
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 { cmdEnable } from "./enable.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("cmdEnable", () => {
|
|
57
|
+
it("no flags defaults to global scope and sets storage preference", async () => {
|
|
58
|
+
await cmdEnable([]);
|
|
59
|
+
expect(record.initStateManager).toHaveBeenCalledWith(GLOBAL_TRACE_DIR);
|
|
60
|
+
expect(record.setGlobalTraceEnabled).toHaveBeenCalledWith(true, GLOBAL_TRACE_DIR);
|
|
61
|
+
expect(record.setStoragePreference).toHaveBeenCalledWith("global", GLOBAL_TRACE_DIR);
|
|
62
|
+
expect(record.setGlobalTraceEnabled).toHaveBeenCalledTimes(1);
|
|
63
|
+
expect(logSpy).toHaveBeenCalledWith("Trace enabled (scope: global)");
|
|
64
|
+
});
|
|
65
|
+
it("-g flag enables global scope", async () => {
|
|
66
|
+
await cmdEnable(["-g"]);
|
|
67
|
+
expect(record.setGlobalTraceEnabled).toHaveBeenCalledWith(true, GLOBAL_TRACE_DIR);
|
|
68
|
+
expect(record.setGlobalTraceEnabled).not.toHaveBeenCalledWith(true, LOCAL_TRACE_DIR);
|
|
69
|
+
expect(logSpy).toHaveBeenCalledWith("Trace enabled (scope: global)");
|
|
70
|
+
});
|
|
71
|
+
it("-l flag enables local scope", async () => {
|
|
72
|
+
await cmdEnable(["-l"]);
|
|
73
|
+
expect(record.setGlobalTraceEnabled).toHaveBeenCalledWith(true, LOCAL_TRACE_DIR);
|
|
74
|
+
expect(record.setGlobalTraceEnabled).not.toHaveBeenCalledWith(true, GLOBAL_TRACE_DIR);
|
|
75
|
+
expect(logSpy).toHaveBeenCalledWith("Trace enabled (scope: local)");
|
|
76
|
+
});
|
|
77
|
+
it("-g -l flags enable both global and local", async () => {
|
|
78
|
+
await cmdEnable(["-g", "-l"]);
|
|
79
|
+
expect(record.setGlobalTraceEnabled).toHaveBeenCalledWith(true, GLOBAL_TRACE_DIR);
|
|
80
|
+
expect(record.setGlobalTraceEnabled).toHaveBeenCalledWith(true, LOCAL_TRACE_DIR);
|
|
81
|
+
expect(record.setGlobalTraceEnabled).toHaveBeenCalledTimes(2);
|
|
82
|
+
expect(logSpy).toHaveBeenCalledWith("Trace enabled (scope: global, local)");
|
|
83
|
+
});
|
|
84
|
+
it("-s without sessionId exits with code 1", async () => {
|
|
85
|
+
await expect(cmdEnable(["-s"])).rejects.toThrow("exit_1");
|
|
86
|
+
expect(errSpy).toHaveBeenCalledWith("Error: session-id is required when using -s");
|
|
87
|
+
});
|
|
88
|
+
it("-s with sessionId enables session scope", async () => {
|
|
89
|
+
await cmdEnable(["-s", "my-session"]);
|
|
90
|
+
expect(record.setSessionEnabled).toHaveBeenCalledWith("my-session", true, GLOBAL_TRACE_DIR);
|
|
91
|
+
expect(logSpy).toHaveBeenCalledWith("Trace enabled (scope: session)");
|
|
92
|
+
});
|
|
93
|
+
it("-d local sets storage preference to local", async () => {
|
|
94
|
+
await cmdEnable(["-d", "local"]);
|
|
95
|
+
expect(record.setStoragePreference).toHaveBeenCalledWith("local", GLOBAL_TRACE_DIR);
|
|
96
|
+
expect(logSpy).toHaveBeenCalledWith("Trace enabled (scope: global, storage: local)");
|
|
97
|
+
});
|
|
98
|
+
it("-d global sets storage preference to global", async () => {
|
|
99
|
+
await cmdEnable(["-d", "global"]);
|
|
100
|
+
expect(record.setStoragePreference).toHaveBeenCalledWith("global", GLOBAL_TRACE_DIR);
|
|
101
|
+
expect(logSpy).toHaveBeenCalledWith("Trace enabled (scope: global, storage: global)");
|
|
102
|
+
});
|
|
103
|
+
it("-d invalid exits with code 1", async () => {
|
|
104
|
+
await expect(cmdEnable(["-d", "invalid"])).rejects.toThrow("exit_1");
|
|
105
|
+
expect(errSpy).toHaveBeenCalledWith("Error: Invalid dir value: invalid. Valid: global, local");
|
|
106
|
+
});
|
|
107
|
+
it("all flags combined - enables all three scopes and sets storage", async () => {
|
|
108
|
+
await cmdEnable(["-g", "-l", "-s", "my-session", "-d", "local"]);
|
|
109
|
+
expect(record.setGlobalTraceEnabled).toHaveBeenCalledWith(true, GLOBAL_TRACE_DIR);
|
|
110
|
+
expect(record.setGlobalTraceEnabled).toHaveBeenCalledWith(true, LOCAL_TRACE_DIR);
|
|
111
|
+
expect(record.setSessionEnabled).toHaveBeenCalledWith("my-session", true, GLOBAL_TRACE_DIR);
|
|
112
|
+
expect(record.setSessionStoragePreference).toHaveBeenCalledWith("my-session", "local", GLOBAL_TRACE_DIR);
|
|
113
|
+
expect(logSpy).toHaveBeenCalledWith("Trace enabled (scope: global, local, session, storage: local)");
|
|
114
|
+
});
|
|
115
|
+
it("-s with -d sets session storage preference", async () => {
|
|
116
|
+
await cmdEnable(["-s", "my-session", "-d", "local"]);
|
|
117
|
+
expect(record.setSessionStoragePreference).toHaveBeenCalledWith("my-session", "local", GLOBAL_TRACE_DIR);
|
|
118
|
+
expect(record.setSessionStoragePreference).toHaveBeenCalledTimes(1);
|
|
119
|
+
});
|
|
120
|
+
it("-s without -d does not call setSessionStoragePreference", async () => {
|
|
121
|
+
await cmdEnable(["-s", "my-session"]);
|
|
122
|
+
expect(record.setSessionStoragePreference).not.toHaveBeenCalled();
|
|
123
|
+
});
|
|
124
|
+
});
|
|
125
|
+
//# sourceMappingURL=enable.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"enable.test.js","sourceRoot":"","sources":["../../src/handlers/enable.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"export.d.ts","sourceRoot":"","sources":["../../src/handlers/export.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"export.d.ts","sourceRoot":"","sources":["../../src/handlers/export.ts"],"names":[],"mappings":"AAiBA,wBAAsB,SAAS,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC,CAyK7D"}
|
package/dist/handlers/export.js
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import { writeFileSync } from "node:fs";
|
|
2
2
|
import { resolve } from "node:path";
|
|
3
3
|
import { store, parse, query, record, format } from "@opencode-trace/core";
|
|
4
|
-
import { parseFlags, parseRange, inRange, findSessionTraceDir } from "../utils.js";
|
|
5
|
-
import { parseCollapse, parseCollapseBlocks, writeCollapsedExport, isConversationsMap, isDeltasMap } from "../formatter.js";
|
|
4
|
+
import { parseFlags, parseRange, inRange, findSessionTraceDir, } from "../utils.js";
|
|
5
|
+
import { parseCollapse, parseCollapseBlocks, writeCollapsedExport, isConversationsMap, isDeltasMap, } from "../formatter.js";
|
|
6
6
|
export async function cmdExport(args) {
|
|
7
7
|
const { positional, flags } = parseFlags(args);
|
|
8
8
|
const sessionId = positional[0];
|
|
@@ -43,8 +43,10 @@ export async function cmdExport(args) {
|
|
|
43
43
|
data = query.buildSessionMetadata(sessionId, parsedRecords);
|
|
44
44
|
const sessionMeta = store.readSessionMetadata(sessionId, traceDir);
|
|
45
45
|
if (sessionMeta) {
|
|
46
|
-
data.createdAt =
|
|
47
|
-
|
|
46
|
+
data.createdAt =
|
|
47
|
+
sessionMeta.createdAt ?? data.createdAt;
|
|
48
|
+
data.updatedAt =
|
|
49
|
+
sessionMeta.updatedAt ?? data.updatedAt;
|
|
48
50
|
data.enabled = sessionMeta.enabled ?? false;
|
|
49
51
|
}
|
|
50
52
|
break;
|
|
@@ -67,7 +69,7 @@ export async function cmdExport(args) {
|
|
|
67
69
|
const result = format.collapseConversations(conversations, {
|
|
68
70
|
collapse: collapseItems,
|
|
69
71
|
collapseBlocks: collapseBlockTypes,
|
|
70
|
-
format: formatType
|
|
72
|
+
format: formatType,
|
|
71
73
|
});
|
|
72
74
|
writeCollapsedExport(outputPath, result, formatType);
|
|
73
75
|
return;
|
|
@@ -94,7 +96,7 @@ export async function cmdExport(args) {
|
|
|
94
96
|
const result = format.collapseDeltas(deltas, {
|
|
95
97
|
collapse: collapseItems,
|
|
96
98
|
collapseBlocks: collapseBlockTypes,
|
|
97
|
-
format: formatType
|
|
99
|
+
format: formatType,
|
|
98
100
|
});
|
|
99
101
|
writeCollapsedExport(outputPath, result, formatType);
|
|
100
102
|
return;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"export.js","sourceRoot":"","sources":["../../src/handlers/export.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,SAAS,CAAC;AACxC,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,sBAAsB,CAAC;AAC3E,OAAO,
|
|
1
|
+
{"version":3,"file":"export.js","sourceRoot":"","sources":["../../src/handlers/export.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"export.test.d.ts","sourceRoot":"","sources":["../../src/handlers/export.test.ts"],"names":[],"mappings":""}
|