@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.
Files changed (82) hide show
  1. package/dist/chunker.d.ts.map +1 -1
  2. package/dist/chunker.js +14 -2
  3. package/dist/chunker.js.map +1 -1
  4. package/dist/extractor-claude-code.test.d.ts +2 -0
  5. package/dist/extractor-claude-code.test.d.ts.map +1 -0
  6. package/dist/extractor-claude-code.test.js +290 -0
  7. package/dist/extractor-claude-code.test.js.map +1 -0
  8. package/dist/extractor-codex.test.d.ts +2 -0
  9. package/dist/extractor-codex.test.d.ts.map +1 -0
  10. package/dist/extractor-codex.test.js +212 -0
  11. package/dist/extractor-codex.test.js.map +1 -0
  12. package/dist/extractor-cursor.test.d.ts +2 -0
  13. package/dist/extractor-cursor.test.d.ts.map +1 -0
  14. package/dist/extractor-cursor.test.js +120 -0
  15. package/dist/extractor-cursor.test.js.map +1 -0
  16. package/dist/extractors/claude-code.d.ts.map +1 -1
  17. package/dist/extractors/claude-code.js +172 -73
  18. package/dist/extractors/claude-code.js.map +1 -1
  19. package/dist/extractors/codex.d.ts.map +1 -1
  20. package/dist/extractors/codex.js +63 -35
  21. package/dist/extractors/codex.js.map +1 -1
  22. package/dist/extractors/common.d.ts +14 -0
  23. package/dist/extractors/common.d.ts.map +1 -0
  24. package/dist/extractors/common.js +100 -0
  25. package/dist/extractors/common.js.map +1 -0
  26. package/dist/extractors/cursor.d.ts.map +1 -1
  27. package/dist/extractors/cursor.js +205 -45
  28. package/dist/extractors/cursor.js.map +1 -1
  29. package/dist/hash.d.ts.map +1 -1
  30. package/dist/hash.js +35 -2
  31. package/dist/hash.js.map +1 -1
  32. package/dist/hash.test.js +29 -2
  33. package/dist/hash.test.js.map +1 -1
  34. package/dist/index.d.ts +1 -0
  35. package/dist/index.d.ts.map +1 -1
  36. package/dist/index.js +1 -0
  37. package/dist/index.js.map +1 -1
  38. package/dist/redact.d.ts +12 -0
  39. package/dist/redact.d.ts.map +1 -1
  40. package/dist/redact.js +120 -38
  41. package/dist/redact.js.map +1 -1
  42. package/dist/redact.test.d.ts +2 -0
  43. package/dist/redact.test.d.ts.map +1 -0
  44. package/dist/redact.test.js +96 -0
  45. package/dist/redact.test.js.map +1 -0
  46. package/dist/turn-actors.d.ts +3 -0
  47. package/dist/turn-actors.d.ts.map +1 -0
  48. package/dist/turn-actors.js +57 -0
  49. package/dist/turn-actors.js.map +1 -0
  50. package/dist/turn-actors.test.d.ts +2 -0
  51. package/dist/turn-actors.test.d.ts.map +1 -0
  52. package/dist/turn-actors.test.js +65 -0
  53. package/dist/turn-actors.test.js.map +1 -0
  54. package/dist/types.d.ts +5 -0
  55. package/dist/types.d.ts.map +1 -1
  56. package/dist/utils.d.ts +1 -1
  57. package/dist/utils.d.ts.map +1 -1
  58. package/dist/utils.js +4 -0
  59. package/dist/utils.js.map +1 -1
  60. package/dist/validators.d.ts +24 -0
  61. package/dist/validators.d.ts.map +1 -1
  62. package/dist/validators.js +3 -0
  63. package/dist/validators.js.map +1 -1
  64. package/package.json +5 -1
  65. package/src/chunker.ts +17 -2
  66. package/src/extractor-claude-code.test.ts +326 -0
  67. package/src/extractor-codex.test.ts +225 -0
  68. package/src/extractor-cursor.test.ts +141 -0
  69. package/src/extractors/claude-code.ts +180 -69
  70. package/src/extractors/codex.ts +69 -38
  71. package/src/extractors/common.ts +139 -0
  72. package/src/extractors/cursor.ts +294 -52
  73. package/src/hash.test.ts +31 -2
  74. package/src/hash.ts +38 -3
  75. package/src/index.ts +1 -0
  76. package/src/redact.test.ts +100 -0
  77. package/src/redact.ts +175 -58
  78. package/src/turn-actors.test.ts +71 -0
  79. package/src/turn-actors.ts +71 -0
  80. package/src/types.ts +6 -0
  81. package/src/utils.ts +3 -1
  82. package/src/validators.ts +3 -0
@@ -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,CAwCnB"}
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 < trace.turns.length; i++) {
48
- const turn = trace.turns[i];
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 &&
@@ -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,2 @@
1
+ export {};
2
+ //# sourceMappingURL=extractor-claude-code.test.d.ts.map
@@ -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,2 @@
1
+ export {};
2
+ //# sourceMappingURL=extractor-codex.test.d.ts.map
@@ -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,2 @@
1
+ export {};
2
+ //# sourceMappingURL=extractor-cursor.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"extractor-cursor.test.d.ts","sourceRoot":"","sources":["../src/extractor-cursor.test.ts"],"names":[],"mappings":""}