@tracemarketplace/shared 0.0.6 → 0.0.9
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/dist/chunker.d.ts.map +1 -1
- package/dist/chunker.js +14 -2
- package/dist/chunker.js.map +1 -1
- package/dist/extractor-claude-code.test.d.ts +2 -0
- package/dist/extractor-claude-code.test.d.ts.map +1 -0
- package/dist/extractor-claude-code.test.js +290 -0
- package/dist/extractor-claude-code.test.js.map +1 -0
- package/dist/extractor-codex.test.d.ts +2 -0
- package/dist/extractor-codex.test.d.ts.map +1 -0
- package/dist/extractor-codex.test.js +212 -0
- package/dist/extractor-codex.test.js.map +1 -0
- package/dist/extractor-cursor.test.d.ts +2 -0
- package/dist/extractor-cursor.test.d.ts.map +1 -0
- package/dist/extractor-cursor.test.js +120 -0
- package/dist/extractor-cursor.test.js.map +1 -0
- package/dist/extractors/claude-code.d.ts.map +1 -1
- package/dist/extractors/claude-code.js +172 -73
- package/dist/extractors/claude-code.js.map +1 -1
- package/dist/extractors/codex.d.ts.map +1 -1
- package/dist/extractors/codex.js +63 -35
- package/dist/extractors/codex.js.map +1 -1
- package/dist/extractors/common.d.ts +14 -0
- package/dist/extractors/common.d.ts.map +1 -0
- package/dist/extractors/common.js +100 -0
- package/dist/extractors/common.js.map +1 -0
- package/dist/extractors/cursor.d.ts.map +1 -1
- package/dist/extractors/cursor.js +205 -45
- package/dist/extractors/cursor.js.map +1 -1
- package/dist/hash.d.ts.map +1 -1
- package/dist/hash.js +35 -2
- package/dist/hash.js.map +1 -1
- package/dist/hash.test.js +29 -2
- package/dist/hash.test.js.map +1 -1
- package/dist/index.d.ts +1 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +1 -0
- package/dist/index.js.map +1 -1
- package/dist/redact.d.ts +12 -0
- package/dist/redact.d.ts.map +1 -1
- package/dist/redact.js +120 -38
- package/dist/redact.js.map +1 -1
- package/dist/redact.test.d.ts +2 -0
- package/dist/redact.test.d.ts.map +1 -0
- package/dist/redact.test.js +96 -0
- package/dist/redact.test.js.map +1 -0
- package/dist/turn-actors.d.ts +3 -0
- package/dist/turn-actors.d.ts.map +1 -0
- package/dist/turn-actors.js +57 -0
- package/dist/turn-actors.js.map +1 -0
- package/dist/turn-actors.test.d.ts +2 -0
- package/dist/turn-actors.test.d.ts.map +1 -0
- package/dist/turn-actors.test.js +65 -0
- package/dist/turn-actors.test.js.map +1 -0
- package/dist/types.d.ts +5 -0
- package/dist/types.d.ts.map +1 -1
- package/dist/utils.d.ts +1 -1
- package/dist/utils.d.ts.map +1 -1
- package/dist/utils.js +4 -0
- package/dist/utils.js.map +1 -1
- package/dist/validators.d.ts +24 -0
- package/dist/validators.d.ts.map +1 -1
- package/dist/validators.js +3 -0
- package/dist/validators.js.map +1 -1
- package/package.json +5 -1
- package/src/chunker.ts +17 -2
- package/src/extractor-claude-code.test.ts +326 -0
- package/src/extractor-codex.test.ts +225 -0
- package/src/extractor-cursor.test.ts +141 -0
- package/src/extractors/claude-code.ts +180 -69
- package/src/extractors/codex.ts +69 -38
- package/src/extractors/common.ts +139 -0
- package/src/extractors/cursor.ts +294 -52
- package/src/hash.test.ts +31 -2
- package/src/hash.ts +38 -3
- package/src/index.ts +1 -0
- package/src/redact.test.ts +100 -0
- package/src/redact.ts +175 -58
- package/src/turn-actors.test.ts +71 -0
- package/src/turn-actors.ts +71 -0
- package/src/types.ts +6 -0
- package/src/utils.ts +3 -1
- package/src/validators.ts +3 -0
package/dist/chunker.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"chunker.d.ts","sourceRoot":"","sources":["../src/chunker.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAQ,MAAM,YAAY,CAAC;AAuDxD;;;;GAIG;AACH,wBAAgB,UAAU,CACxB,KAAK,EAAE,eAAe,EACtB,eAAe,SAAoB,GAClC,eAAe,EAAE,
|
|
1
|
+
{"version":3,"file":"chunker.d.ts","sourceRoot":"","sources":["../src/chunker.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAQ,MAAM,YAAY,CAAC;AAuDxD;;;;GAIG;AACH,wBAAgB,UAAU,CACxB,KAAK,EAAE,eAAe,EACtB,eAAe,SAAoB,GAClC,eAAe,EAAE,CAuDnB"}
|
package/dist/chunker.js
CHANGED
|
@@ -39,13 +39,25 @@ export function chunkTrace(trace, maxOutputTokens = MAX_OUTPUT_TOKENS) {
|
|
|
39
39
|
if (totalOutput <= maxOutputTokens) {
|
|
40
40
|
return [{ ...trace, chunk_index: 0, chunk_start_turn: 0 }];
|
|
41
41
|
}
|
|
42
|
+
// If per-turn usage isn't populated, distribute total_output_tokens uniformly
|
|
43
|
+
// across assistant turns so the chunk boundary logic still fires correctly.
|
|
44
|
+
const perTurnSum = sumOutputTokens(trace.turns);
|
|
45
|
+
const turns = perTurnSum > 0
|
|
46
|
+
? trace.turns
|
|
47
|
+
: (() => {
|
|
48
|
+
const assistantTurns = trace.turns.filter(t => t.role === "assistant").length || 1;
|
|
49
|
+
const tokensPerAssistantTurn = Math.ceil(totalOutput / assistantTurns);
|
|
50
|
+
return trace.turns.map(t => t.role === "assistant" && (t.usage?.output_tokens ?? 0) === 0
|
|
51
|
+
? { ...t, usage: { input_tokens: t.usage?.input_tokens ?? 0, output_tokens: tokensPerAssistantTurn, cache_read_input_tokens: t.usage?.cache_read_input_tokens ?? null, cache_creation_input_tokens: t.usage?.cache_creation_input_tokens ?? null, reasoning_tokens: t.usage?.reasoning_tokens ?? null } }
|
|
52
|
+
: t);
|
|
53
|
+
})();
|
|
42
54
|
const chunks = [];
|
|
43
55
|
let chunkStartTurn = 0;
|
|
44
56
|
let chunkOutputTokens = 0;
|
|
45
57
|
let chunkTurns = [];
|
|
46
58
|
let chunkIndex = 0;
|
|
47
|
-
for (let i = 0; i <
|
|
48
|
-
const turn =
|
|
59
|
+
for (let i = 0; i < turns.length; i++) {
|
|
60
|
+
const turn = turns[i];
|
|
49
61
|
// Break at user-turn boundary once we've accumulated enough
|
|
50
62
|
if (turn.role === "user" &&
|
|
51
63
|
chunkOutputTokens >= maxOutputTokens &&
|
package/dist/chunker.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"chunker.js","sourceRoot":"","sources":["../src/chunker.ts"],"names":[],"mappings":"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
|
|
1
|
+
{"version":3,"file":"chunker.js","sourceRoot":"","sources":["../src/chunker.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"extractor-claude-code.test.d.ts","sourceRoot":"","sources":["../src/extractor-claude-code.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,290 @@
|
|
|
1
|
+
import { describe, it, expect, beforeAll } from "vitest";
|
|
2
|
+
import { writeFileSync, mkdirSync } from "fs";
|
|
3
|
+
import { tmpdir } from "os";
|
|
4
|
+
import { join } from "path";
|
|
5
|
+
import { extractClaudeCode } from "./extractors/claude-code.js";
|
|
6
|
+
// Build a JSONL fixture on disk once, then test against it.
|
|
7
|
+
// The fixture exercises the key bugs that were fixed:
|
|
8
|
+
// 1. Chained assistant entries (thinking+tool_use) must be merged into one turn
|
|
9
|
+
// 2. Cache tokens (cache_creation + cache_read) must be included in total_input_tokens
|
|
10
|
+
// 3. Output tokens must be summed across all chain entries, not just the root
|
|
11
|
+
const FIXTURE_PATH = join(tmpdir(), "tracemp-extractor-test.jsonl");
|
|
12
|
+
const FIXTURE_LINES = [
|
|
13
|
+
// Skipped: file-history-snapshot
|
|
14
|
+
{ type: "file-history-snapshot", messageId: "snap1", snapshot: {} },
|
|
15
|
+
// Turn 0 — user initial message (string content)
|
|
16
|
+
{
|
|
17
|
+
type: "user",
|
|
18
|
+
uuid: "u1",
|
|
19
|
+
parentUuid: null,
|
|
20
|
+
timestamp: "2024-01-01T00:00:00.000Z",
|
|
21
|
+
gitBranch: "main",
|
|
22
|
+
cwd: "/home/user/project",
|
|
23
|
+
message: { role: "user", content: "Please help me with a task" },
|
|
24
|
+
},
|
|
25
|
+
// Turn 1 — assistant: thinking (root) → tool_use (child), must MERGE
|
|
26
|
+
{
|
|
27
|
+
type: "assistant",
|
|
28
|
+
uuid: "a1",
|
|
29
|
+
parentUuid: "u1",
|
|
30
|
+
timestamp: "2024-01-01T00:00:01.000Z",
|
|
31
|
+
message: {
|
|
32
|
+
role: "assistant",
|
|
33
|
+
model: "claude-sonnet-4-5",
|
|
34
|
+
content: [{ type: "thinking", thinking: "Let me think..." }],
|
|
35
|
+
usage: {
|
|
36
|
+
input_tokens: 5,
|
|
37
|
+
cache_creation_input_tokens: 1000,
|
|
38
|
+
cache_read_input_tokens: 500,
|
|
39
|
+
output_tokens: 10,
|
|
40
|
+
},
|
|
41
|
+
},
|
|
42
|
+
},
|
|
43
|
+
{
|
|
44
|
+
type: "assistant",
|
|
45
|
+
uuid: "a2",
|
|
46
|
+
parentUuid: "a1",
|
|
47
|
+
timestamp: "2024-01-01T00:00:01.000Z",
|
|
48
|
+
message: {
|
|
49
|
+
role: "assistant",
|
|
50
|
+
model: "claude-sonnet-4-5",
|
|
51
|
+
content: [{ type: "tool_use", id: "tu1", name: "Bash", input: { command: "ls" } }],
|
|
52
|
+
usage: {
|
|
53
|
+
input_tokens: 5,
|
|
54
|
+
cache_creation_input_tokens: 1000,
|
|
55
|
+
cache_read_input_tokens: 500,
|
|
56
|
+
output_tokens: 25,
|
|
57
|
+
},
|
|
58
|
+
},
|
|
59
|
+
},
|
|
60
|
+
// Skipped: progress entries
|
|
61
|
+
{ type: "progress", uuid: "p1", parentUuid: "a2" },
|
|
62
|
+
{ type: "progress", uuid: "p2", parentUuid: "p1" },
|
|
63
|
+
// Turn 2 — user tool_result
|
|
64
|
+
{
|
|
65
|
+
type: "user",
|
|
66
|
+
uuid: "u2",
|
|
67
|
+
parentUuid: "a2",
|
|
68
|
+
timestamp: "2024-01-01T00:00:02.000Z",
|
|
69
|
+
message: {
|
|
70
|
+
role: "user",
|
|
71
|
+
content: [
|
|
72
|
+
{
|
|
73
|
+
type: "tool_result",
|
|
74
|
+
tool_use_id: "tu1",
|
|
75
|
+
content: [{ type: "text", text: "file1.ts\nfile2.ts" }],
|
|
76
|
+
is_error: false,
|
|
77
|
+
},
|
|
78
|
+
],
|
|
79
|
+
},
|
|
80
|
+
},
|
|
81
|
+
// Turn 3 — assistant: text (root) → tool_use (child), must MERGE
|
|
82
|
+
{
|
|
83
|
+
type: "assistant",
|
|
84
|
+
uuid: "a3",
|
|
85
|
+
parentUuid: "u2",
|
|
86
|
+
timestamp: "2024-01-01T00:00:03.000Z",
|
|
87
|
+
message: {
|
|
88
|
+
role: "assistant",
|
|
89
|
+
model: "claude-sonnet-4-5",
|
|
90
|
+
content: [{ type: "text", text: "Here is what I found:" }],
|
|
91
|
+
usage: {
|
|
92
|
+
input_tokens: 3,
|
|
93
|
+
cache_creation_input_tokens: 0,
|
|
94
|
+
cache_read_input_tokens: 1500,
|
|
95
|
+
output_tokens: 8,
|
|
96
|
+
},
|
|
97
|
+
},
|
|
98
|
+
},
|
|
99
|
+
{
|
|
100
|
+
type: "assistant",
|
|
101
|
+
uuid: "a4",
|
|
102
|
+
parentUuid: "a3",
|
|
103
|
+
timestamp: "2024-01-01T00:00:03.000Z",
|
|
104
|
+
message: {
|
|
105
|
+
role: "assistant",
|
|
106
|
+
model: "claude-sonnet-4-5",
|
|
107
|
+
content: [{ type: "tool_use", id: "tu2", name: "Read", input: { file_path: "file1.ts" } }],
|
|
108
|
+
usage: {
|
|
109
|
+
input_tokens: 3,
|
|
110
|
+
cache_creation_input_tokens: 0,
|
|
111
|
+
cache_read_input_tokens: 1500,
|
|
112
|
+
output_tokens: 15,
|
|
113
|
+
},
|
|
114
|
+
},
|
|
115
|
+
},
|
|
116
|
+
// Turn 4 — user tool_result
|
|
117
|
+
{
|
|
118
|
+
type: "user",
|
|
119
|
+
uuid: "u3",
|
|
120
|
+
parentUuid: "a4",
|
|
121
|
+
timestamp: "2024-01-01T00:00:04.000Z",
|
|
122
|
+
message: {
|
|
123
|
+
role: "user",
|
|
124
|
+
content: [
|
|
125
|
+
{
|
|
126
|
+
type: "tool_result",
|
|
127
|
+
tool_use_id: "tu2",
|
|
128
|
+
content: [{ type: "text", text: "const x = 1;" }],
|
|
129
|
+
is_error: false,
|
|
130
|
+
},
|
|
131
|
+
],
|
|
132
|
+
},
|
|
133
|
+
},
|
|
134
|
+
// Turn 5 — simple assistant text, no chain
|
|
135
|
+
{
|
|
136
|
+
type: "assistant",
|
|
137
|
+
uuid: "a5",
|
|
138
|
+
parentUuid: "u3",
|
|
139
|
+
timestamp: "2024-01-01T00:00:05.000Z",
|
|
140
|
+
message: {
|
|
141
|
+
role: "assistant",
|
|
142
|
+
model: "claude-sonnet-4-5",
|
|
143
|
+
content: [{ type: "text", text: "Done! The file contains a constant." }],
|
|
144
|
+
usage: {
|
|
145
|
+
input_tokens: 2,
|
|
146
|
+
cache_creation_input_tokens: 0,
|
|
147
|
+
cache_read_input_tokens: 2000,
|
|
148
|
+
output_tokens: 20,
|
|
149
|
+
},
|
|
150
|
+
},
|
|
151
|
+
},
|
|
152
|
+
// Skipped: last-prompt
|
|
153
|
+
{ type: "last-prompt", uuid: "" },
|
|
154
|
+
];
|
|
155
|
+
beforeAll(() => {
|
|
156
|
+
mkdirSync(tmpdir(), { recursive: true });
|
|
157
|
+
writeFileSync(FIXTURE_PATH, FIXTURE_LINES.map((l) => JSON.stringify(l)).join("\n") + "\n");
|
|
158
|
+
});
|
|
159
|
+
describe("extractClaudeCode", () => {
|
|
160
|
+
it("merges chained assistant entries into one turn", async () => {
|
|
161
|
+
const trace = await extractClaudeCode(FIXTURE_PATH, "test@test.com");
|
|
162
|
+
// Should have 6 turns: user, assistant(merged), user, assistant(merged), user, assistant
|
|
163
|
+
expect(trace.turn_count).toBe(6);
|
|
164
|
+
// Roles must strictly alternate
|
|
165
|
+
const roles = trace.turns.map((t) => t.role);
|
|
166
|
+
for (let i = 1; i < roles.length; i++) {
|
|
167
|
+
expect(roles[i]).not.toBe(roles[i - 1]);
|
|
168
|
+
}
|
|
169
|
+
// Turn 1: thinking+tool_use merged from two chained entries
|
|
170
|
+
expect(trace.turns[1].role).toBe("assistant");
|
|
171
|
+
const t1Types = trace.turns[1].content.map((c) => c.type);
|
|
172
|
+
expect(t1Types).toContain("thinking");
|
|
173
|
+
expect(t1Types).toContain("tool_use");
|
|
174
|
+
// Turn 3: text+tool_use merged
|
|
175
|
+
expect(trace.turns[3].role).toBe("assistant");
|
|
176
|
+
const t3Types = trace.turns[3].content.map((c) => c.type);
|
|
177
|
+
expect(t3Types).toContain("text");
|
|
178
|
+
expect(t3Types).toContain("tool_use");
|
|
179
|
+
});
|
|
180
|
+
it("counts tool calls correctly", async () => {
|
|
181
|
+
const trace = await extractClaudeCode(FIXTURE_PATH, "test@test.com");
|
|
182
|
+
expect(trace.tool_call_count).toBe(2);
|
|
183
|
+
});
|
|
184
|
+
it("includes cache tokens in total_input_tokens", async () => {
|
|
185
|
+
const trace = await extractClaudeCode(FIXTURE_PATH, "test@test.com");
|
|
186
|
+
// Turn 1: input=5 + cache_create=1000 + cache_read=500 = 1505 (counted once, not twice)
|
|
187
|
+
// Turn 3: input=3 + cache_create=0 + cache_read=1500 = 1503
|
|
188
|
+
// Turn 5: input=2 + cache_create=0 + cache_read=2000 = 2002
|
|
189
|
+
// Total: 1505 + 1503 + 2002 = 5010
|
|
190
|
+
expect(trace.total_input_tokens).toBe(5010);
|
|
191
|
+
});
|
|
192
|
+
it("does not double-count input tokens from chained entries", async () => {
|
|
193
|
+
const trace = await extractClaudeCode(FIXTURE_PATH, "test@test.com");
|
|
194
|
+
// Turn 1 root (a1) and child (a2) both carry the same input/cache usage (same API call).
|
|
195
|
+
// We must count it only once from the root.
|
|
196
|
+
// If double-counted: 1505 * 2 + 1503 + 2002 = 6010. Correct: 5010.
|
|
197
|
+
expect(trace.total_input_tokens).toBe(5010);
|
|
198
|
+
});
|
|
199
|
+
it("sums output tokens across all chain entries", async () => {
|
|
200
|
+
const trace = await extractClaudeCode(FIXTURE_PATH, "test@test.com");
|
|
201
|
+
// Turn 1: root output=10 (thinking) + child output=25 (tool_use) = 35
|
|
202
|
+
// Turn 3: root output=8 (text) + child output=15 (tool_use) = 23
|
|
203
|
+
// Turn 5: output=20
|
|
204
|
+
// Total: 35 + 23 + 20 = 78
|
|
205
|
+
expect(trace.total_output_tokens).toBe(78);
|
|
206
|
+
// Turn 1's per-turn usage should also reflect the summed output
|
|
207
|
+
expect(trace.turns[1].usage?.output_tokens).toBe(35);
|
|
208
|
+
});
|
|
209
|
+
it("skips progress, file-history-snapshot, and last-prompt entries", async () => {
|
|
210
|
+
const trace = await extractClaudeCode(FIXTURE_PATH, "test@test.com");
|
|
211
|
+
// All entries that should be skipped produce no turns
|
|
212
|
+
expect(trace.turn_count).toBe(6);
|
|
213
|
+
});
|
|
214
|
+
it("captures git branch and session metadata", async () => {
|
|
215
|
+
const trace = await extractClaudeCode(FIXTURE_PATH, "test@test.com");
|
|
216
|
+
expect(trace.git_branch).toBe("main");
|
|
217
|
+
expect(trace.cwd_hash).toBeTruthy();
|
|
218
|
+
expect(trace.source_tool).toBe("claude_code");
|
|
219
|
+
expect(trace.submitted_by).toBe("test@test.com");
|
|
220
|
+
});
|
|
221
|
+
it("sets started_at and ended_at from first and last turn timestamps", async () => {
|
|
222
|
+
const trace = await extractClaudeCode(FIXTURE_PATH, "test@test.com");
|
|
223
|
+
expect(trace.started_at).toBe("2024-01-01T00:00:00.000Z");
|
|
224
|
+
expect(trace.ended_at).toBe("2024-01-01T00:00:05.000Z");
|
|
225
|
+
});
|
|
226
|
+
it("marks skill context chained off tool output as tool-authored", async () => {
|
|
227
|
+
const skillFixturePath = join(tmpdir(), "tracemp-extractor-skill-test.jsonl");
|
|
228
|
+
writeFileSync(skillFixturePath, [
|
|
229
|
+
{
|
|
230
|
+
type: "user",
|
|
231
|
+
uuid: "u1",
|
|
232
|
+
parentUuid: null,
|
|
233
|
+
timestamp: "2024-01-01T00:00:00.000Z",
|
|
234
|
+
message: { role: "user", content: "why is lazyvim failing" },
|
|
235
|
+
},
|
|
236
|
+
{
|
|
237
|
+
type: "assistant",
|
|
238
|
+
uuid: "a1",
|
|
239
|
+
parentUuid: "u1",
|
|
240
|
+
timestamp: "2024-01-01T00:00:01.000Z",
|
|
241
|
+
message: {
|
|
242
|
+
role: "assistant",
|
|
243
|
+
model: "claude-sonnet-4-5",
|
|
244
|
+
content: [{ type: "tool_use", id: "skill-1", name: "Skill", input: { skill_name: "trent-lazyvim" } }],
|
|
245
|
+
usage: {
|
|
246
|
+
input_tokens: 10,
|
|
247
|
+
cache_creation_input_tokens: 0,
|
|
248
|
+
cache_read_input_tokens: 0,
|
|
249
|
+
output_tokens: 5,
|
|
250
|
+
},
|
|
251
|
+
},
|
|
252
|
+
},
|
|
253
|
+
{
|
|
254
|
+
type: "user",
|
|
255
|
+
uuid: "u2",
|
|
256
|
+
parentUuid: "a1",
|
|
257
|
+
timestamp: "2024-01-01T00:00:02.000Z",
|
|
258
|
+
message: {
|
|
259
|
+
role: "user",
|
|
260
|
+
content: [
|
|
261
|
+
{
|
|
262
|
+
type: "tool_result",
|
|
263
|
+
tool_use_id: "skill-1",
|
|
264
|
+
content: [{ type: "text", text: "Launching skill: trent-lazyvim" }],
|
|
265
|
+
is_error: false,
|
|
266
|
+
},
|
|
267
|
+
],
|
|
268
|
+
},
|
|
269
|
+
},
|
|
270
|
+
{
|
|
271
|
+
type: "user",
|
|
272
|
+
uuid: "u3",
|
|
273
|
+
parentUuid: "u2",
|
|
274
|
+
timestamp: "2024-01-01T00:00:03.000Z",
|
|
275
|
+
message: {
|
|
276
|
+
role: "user",
|
|
277
|
+
content: "Base directory for this skill: ~/.claude/skills/trent-lazyvim",
|
|
278
|
+
},
|
|
279
|
+
},
|
|
280
|
+
].map((line) => JSON.stringify(line)).join("\n") + "\n");
|
|
281
|
+
const trace = await extractClaudeCode(skillFixturePath, "test@test.com");
|
|
282
|
+
expect(trace.turns.map((turn) => turn.actor)).toEqual([
|
|
283
|
+
"human",
|
|
284
|
+
"assistant",
|
|
285
|
+
"tool",
|
|
286
|
+
"tool",
|
|
287
|
+
]);
|
|
288
|
+
});
|
|
289
|
+
});
|
|
290
|
+
//# sourceMappingURL=extractor-claude-code.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"extractor-claude-code.test.js","sourceRoot":"","sources":["../src/extractor-claude-code.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"extractor-codex.test.d.ts","sourceRoot":"","sources":["../src/extractor-codex.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,212 @@
|
|
|
1
|
+
import { describe, expect, it } from "vitest";
|
|
2
|
+
import { extractCodex } from "./extractors/codex.js";
|
|
3
|
+
function makeBuffer(lines) {
|
|
4
|
+
return Buffer.from(lines.map((line) => JSON.stringify(line)).join("\n") + "\n", "utf-8");
|
|
5
|
+
}
|
|
6
|
+
describe("extractCodex", () => {
|
|
7
|
+
it("parses modern Codex response items and token counts", async () => {
|
|
8
|
+
const trace = await extractCodex(makeBuffer([
|
|
9
|
+
{
|
|
10
|
+
timestamp: "2026-03-21T00:00:00.000Z",
|
|
11
|
+
type: "session_meta",
|
|
12
|
+
payload: {
|
|
13
|
+
id: "codex-session-1",
|
|
14
|
+
timestamp: "2026-03-21T00:00:00.000Z",
|
|
15
|
+
cwd: "/Users/test/project",
|
|
16
|
+
cli_version: "0.110.0",
|
|
17
|
+
},
|
|
18
|
+
},
|
|
19
|
+
{
|
|
20
|
+
timestamp: "2026-03-21T00:00:01.000Z",
|
|
21
|
+
type: "event_msg",
|
|
22
|
+
payload: { type: "task_started", turn_id: "turn-1" },
|
|
23
|
+
},
|
|
24
|
+
{
|
|
25
|
+
timestamp: "2026-03-21T00:00:01.000Z",
|
|
26
|
+
type: "turn_context",
|
|
27
|
+
payload: { model: "gpt-5.4" },
|
|
28
|
+
},
|
|
29
|
+
{
|
|
30
|
+
timestamp: "2026-03-21T00:00:02.000Z",
|
|
31
|
+
type: "event_msg",
|
|
32
|
+
payload: { type: "user_message", message: "Audit the repo" },
|
|
33
|
+
},
|
|
34
|
+
{
|
|
35
|
+
timestamp: "2026-03-21T00:00:03.000Z",
|
|
36
|
+
type: "response_item",
|
|
37
|
+
payload: {
|
|
38
|
+
type: "message",
|
|
39
|
+
role: "assistant",
|
|
40
|
+
content: [{ type: "output_text", text: "I will inspect the repo." }],
|
|
41
|
+
},
|
|
42
|
+
},
|
|
43
|
+
{
|
|
44
|
+
timestamp: "2026-03-21T00:00:04.000Z",
|
|
45
|
+
type: "response_item",
|
|
46
|
+
payload: {
|
|
47
|
+
type: "function_call",
|
|
48
|
+
name: "exec_command",
|
|
49
|
+
arguments: JSON.stringify({
|
|
50
|
+
cmd: "sed -n '1,120p' src/main.ts",
|
|
51
|
+
workdir: "/Users/test/project",
|
|
52
|
+
}),
|
|
53
|
+
call_id: "call-1",
|
|
54
|
+
},
|
|
55
|
+
},
|
|
56
|
+
{
|
|
57
|
+
timestamp: "2026-03-21T00:00:05.000Z",
|
|
58
|
+
type: "response_item",
|
|
59
|
+
payload: {
|
|
60
|
+
type: "function_call_output",
|
|
61
|
+
call_id: "call-1",
|
|
62
|
+
output: "Process exited with code 0\nsrc/main.ts",
|
|
63
|
+
},
|
|
64
|
+
},
|
|
65
|
+
{
|
|
66
|
+
timestamp: "2026-03-21T00:00:06.000Z",
|
|
67
|
+
type: "event_msg",
|
|
68
|
+
payload: {
|
|
69
|
+
type: "token_count",
|
|
70
|
+
info: {
|
|
71
|
+
total_token_usage: {
|
|
72
|
+
input_tokens: 1200,
|
|
73
|
+
cached_input_tokens: 200,
|
|
74
|
+
output_tokens: 300,
|
|
75
|
+
reasoning_output_tokens: 50,
|
|
76
|
+
total_tokens: 1500,
|
|
77
|
+
},
|
|
78
|
+
},
|
|
79
|
+
},
|
|
80
|
+
},
|
|
81
|
+
{
|
|
82
|
+
timestamp: "2026-03-21T00:00:07.000Z",
|
|
83
|
+
type: "event_msg",
|
|
84
|
+
payload: { type: "agent_message", message: "I found the relevant file." },
|
|
85
|
+
},
|
|
86
|
+
{
|
|
87
|
+
timestamp: "2026-03-21T00:00:08.000Z",
|
|
88
|
+
type: "event_msg",
|
|
89
|
+
payload: {
|
|
90
|
+
type: "task_complete",
|
|
91
|
+
last_agent_message: "I found the relevant file.",
|
|
92
|
+
},
|
|
93
|
+
},
|
|
94
|
+
]), "test@example.com");
|
|
95
|
+
expect(trace.source_tool).toBe("codex_cli");
|
|
96
|
+
expect(trace.source_session_id).toBe("codex-session-1");
|
|
97
|
+
expect(trace.source_version).toBe("0.110.0");
|
|
98
|
+
expect(trace.turn_count).toBe(2);
|
|
99
|
+
expect(trace.total_input_tokens).toBe(1200);
|
|
100
|
+
expect(trace.total_output_tokens).toBe(300);
|
|
101
|
+
expect(trace.total_cache_read_tokens).toBe(200);
|
|
102
|
+
expect(trace.has_shell_commands).toBe(true);
|
|
103
|
+
expect(trace.has_tool_calls).toBe(true);
|
|
104
|
+
expect(trace.cwd_hash).toBeTruthy();
|
|
105
|
+
expect(trace.turns[0]).toMatchObject({
|
|
106
|
+
role: "user",
|
|
107
|
+
content: [{ type: "text", text: "Audit the repo" }],
|
|
108
|
+
});
|
|
109
|
+
expect(trace.turns[1].role).toBe("assistant");
|
|
110
|
+
expect(trace.turns[1].model).toBe("gpt-5.4");
|
|
111
|
+
expect(trace.turns[1].content.map((block) => block.type)).toEqual([
|
|
112
|
+
"text",
|
|
113
|
+
"tool_use",
|
|
114
|
+
"tool_result",
|
|
115
|
+
"text",
|
|
116
|
+
]);
|
|
117
|
+
expect(trace.turns[1].content[0]).toMatchObject({
|
|
118
|
+
type: "text",
|
|
119
|
+
text: "I will inspect the repo.",
|
|
120
|
+
});
|
|
121
|
+
expect(trace.turns[1].content[1]).toMatchObject({
|
|
122
|
+
type: "tool_use",
|
|
123
|
+
tool_name: "exec_command",
|
|
124
|
+
});
|
|
125
|
+
expect(trace.turns[1].content[2]).toMatchObject({
|
|
126
|
+
type: "tool_result",
|
|
127
|
+
tool_call_id: "call-1",
|
|
128
|
+
is_error: false,
|
|
129
|
+
exit_code: 0,
|
|
130
|
+
});
|
|
131
|
+
expect(trace.turns[1].content[3]).toMatchObject({
|
|
132
|
+
type: "text",
|
|
133
|
+
text: "I found the relevant file.",
|
|
134
|
+
});
|
|
135
|
+
});
|
|
136
|
+
it("falls back to response-item user messages and preserves invalid tool arguments", async () => {
|
|
137
|
+
const trace = await extractCodex(makeBuffer([
|
|
138
|
+
{
|
|
139
|
+
timestamp: "2026-03-21T01:00:00.000Z",
|
|
140
|
+
type: "session_meta",
|
|
141
|
+
payload: { id: "codex-session-2", timestamp: "2026-03-21T01:00:00.000Z" },
|
|
142
|
+
},
|
|
143
|
+
{
|
|
144
|
+
timestamp: "2026-03-21T01:00:01.000Z",
|
|
145
|
+
type: "event_msg",
|
|
146
|
+
payload: { type: "task_started", turn_id: "turn-2" },
|
|
147
|
+
},
|
|
148
|
+
{
|
|
149
|
+
timestamp: "2026-03-21T01:00:02.000Z",
|
|
150
|
+
type: "response_item",
|
|
151
|
+
payload: {
|
|
152
|
+
type: "message",
|
|
153
|
+
role: "user",
|
|
154
|
+
content: [{ type: "input_text", text: "Retry the failing command" }],
|
|
155
|
+
},
|
|
156
|
+
},
|
|
157
|
+
{
|
|
158
|
+
timestamp: "2026-03-21T01:00:03.000Z",
|
|
159
|
+
type: "response_item",
|
|
160
|
+
payload: {
|
|
161
|
+
type: "reasoning",
|
|
162
|
+
content: [{ type: "text", text: "I should re-run it with verbose output." }],
|
|
163
|
+
},
|
|
164
|
+
},
|
|
165
|
+
{
|
|
166
|
+
timestamp: "2026-03-21T01:00:04.000Z",
|
|
167
|
+
type: "response_item",
|
|
168
|
+
payload: {
|
|
169
|
+
type: "function_call",
|
|
170
|
+
name: "exec_command",
|
|
171
|
+
arguments: "{not-json",
|
|
172
|
+
call_id: "call-err",
|
|
173
|
+
},
|
|
174
|
+
},
|
|
175
|
+
{
|
|
176
|
+
timestamp: "2026-03-21T01:00:05.000Z",
|
|
177
|
+
type: "response_item",
|
|
178
|
+
payload: {
|
|
179
|
+
type: "function_call_output",
|
|
180
|
+
call_id: "call-err",
|
|
181
|
+
output: "Process exited with code 2\nError: command failed",
|
|
182
|
+
},
|
|
183
|
+
},
|
|
184
|
+
{
|
|
185
|
+
timestamp: "2026-03-21T01:00:06.000Z",
|
|
186
|
+
type: "event_msg",
|
|
187
|
+
payload: { type: "task_complete", last_agent_message: "The command failed again." },
|
|
188
|
+
},
|
|
189
|
+
]), "test@example.com");
|
|
190
|
+
expect(trace.turn_count).toBe(2);
|
|
191
|
+
expect(trace.has_thinking_blocks).toBe(true);
|
|
192
|
+
expect(trace.turns[0]).toMatchObject({
|
|
193
|
+
role: "user",
|
|
194
|
+
content: [{ type: "text", text: "Retry the failing command" }],
|
|
195
|
+
});
|
|
196
|
+
const assistantBlocks = trace.turns[1].content;
|
|
197
|
+
expect(assistantBlocks[0]).toMatchObject({
|
|
198
|
+
type: "thinking",
|
|
199
|
+
text: "I should re-run it with verbose output.",
|
|
200
|
+
});
|
|
201
|
+
expect(assistantBlocks[1]).toMatchObject({
|
|
202
|
+
type: "tool_use",
|
|
203
|
+
tool_input: { raw: "{not-json" },
|
|
204
|
+
});
|
|
205
|
+
expect(assistantBlocks[2]).toMatchObject({
|
|
206
|
+
type: "tool_result",
|
|
207
|
+
is_error: true,
|
|
208
|
+
exit_code: 2,
|
|
209
|
+
});
|
|
210
|
+
});
|
|
211
|
+
});
|
|
212
|
+
//# sourceMappingURL=extractor-codex.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"extractor-codex.test.js","sourceRoot":"","sources":["../src/extractor-codex.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"extractor-cursor.test.d.ts","sourceRoot":"","sources":["../src/extractor-cursor.test.ts"],"names":[],"mappings":""}
|