@united-workforce/cli 0.4.0 → 0.5.0

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 (193) hide show
  1. package/README.md +30 -3
  2. package/dist/.build-fingerprint +1 -0
  3. package/dist/__tests__/adapter-json-roundtrip.test.js +16 -6
  4. package/dist/__tests__/adapter-json-roundtrip.test.js.map +1 -1
  5. package/dist/__tests__/concurrency.test.d.ts +2 -0
  6. package/dist/__tests__/concurrency.test.d.ts.map +1 -0
  7. package/dist/__tests__/concurrency.test.js +196 -0
  8. package/dist/__tests__/concurrency.test.js.map +1 -0
  9. package/dist/__tests__/e2e-mock-agent.test.js +23 -7
  10. package/dist/__tests__/e2e-mock-agent.test.js.map +1 -1
  11. package/dist/__tests__/format-text-default.test.d.ts +2 -0
  12. package/dist/__tests__/format-text-default.test.d.ts.map +1 -0
  13. package/dist/__tests__/format-text-default.test.js +43 -0
  14. package/dist/__tests__/format-text-default.test.js.map +1 -0
  15. package/dist/__tests__/format-text-registry.test.d.ts +2 -0
  16. package/dist/__tests__/format-text-registry.test.d.ts.map +1 -0
  17. package/dist/__tests__/format-text-registry.test.js +158 -0
  18. package/dist/__tests__/format-text-registry.test.js.map +1 -0
  19. package/dist/__tests__/log-text-renderer.test.d.ts +2 -0
  20. package/dist/__tests__/log-text-renderer.test.d.ts.map +1 -0
  21. package/dist/__tests__/log-text-renderer.test.js +265 -0
  22. package/dist/__tests__/log-text-renderer.test.js.map +1 -0
  23. package/dist/__tests__/output-mapper-thread-list-startedat.test.d.ts +2 -0
  24. package/dist/__tests__/output-mapper-thread-list-startedat.test.d.ts.map +1 -0
  25. package/dist/__tests__/output-mapper-thread-list-startedat.test.js +102 -0
  26. package/dist/__tests__/output-mapper-thread-list-startedat.test.js.map +1 -0
  27. package/dist/__tests__/output-mapper-workflow-add.test.d.ts +2 -0
  28. package/dist/__tests__/output-mapper-workflow-add.test.d.ts.map +1 -0
  29. package/dist/__tests__/output-mapper-workflow-add.test.js +22 -0
  30. package/dist/__tests__/output-mapper-workflow-add.test.js.map +1 -0
  31. package/dist/__tests__/pid-recycling.test.js +9 -7
  32. package/dist/__tests__/pid-recycling.test.js.map +1 -1
  33. package/dist/__tests__/prompt.test.js +46 -4
  34. package/dist/__tests__/prompt.test.js.map +1 -1
  35. package/dist/__tests__/resolve-head-hash.test.js +8 -0
  36. package/dist/__tests__/resolve-head-hash.test.js.map +1 -1
  37. package/dist/__tests__/solve-issue-tea-worktree.test.js +3 -1
  38. package/dist/__tests__/solve-issue-tea-worktree.test.js.map +1 -1
  39. package/dist/__tests__/step-ask.test.js +9 -1
  40. package/dist/__tests__/step-ask.test.js.map +1 -1
  41. package/dist/__tests__/store-unified-threads.test.js +19 -17
  42. package/dist/__tests__/store-unified-threads.test.js.map +1 -1
  43. package/dist/__tests__/thread-cancel-status.test.js +19 -13
  44. package/dist/__tests__/thread-cancel-status.test.js.map +1 -1
  45. package/dist/__tests__/thread-cancel-text-renderer.test.d.ts +2 -0
  46. package/dist/__tests__/thread-cancel-text-renderer.test.d.ts.map +1 -0
  47. package/dist/__tests__/thread-cancel-text-renderer.test.js +110 -0
  48. package/dist/__tests__/thread-cancel-text-renderer.test.js.map +1 -0
  49. package/dist/__tests__/thread-list-filters.test.js +10 -8
  50. package/dist/__tests__/thread-list-filters.test.js.map +1 -1
  51. package/dist/__tests__/thread-list-template-ms-date.test.d.ts +2 -0
  52. package/dist/__tests__/thread-list-template-ms-date.test.d.ts.map +1 -0
  53. package/dist/__tests__/thread-list-template-ms-date.test.js +102 -0
  54. package/dist/__tests__/thread-list-template-ms-date.test.js.map +1 -0
  55. package/dist/__tests__/thread-list-workflow-corrupt.test.d.ts +2 -0
  56. package/dist/__tests__/thread-list-workflow-corrupt.test.d.ts.map +1 -0
  57. package/dist/__tests__/thread-list-workflow-corrupt.test.js +157 -0
  58. package/dist/__tests__/thread-list-workflow-corrupt.test.js.map +1 -0
  59. package/dist/__tests__/thread-poke.test.js +11 -1
  60. package/dist/__tests__/thread-poke.test.js.map +1 -1
  61. package/dist/__tests__/thread-read-xml-tags.test.js +10 -9
  62. package/dist/__tests__/thread-read-xml-tags.test.js.map +1 -1
  63. package/dist/__tests__/thread-resume.test.js +11 -1
  64. package/dist/__tests__/thread-resume.test.js.map +1 -1
  65. package/dist/__tests__/thread-start-cwd-cli.test.js +15 -3
  66. package/dist/__tests__/thread-start-cwd-cli.test.js.map +1 -1
  67. package/dist/__tests__/thread-stop-text-renderer.test.d.ts +2 -0
  68. package/dist/__tests__/thread-stop-text-renderer.test.d.ts.map +1 -0
  69. package/dist/__tests__/thread-stop-text-renderer.test.js +148 -0
  70. package/dist/__tests__/thread-stop-text-renderer.test.js.map +1 -0
  71. package/dist/__tests__/thread-suspend-step.test.js +5 -2
  72. package/dist/__tests__/thread-suspend-step.test.js.map +1 -1
  73. package/dist/__tests__/thread-test-helpers.d.ts +7 -0
  74. package/dist/__tests__/thread-test-helpers.d.ts.map +1 -1
  75. package/dist/__tests__/thread-test-helpers.js +13 -0
  76. package/dist/__tests__/thread-test-helpers.js.map +1 -1
  77. package/dist/__tests__/thread.test.js +11 -9
  78. package/dist/__tests__/thread.test.js.map +1 -1
  79. package/dist/__tests__/validate-semantic.test.js +56 -2
  80. package/dist/__tests__/validate-semantic.test.js.map +1 -1
  81. package/dist/__tests__/workflow-list-recursive.test.js +10 -7
  82. package/dist/__tests__/workflow-list-recursive.test.js.map +1 -1
  83. package/dist/__tests__/workflow-resolution.test.js +10 -7
  84. package/dist/__tests__/workflow-resolution.test.js.map +1 -1
  85. package/dist/__tests__/workflow-show-resolution.test.js +10 -7
  86. package/dist/__tests__/workflow-show-resolution.test.js.map +1 -1
  87. package/dist/__tests__/workflow-validate.test.js +75 -55
  88. package/dist/__tests__/workflow-validate.test.js.map +1 -1
  89. package/dist/__tests__/write-envelope.test.d.ts +2 -0
  90. package/dist/__tests__/write-envelope.test.d.ts.map +1 -0
  91. package/dist/__tests__/write-envelope.test.js +201 -0
  92. package/dist/__tests__/write-envelope.test.js.map +1 -0
  93. package/dist/cli.js +58 -35
  94. package/dist/cli.js.map +1 -1
  95. package/dist/commands/config.d.ts.map +1 -1
  96. package/dist/commands/config.js +12 -0
  97. package/dist/commands/config.js.map +1 -1
  98. package/dist/commands/prompt.d.ts.map +1 -1
  99. package/dist/commands/prompt.js +42 -29
  100. package/dist/commands/prompt.js.map +1 -1
  101. package/dist/commands/setup.d.ts +9 -4
  102. package/dist/commands/setup.d.ts.map +1 -1
  103. package/dist/commands/setup.js +51 -7
  104. package/dist/commands/setup.js.map +1 -1
  105. package/dist/commands/thread.d.ts.map +1 -1
  106. package/dist/commands/thread.js +44 -2
  107. package/dist/commands/thread.js.map +1 -1
  108. package/dist/commands/workflow.d.ts +1 -1
  109. package/dist/commands/workflow.d.ts.map +1 -1
  110. package/dist/commands/workflow.js +2 -6
  111. package/dist/commands/workflow.js.map +1 -1
  112. package/dist/concurrency/concurrency.d.ts +34 -0
  113. package/dist/concurrency/concurrency.d.ts.map +1 -0
  114. package/dist/concurrency/concurrency.js +216 -0
  115. package/dist/concurrency/concurrency.js.map +1 -0
  116. package/dist/concurrency/index.d.ts +3 -0
  117. package/dist/concurrency/index.d.ts.map +1 -0
  118. package/dist/concurrency/index.js +2 -0
  119. package/dist/concurrency/index.js.map +1 -0
  120. package/dist/concurrency/types.d.ts +19 -0
  121. package/dist/concurrency/types.d.ts.map +1 -0
  122. package/dist/concurrency/types.js +2 -0
  123. package/dist/concurrency/types.js.map +1 -0
  124. package/dist/format.d.ts +69 -2
  125. package/dist/format.d.ts.map +1 -1
  126. package/dist/format.js +198 -1
  127. package/dist/format.js.map +1 -1
  128. package/dist/output-mappers.d.ts +122 -0
  129. package/dist/output-mappers.d.ts.map +1 -0
  130. package/dist/output-mappers.js +134 -0
  131. package/dist/output-mappers.js.map +1 -0
  132. package/dist/schemas.d.ts +4 -1
  133. package/dist/schemas.d.ts.map +1 -1
  134. package/dist/schemas.js +31 -4
  135. package/dist/schemas.js.map +1 -1
  136. package/dist/text-renderers.d.ts +30 -0
  137. package/dist/text-renderers.d.ts.map +1 -0
  138. package/dist/text-renderers.js +251 -0
  139. package/dist/text-renderers.js.map +1 -0
  140. package/dist/validate-semantic.d.ts.map +1 -1
  141. package/dist/validate-semantic.js +28 -11
  142. package/dist/validate-semantic.js.map +1 -1
  143. package/examples/brainstorm.yaml +130 -0
  144. package/examples/debate.yaml +169 -0
  145. package/examples/socratic-questioning.yaml +112 -0
  146. package/package.json +5 -4
  147. package/src/__tests__/adapter-json-roundtrip.test.ts +15 -6
  148. package/src/__tests__/concurrency.test.ts +266 -0
  149. package/src/__tests__/e2e-mock-agent.test.ts +45 -7
  150. package/src/__tests__/format-text-default.test.ts +49 -0
  151. package/src/__tests__/format-text-registry.test.ts +173 -0
  152. package/src/__tests__/log-text-renderer.test.ts +294 -0
  153. package/src/__tests__/output-mapper-thread-list-startedat.test.ts +124 -0
  154. package/src/__tests__/output-mapper-workflow-add.test.ts +24 -0
  155. package/src/__tests__/pid-recycling.test.ts +9 -8
  156. package/src/__tests__/prompt.test.ts +48 -4
  157. package/src/__tests__/resolve-head-hash.test.ts +7 -0
  158. package/src/__tests__/solve-issue-tea-worktree.test.ts +3 -1
  159. package/src/__tests__/step-ask.test.ts +8 -1
  160. package/src/__tests__/store-unified-threads.test.ts +21 -18
  161. package/src/__tests__/thread-cancel-status.test.ts +21 -14
  162. package/src/__tests__/thread-cancel-text-renderer.test.ts +125 -0
  163. package/src/__tests__/thread-list-filters.test.ts +9 -9
  164. package/src/__tests__/thread-list-template-ms-date.test.ts +110 -0
  165. package/src/__tests__/thread-list-workflow-corrupt.test.ts +198 -0
  166. package/src/__tests__/thread-poke.test.ts +10 -1
  167. package/src/__tests__/thread-read-xml-tags.test.ts +9 -11
  168. package/src/__tests__/thread-resume.test.ts +10 -1
  169. package/src/__tests__/thread-start-cwd-cli.test.ts +15 -3
  170. package/src/__tests__/thread-stop-text-renderer.test.ts +168 -0
  171. package/src/__tests__/thread-suspend-step.test.ts +5 -2
  172. package/src/__tests__/thread-test-helpers.ts +15 -1
  173. package/src/__tests__/thread.test.ts +10 -10
  174. package/src/__tests__/validate-semantic.test.ts +59 -2
  175. package/src/__tests__/workflow-list-recursive.test.ts +9 -9
  176. package/src/__tests__/workflow-resolution.test.ts +9 -8
  177. package/src/__tests__/workflow-show-resolution.test.ts +9 -8
  178. package/src/__tests__/workflow-validate.test.ts +78 -56
  179. package/src/__tests__/write-envelope.test.ts +257 -0
  180. package/src/cli.ts +92 -35
  181. package/src/commands/config.ts +11 -0
  182. package/src/commands/prompt.ts +42 -29
  183. package/src/commands/setup.ts +57 -7
  184. package/src/commands/thread.ts +48 -2
  185. package/src/commands/workflow.ts +3 -7
  186. package/src/concurrency/concurrency.ts +245 -0
  187. package/src/concurrency/index.ts +10 -0
  188. package/src/concurrency/types.ts +19 -0
  189. package/src/format.ts +282 -2
  190. package/src/output-mappers.ts +254 -0
  191. package/src/schemas.ts +39 -3
  192. package/src/text-renderers.ts +355 -0
  193. package/src/validate-semantic.ts +33 -12
@@ -0,0 +1,158 @@
1
+ import { describe, expect, test } from "vitest";
2
+ import { formatOutput, getTextRenderer, registerTextRenderer, TEXT_RENDERERS } from "../format.js";
3
+ describe("OutputFormat — text type contract", () => {
4
+ test("formatOutput(data, 'text') returns a string (not undefined)", () => {
5
+ const out = formatOutput({ items: [] }, "text");
6
+ expect(typeof out).toBe("string");
7
+ expect(out).not.toContain("undefined");
8
+ });
9
+ test("formatOutput(data, 'text') with no commandPath returns JSON fallback", () => {
10
+ const data = { foo: "bar" };
11
+ const out = formatOutput(data, "text");
12
+ expect(typeof out).toBe("string");
13
+ // Must be parseable JSON (the fallback)
14
+ expect(() => JSON.parse(out)).not.toThrow();
15
+ });
16
+ test("formatOutput supports 'text' alongside 'json' and 'yaml'", () => {
17
+ const data = { foo: "bar" };
18
+ expect(typeof formatOutput(data, "json")).toBe("string");
19
+ expect(typeof formatOutput(data, "yaml")).toBe("string");
20
+ expect(typeof formatOutput(data, "text")).toBe("string");
21
+ });
22
+ });
23
+ describe("TEXT_RENDERERS registry", () => {
24
+ test("is a Record<string, (data: unknown) => string>", () => {
25
+ expect(TEXT_RENDERERS).toBeDefined();
26
+ expect(typeof TEXT_RENDERERS).toBe("object");
27
+ for (const [key, fn] of Object.entries(TEXT_RENDERERS)) {
28
+ expect(typeof key).toBe("string");
29
+ expect(typeof fn).toBe("function");
30
+ }
31
+ });
32
+ test("contains renderers for all in-scope commands", () => {
33
+ const expectedCommands = [
34
+ "thread list",
35
+ "thread show",
36
+ "thread start",
37
+ "workflow list",
38
+ "workflow show",
39
+ "step list",
40
+ "step show",
41
+ ];
42
+ for (const cmd of expectedCommands) {
43
+ expect(getTextRenderer(cmd)).toBeDefined();
44
+ expect(typeof getTextRenderer(cmd)).toBe("function");
45
+ }
46
+ });
47
+ test("registered renderers always return strings (never undefined)", () => {
48
+ // thread list with empty items
49
+ const threadListOut = TEXT_RENDERERS["thread list"]?.({ items: [] });
50
+ expect(typeof threadListOut).toBe("string");
51
+ expect(threadListOut).not.toContain("undefined");
52
+ // workflow list with empty items
53
+ const workflowListOut = TEXT_RENDERERS["workflow list"]?.({ items: [] });
54
+ expect(typeof workflowListOut).toBe("string");
55
+ expect(workflowListOut).not.toContain("undefined");
56
+ // step list
57
+ const stepListOut = TEXT_RENDERERS["step list"]?.({ threadId: "t", items: [] });
58
+ expect(typeof stepListOut).toBe("string");
59
+ expect(stepListOut).not.toContain("undefined");
60
+ });
61
+ });
62
+ describe("formatOutput with text format and commandPath", () => {
63
+ test("uses registered renderer when commandPath is provided", () => {
64
+ const data = {
65
+ threadId: "01HXYZ",
66
+ workflowHash: "ABC123",
67
+ };
68
+ const out = formatOutput(data, "text", "thread start");
69
+ expect(typeof out).toBe("string");
70
+ expect(out).not.toContain("undefined");
71
+ // thread-start renderer should mention the threadId
72
+ expect(out).toContain("01HXYZ");
73
+ });
74
+ test("falls back to JSON when commandPath has no registered renderer", () => {
75
+ const data = { foo: "bar" };
76
+ const out = formatOutput(data, "text", "unknown command");
77
+ expect(typeof out).toBe("string");
78
+ expect(out).not.toContain("undefined");
79
+ // Should be JSON
80
+ expect(() => JSON.parse(out)).not.toThrow();
81
+ });
82
+ test("renderer is NOT invoked when format is 'json'", () => {
83
+ const data = {
84
+ threadId: "01HXYZ",
85
+ workflowHash: "ABC123",
86
+ };
87
+ const out = formatOutput(data, "json", "thread start");
88
+ expect(typeof out).toBe("string");
89
+ // JSON output is parseable
90
+ const parsed = JSON.parse(out);
91
+ expect(parsed).toEqual(data);
92
+ });
93
+ test("renderer is NOT invoked when format is 'yaml'", () => {
94
+ const data = {
95
+ threadId: "01HXYZ",
96
+ workflowHash: "ABC123",
97
+ };
98
+ const out = formatOutput(data, "yaml", "thread start");
99
+ expect(typeof out).toBe("string");
100
+ expect(out).toContain("threadId:");
101
+ expect(out).toContain("workflowHash:");
102
+ });
103
+ });
104
+ describe("Renderers handle partial/missing data without throwing", () => {
105
+ test("thread list handles items with null currentRole", () => {
106
+ const data = {
107
+ items: [
108
+ {
109
+ threadId: "01HXYZ",
110
+ workflowHash: "ABC123",
111
+ workflowName: null,
112
+ status: "idle",
113
+ currentRole: null,
114
+ startedAt: null,
115
+ completedAt: null,
116
+ },
117
+ ],
118
+ };
119
+ const out = TEXT_RENDERERS["thread list"]?.(data);
120
+ expect(typeof out).toBe("string");
121
+ expect(out).not.toContain("undefined");
122
+ expect(out).not.toContain("null");
123
+ });
124
+ test("thread show handles missing optional fields", () => {
125
+ const data = {
126
+ threadId: "01HXYZ",
127
+ workflowHash: "ABC123",
128
+ head: null,
129
+ status: "idle",
130
+ currentRole: null,
131
+ suspendedRole: null,
132
+ suspendMessage: null,
133
+ done: false,
134
+ };
135
+ const out = TEXT_RENDERERS["thread show"]?.(data);
136
+ expect(typeof out).toBe("string");
137
+ expect(out).not.toContain("undefined");
138
+ });
139
+ test("step list handles items with null durationMs", () => {
140
+ const data = {
141
+ threadId: "01HXYZ",
142
+ items: [{ hash: "STEP1", role: "planner", durationMs: null }],
143
+ };
144
+ const out = TEXT_RENDERERS["step list"]?.(data);
145
+ expect(typeof out).toBe("string");
146
+ expect(out).not.toContain("undefined");
147
+ });
148
+ });
149
+ describe("registerTextRenderer", () => {
150
+ test("allows registering a custom renderer", () => {
151
+ registerTextRenderer("test command", (data) => `custom: ${JSON.stringify(data)}`);
152
+ const out = formatOutput({ foo: "bar" }, "text", "test command");
153
+ expect(out).toContain("custom:");
154
+ expect(out).toContain("foo");
155
+ expect(out).toContain("bar");
156
+ });
157
+ });
158
+ //# sourceMappingURL=format-text-registry.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"format-text-registry.test.js","sourceRoot":"","sources":["../../src/__tests__/format-text-registry.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAC;AAChD,OAAO,EAAE,YAAY,EAAE,eAAe,EAAE,oBAAoB,EAAE,cAAc,EAAE,MAAM,cAAc,CAAC;AAEnG,QAAQ,CAAC,mCAAmC,EAAE,GAAG,EAAE;IACjD,IAAI,CAAC,6DAA6D,EAAE,GAAG,EAAE;QACvE,MAAM,GAAG,GAAG,YAAY,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,EAAE,MAAM,CAAC,CAAC;QAChD,MAAM,CAAC,OAAO,GAAG,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAClC,MAAM,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC;IACzC,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,sEAAsE,EAAE,GAAG,EAAE;QAChF,MAAM,IAAI,GAAG,EAAE,GAAG,EAAE,KAAK,EAAE,CAAC;QAC5B,MAAM,GAAG,GAAG,YAAY,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;QACvC,MAAM,CAAC,OAAO,GAAG,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAClC,wCAAwC;QACxC,MAAM,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;IAC9C,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,0DAA0D,EAAE,GAAG,EAAE;QACpE,MAAM,IAAI,GAAG,EAAE,GAAG,EAAE,KAAK,EAAE,CAAC;QAC5B,MAAM,CAAC,OAAO,YAAY,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACzD,MAAM,CAAC,OAAO,YAAY,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACzD,MAAM,CAAC,OAAO,YAAY,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IAC3D,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,QAAQ,CAAC,yBAAyB,EAAE,GAAG,EAAE;IACvC,IAAI,CAAC,gDAAgD,EAAE,GAAG,EAAE;QAC1D,MAAM,CAAC,cAAc,CAAC,CAAC,WAAW,EAAE,CAAC;QACrC,MAAM,CAAC,OAAO,cAAc,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC7C,KAAK,MAAM,CAAC,GAAG,EAAE,EAAE,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,cAAc,CAAC,EAAE,CAAC;YACvD,MAAM,CAAC,OAAO,GAAG,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YAClC,MAAM,CAAC,OAAO,EAAE,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACrC,CAAC;IACH,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,8CAA8C,EAAE,GAAG,EAAE;QACxD,MAAM,gBAAgB,GAAG;YACvB,aAAa;YACb,aAAa;YACb,cAAc;YACd,eAAe;YACf,eAAe;YACf,WAAW;YACX,WAAW;SACZ,CAAC;QACF,KAAK,MAAM,GAAG,IAAI,gBAAgB,EAAE,CAAC;YACnC,MAAM,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC;YAC3C,MAAM,CAAC,OAAO,eAAe,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACvD,CAAC;IACH,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,8DAA8D,EAAE,GAAG,EAAE;QACxE,+BAA+B;QAC/B,MAAM,aAAa,GAAG,cAAc,CAAC,aAAa,CAAC,EAAE,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,CAAC;QACrE,MAAM,CAAC,OAAO,aAAa,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC5C,MAAM,CAAC,aAAa,CAAC,CAAC,GAAG,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC;QAEjD,iCAAiC;QACjC,MAAM,eAAe,GAAG,cAAc,CAAC,eAAe,CAAC,EAAE,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,CAAC;QACzE,MAAM,CAAC,OAAO,eAAe,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC9C,MAAM,CAAC,eAAe,CAAC,CAAC,GAAG,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC;QAEnD,YAAY;QACZ,MAAM,WAAW,GAAG,cAAc,CAAC,WAAW,CAAC,EAAE,CAAC,EAAE,QAAQ,EAAE,GAAG,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,CAAC;QAChF,MAAM,CAAC,OAAO,WAAW,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC1C,MAAM,CAAC,WAAW,CAAC,CAAC,GAAG,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC;IACjD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,QAAQ,CAAC,+CAA+C,EAAE,GAAG,EAAE;IAC7D,IAAI,CAAC,uDAAuD,EAAE,GAAG,EAAE;QACjE,MAAM,IAAI,GAAG;YACX,QAAQ,EAAE,QAAQ;YAClB,YAAY,EAAE,QAAQ;SACvB,CAAC;QACF,MAAM,GAAG,GAAG,YAAY,CAAC,IAAI,EAAE,MAAM,EAAE,cAAc,CAAC,CAAC;QACvD,MAAM,CAAC,OAAO,GAAG,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAClC,MAAM,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC;QACvC,oDAAoD;QACpD,MAAM,CAAC,GAAG,CAAC,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;IAClC,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,gEAAgE,EAAE,GAAG,EAAE;QAC1E,MAAM,IAAI,GAAG,EAAE,GAAG,EAAE,KAAK,EAAE,CAAC;QAC5B,MAAM,GAAG,GAAG,YAAY,CAAC,IAAI,EAAE,MAAM,EAAE,iBAAiB,CAAC,CAAC;QAC1D,MAAM,CAAC,OAAO,GAAG,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAClC,MAAM,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC;QACvC,iBAAiB;QACjB,MAAM,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;IAC9C,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,+CAA+C,EAAE,GAAG,EAAE;QACzD,MAAM,IAAI,GAAG;YACX,QAAQ,EAAE,QAAQ;YAClB,YAAY,EAAE,QAAQ;SACvB,CAAC;QACF,MAAM,GAAG,GAAG,YAAY,CAAC,IAAI,EAAE,MAAM,EAAE,cAAc,CAAC,CAAC;QACvD,MAAM,CAAC,OAAO,GAAG,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAClC,2BAA2B;QAC3B,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QAC/B,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IAC/B,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,+CAA+C,EAAE,GAAG,EAAE;QACzD,MAAM,IAAI,GAAG;YACX,QAAQ,EAAE,QAAQ;YAClB,YAAY,EAAE,QAAQ;SACvB,CAAC;QACF,MAAM,GAAG,GAAG,YAAY,CAAC,IAAI,EAAE,MAAM,EAAE,cAAc,CAAC,CAAC;QACvD,MAAM,CAAC,OAAO,GAAG,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAClC,MAAM,CAAC,GAAG,CAAC,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC;QACnC,MAAM,CAAC,GAAG,CAAC,CAAC,SAAS,CAAC,eAAe,CAAC,CAAC;IACzC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,QAAQ,CAAC,wDAAwD,EAAE,GAAG,EAAE;IACtE,IAAI,CAAC,iDAAiD,EAAE,GAAG,EAAE;QAC3D,MAAM,IAAI,GAAG;YACX,KAAK,EAAE;gBACL;oBACE,QAAQ,EAAE,QAAQ;oBAClB,YAAY,EAAE,QAAQ;oBACtB,YAAY,EAAE,IAAI;oBAClB,MAAM,EAAE,MAAM;oBACd,WAAW,EAAE,IAAI;oBACjB,SAAS,EAAE,IAAI;oBACf,WAAW,EAAE,IAAI;iBAClB;aACF;SACF,CAAC;QACF,MAAM,GAAG,GAAG,cAAc,CAAC,aAAa,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC;QAClD,MAAM,CAAC,OAAO,GAAG,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAClC,MAAM,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC;QACvC,MAAM,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;IACpC,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,6CAA6C,EAAE,GAAG,EAAE;QACvD,MAAM,IAAI,GAAG;YACX,QAAQ,EAAE,QAAQ;YAClB,YAAY,EAAE,QAAQ;YACtB,IAAI,EAAE,IAAI;YACV,MAAM,EAAE,MAAM;YACd,WAAW,EAAE,IAAI;YACjB,aAAa,EAAE,IAAI;YACnB,cAAc,EAAE,IAAI;YACpB,IAAI,EAAE,KAAK;SACZ,CAAC;QACF,MAAM,GAAG,GAAG,cAAc,CAAC,aAAa,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC;QAClD,MAAM,CAAC,OAAO,GAAG,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAClC,MAAM,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC;IACzC,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,8CAA8C,EAAE,GAAG,EAAE;QACxD,MAAM,IAAI,GAAG;YACX,QAAQ,EAAE,QAAQ;YAClB,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,UAAU,EAAE,IAAI,EAAE,CAAC;SAC9D,CAAC;QACF,MAAM,GAAG,GAAG,cAAc,CAAC,WAAW,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC;QAChD,MAAM,CAAC,OAAO,GAAG,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAClC,MAAM,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC;IACzC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,QAAQ,CAAC,sBAAsB,EAAE,GAAG,EAAE;IACpC,IAAI,CAAC,sCAAsC,EAAE,GAAG,EAAE;QAChD,oBAAoB,CAAC,cAAc,EAAE,CAAC,IAAI,EAAE,EAAE,CAAC,WAAW,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QAClF,MAAM,GAAG,GAAG,YAAY,CAAC,EAAE,GAAG,EAAE,KAAK,EAAE,EAAE,MAAM,EAAE,cAAc,CAAC,CAAC;QACjE,MAAM,CAAC,GAAG,CAAC,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;QACjC,MAAM,CAAC,GAAG,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;QAC7B,MAAM,CAAC,GAAG,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;IAC/B,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=log-text-renderer.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"log-text-renderer.test.d.ts","sourceRoot":"","sources":["../../src/__tests__/log-text-renderer.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,265 @@
1
+ import { describe, expect, test } from "vitest";
2
+ import { formatOutput, getTextRenderer, TEXT_RENDERERS } from "../format.js";
3
+ import { renderLogList, renderLogShow } from "../text-renderers.js";
4
+ describe("log list — text renderer registration", () => {
5
+ test("TEXT_RENDERERS contains 'log list'", () => {
6
+ expect(getTextRenderer("log list")).toBeDefined();
7
+ expect(typeof getTextRenderer("log list")).toBe("function");
8
+ });
9
+ test("TEXT_RENDERERS['log list'] is the same reference as renderLogList", () => {
10
+ expect(TEXT_RENDERERS["log list"]).toBe(renderLogList);
11
+ });
12
+ test("renderLogList is exported from text-renderers.ts", () => {
13
+ expect(typeof renderLogList).toBe("function");
14
+ });
15
+ });
16
+ describe("log show — text renderer registration", () => {
17
+ test("TEXT_RENDERERS contains 'log show'", () => {
18
+ expect(getTextRenderer("log show")).toBeDefined();
19
+ expect(typeof getTextRenderer("log show")).toBe("function");
20
+ });
21
+ test("TEXT_RENDERERS['log show'] is the same reference as renderLogShow", () => {
22
+ expect(TEXT_RENDERERS["log show"]).toBe(renderLogShow);
23
+ });
24
+ test("renderLogShow is exported from text-renderers.ts", () => {
25
+ expect(typeof renderLogShow).toBe("function");
26
+ });
27
+ });
28
+ describe("renderLogList — output shape", () => {
29
+ test("returns a string for full payload", () => {
30
+ const out = renderLogList([
31
+ { name: "2026-06-10.jsonl", size: 4096, date: "2026-06-10" },
32
+ { name: "2026-06-11.jsonl", size: 8192, date: "2026-06-11" },
33
+ ]);
34
+ expect(typeof out).toBe("string");
35
+ });
36
+ test("includes file names, dates, and sizes for each row", () => {
37
+ const out = renderLogList([
38
+ { name: "2026-06-10.jsonl", size: 4096, date: "2026-06-10" },
39
+ { name: "2026-06-11.jsonl", size: 8192, date: "2026-06-11" },
40
+ ]);
41
+ expect(out).toContain("2026-06-10.jsonl");
42
+ expect(out).toContain("2026-06-10");
43
+ expect(out).toContain("2026-06-11.jsonl");
44
+ expect(out).toContain("2026-06-11");
45
+ });
46
+ test("includes a header line", () => {
47
+ const out = renderLogList([{ name: "2026-06-10.jsonl", size: 4096, date: "2026-06-10" }]);
48
+ const lines = out.split("\n");
49
+ expect(lines.length).toBeGreaterThanOrEqual(2);
50
+ // header should mention NAME or DATE or SIZE
51
+ const header = lines[0]?.toUpperCase() ?? "";
52
+ const hasHeader = header.includes("NAME") || header.includes("DATE") || header.includes("SIZE");
53
+ expect(hasHeader).toBe(true);
54
+ });
55
+ test("does NOT begin with '{' or '[' (not raw JSON)", () => {
56
+ const out = renderLogList([{ name: "2026-06-10.jsonl", size: 4096, date: "2026-06-10" }]);
57
+ const trimmed = out.trimStart();
58
+ expect(trimmed.startsWith("{")).toBe(false);
59
+ expect(trimmed.startsWith("[")).toBe(false);
60
+ });
61
+ test("does NOT contain literal 'undefined'", () => {
62
+ const out = renderLogList([{ name: "2026-06-10.jsonl", size: 4096, date: "2026-06-10" }]);
63
+ expect(out).not.toContain("undefined");
64
+ });
65
+ test("empty array — returns string, no 'undefined'", () => {
66
+ const out = renderLogList([]);
67
+ expect(typeof out).toBe("string");
68
+ expect(out).not.toContain("undefined");
69
+ });
70
+ test("null payload — returns string, does not throw", () => {
71
+ expect(() => renderLogList(null)).not.toThrow();
72
+ const out = renderLogList(null);
73
+ expect(typeof out).toBe("string");
74
+ expect(out).not.toContain("undefined");
75
+ });
76
+ test("non-array payload — returns string, does not throw", () => {
77
+ expect(() => renderLogList({ name: "x" })).not.toThrow();
78
+ const out = renderLogList({ name: "x" });
79
+ expect(typeof out).toBe("string");
80
+ expect(out).not.toContain("undefined");
81
+ });
82
+ test("partial item (missing size) — returns string, no 'undefined'", () => {
83
+ const out = renderLogList([{ name: "2026-06-10.jsonl", date: "2026-06-10" }]);
84
+ expect(typeof out).toBe("string");
85
+ expect(out).not.toContain("undefined");
86
+ });
87
+ });
88
+ describe("renderLogShow — output shape", () => {
89
+ test("returns a string for full payload", () => {
90
+ const out = renderLogShow([
91
+ {
92
+ ts: "2026-06-12T10:00:00.000Z",
93
+ pid: "12345",
94
+ tag: "4KNMR2PX",
95
+ msg: "Loading workflow...",
96
+ thread: "01JTEST000000000000THREAD1",
97
+ workflow: "WF1234567890A",
98
+ },
99
+ ]);
100
+ expect(typeof out).toBe("string");
101
+ });
102
+ test("includes ts, pid, tag, and msg for each entry", () => {
103
+ const out = renderLogShow([
104
+ {
105
+ ts: "2026-06-12T10:00:00.000Z",
106
+ pid: "12345",
107
+ tag: "4KNMR2PX",
108
+ msg: "Loading workflow...",
109
+ thread: null,
110
+ workflow: null,
111
+ },
112
+ ]);
113
+ expect(out).toContain("2026-06-12T10:00:00.000Z");
114
+ expect(out).toContain("12345");
115
+ expect(out).toContain("4KNMR2PX");
116
+ expect(out).toContain("Loading workflow...");
117
+ });
118
+ test("includes thread id when present", () => {
119
+ const out = renderLogShow([
120
+ {
121
+ ts: "2026-06-12T10:00:00.000Z",
122
+ pid: "12345",
123
+ tag: "4KNMR2PX",
124
+ msg: "Loading workflow...",
125
+ thread: "01JTEST000000000000THREAD1",
126
+ workflow: null,
127
+ },
128
+ ]);
129
+ expect(out).toContain("01JTEST000000000000THREAD1");
130
+ });
131
+ test("does NOT begin with '{' or '[' (not raw JSON)", () => {
132
+ const out = renderLogShow([
133
+ {
134
+ ts: "2026-06-12T10:00:00.000Z",
135
+ pid: "12345",
136
+ tag: "4KNMR2PX",
137
+ msg: "Loading workflow...",
138
+ thread: null,
139
+ workflow: null,
140
+ },
141
+ ]);
142
+ const trimmed = out.trimStart();
143
+ expect(trimmed.startsWith("{")).toBe(false);
144
+ expect(trimmed.startsWith("[")).toBe(false);
145
+ });
146
+ test("does NOT contain literal 'undefined'", () => {
147
+ const out = renderLogShow([
148
+ {
149
+ ts: "2026-06-12T10:00:00.000Z",
150
+ pid: "12345",
151
+ tag: "4KNMR2PX",
152
+ msg: "Loading workflow...",
153
+ thread: null,
154
+ workflow: null,
155
+ },
156
+ ]);
157
+ expect(out).not.toContain("undefined");
158
+ });
159
+ test("empty array — returns string, no 'undefined'", () => {
160
+ const out = renderLogShow([]);
161
+ expect(typeof out).toBe("string");
162
+ expect(out).not.toContain("undefined");
163
+ });
164
+ test("null payload — returns string, does not throw", () => {
165
+ expect(() => renderLogShow(null)).not.toThrow();
166
+ const out = renderLogShow(null);
167
+ expect(typeof out).toBe("string");
168
+ expect(out).not.toContain("undefined");
169
+ });
170
+ test("non-array payload — returns string, does not throw", () => {
171
+ expect(() => renderLogShow({ ts: "x" })).not.toThrow();
172
+ const out = renderLogShow({ ts: "x" });
173
+ expect(typeof out).toBe("string");
174
+ expect(out).not.toContain("undefined");
175
+ });
176
+ test("partial entry (missing thread) — returns string, no 'undefined'", () => {
177
+ const out = renderLogShow([
178
+ {
179
+ ts: "2026-06-12T10:00:00.000Z",
180
+ pid: "12345",
181
+ tag: "4KNMR2PX",
182
+ msg: "hello",
183
+ },
184
+ ]);
185
+ expect(typeof out).toBe("string");
186
+ expect(out).not.toContain("undefined");
187
+ });
188
+ });
189
+ describe("formatOutput integration — log list", () => {
190
+ test("formatOutput(data, 'text', 'log list') uses renderer", () => {
191
+ const data = [{ name: "2026-06-10.jsonl", size: 4096, date: "2026-06-10" }];
192
+ const out = formatOutput(data, "text", "log list");
193
+ expect(typeof out).toBe("string");
194
+ expect(out).not.toContain("undefined");
195
+ expect(out.trimStart().startsWith("{")).toBe(false);
196
+ expect(out.trimStart().startsWith("[")).toBe(false);
197
+ expect(out).toContain("2026-06-10.jsonl");
198
+ });
199
+ test("formatOutput(data, 'json', 'log list') still emits parseable JSON", () => {
200
+ const data = [{ name: "2026-06-10.jsonl", size: 4096, date: "2026-06-10" }];
201
+ const out = formatOutput(data, "json", "log list");
202
+ const parsed = JSON.parse(out);
203
+ expect(parsed).toEqual(data);
204
+ });
205
+ test("formatOutput(data, 'yaml', 'log list') still emits YAML", () => {
206
+ const data = [{ name: "2026-06-10.jsonl", size: 4096, date: "2026-06-10" }];
207
+ const out = formatOutput(data, "yaml", "log list");
208
+ expect(typeof out).toBe("string");
209
+ expect(out).toContain("name:");
210
+ expect(out).toContain("2026-06-10.jsonl");
211
+ });
212
+ });
213
+ describe("formatOutput integration — log show", () => {
214
+ test("formatOutput(data, 'text', 'log show') uses renderer", () => {
215
+ const data = [
216
+ {
217
+ ts: "2026-06-12T10:00:00.000Z",
218
+ pid: "12345",
219
+ tag: "4KNMR2PX",
220
+ msg: "hello",
221
+ thread: null,
222
+ workflow: null,
223
+ },
224
+ ];
225
+ const out = formatOutput(data, "text", "log show");
226
+ expect(typeof out).toBe("string");
227
+ expect(out).not.toContain("undefined");
228
+ expect(out.trimStart().startsWith("{")).toBe(false);
229
+ expect(out.trimStart().startsWith("[")).toBe(false);
230
+ expect(out).toContain("4KNMR2PX");
231
+ expect(out).toContain("hello");
232
+ });
233
+ test("formatOutput(data, 'json', 'log show') still emits parseable JSON", () => {
234
+ const data = [
235
+ {
236
+ ts: "2026-06-12T10:00:00.000Z",
237
+ pid: "12345",
238
+ tag: "4KNMR2PX",
239
+ msg: "hello",
240
+ thread: null,
241
+ workflow: null,
242
+ },
243
+ ];
244
+ const out = formatOutput(data, "json", "log show");
245
+ const parsed = JSON.parse(out);
246
+ expect(parsed).toEqual(data);
247
+ });
248
+ test("formatOutput(data, 'yaml', 'log show') still emits YAML", () => {
249
+ const data = [
250
+ {
251
+ ts: "2026-06-12T10:00:00.000Z",
252
+ pid: "12345",
253
+ tag: "4KNMR2PX",
254
+ msg: "hello",
255
+ thread: null,
256
+ workflow: null,
257
+ },
258
+ ];
259
+ const out = formatOutput(data, "yaml", "log show");
260
+ expect(typeof out).toBe("string");
261
+ expect(out).toContain("ts:");
262
+ expect(out).toContain("pid:");
263
+ });
264
+ });
265
+ //# sourceMappingURL=log-text-renderer.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"log-text-renderer.test.js","sourceRoot":"","sources":["../../src/__tests__/log-text-renderer.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=output-mapper-thread-list-startedat.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"output-mapper-thread-list-startedat.test.d.ts","sourceRoot":"","sources":["../../src/__tests__/output-mapper-thread-list-startedat.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,102 @@
1
+ import { readFile } from "node:fs/promises";
2
+ import { fileURLToPath } from "node:url";
3
+ import { generateUlid } from "@united-workforce/util";
4
+ import { describe, expect, test } from "vitest";
5
+ import { toThreadListPayload } from "../output-mappers.js";
6
+ const OUTPUT_MAPPERS_PATH = fileURLToPath(new URL("../output-mappers.ts", import.meta.url));
7
+ function makeItem(threadId) {
8
+ return {
9
+ thread: threadId,
10
+ workflow: "WORKFLOWHASH1",
11
+ head: "HEADHASH00001",
12
+ status: "idle",
13
+ currentRole: null,
14
+ statusDisplay: "idle",
15
+ workflowName: "test-workflow",
16
+ };
17
+ }
18
+ describe("toThreadListPayload — issue #343 (ULID timestamp decoded with padding stripped)", () => {
19
+ test("startedAt equals the millisecond timestamp originally passed to generateUlid", () => {
20
+ const ts = 1781219097830; // 2026-06-11T23:04:57.830Z
21
+ const ulid = generateUlid(ts);
22
+ const payload = toThreadListPayload([makeItem(ulid)]);
23
+ expect(payload.items).toHaveLength(1);
24
+ expect(payload.items[0].startedAt).toBe(ts);
25
+ });
26
+ test("startedAt is NOT the raw 50-bit value (i.e. NOT timestamp << 2)", () => {
27
+ const ts = 1781219097830;
28
+ const ulid = generateUlid(ts);
29
+ const payload = toThreadListPayload([makeItem(ulid)]);
30
+ // The buggy decoder produced ts * 4 = 7124876391323, pushing year to 2195.
31
+ expect(payload.items[0].startedAt).not.toBe(ts * 4);
32
+ expect(payload.items[0].startedAt).not.toBe(7124876391323);
33
+ });
34
+ test("startedAt decodes to year 2026 for the issue-reported ULID timestamp", () => {
35
+ const ts = 1781219097830;
36
+ const ulid = generateUlid(ts);
37
+ const payload = toThreadListPayload([makeItem(ulid)]);
38
+ const startedAt = payload.items[0].startedAt;
39
+ expect(startedAt).not.toBeNull();
40
+ if (startedAt === null)
41
+ return;
42
+ const isoDate = new Date(startedAt).toISOString().slice(0, 10);
43
+ expect(isoDate).toBe("2026-06-11");
44
+ });
45
+ test("round-trips correctly across several timestamps", () => {
46
+ const timestamps = [
47
+ 0,
48
+ Date.UTC(2020, 0, 1, 0, 0, 0),
49
+ Date.UTC(2023, 5, 15, 12, 30, 45),
50
+ Date.UTC(2026, 4, 20, 0, 0, 0),
51
+ Date.UTC(2030, 11, 31, 23, 59, 59),
52
+ ];
53
+ const items = timestamps.map((t) => makeItem(generateUlid(t)));
54
+ const payload = toThreadListPayload(items);
55
+ for (let i = 0; i < timestamps.length; i++) {
56
+ expect(payload.items[i].startedAt).toBe(timestamps[i]);
57
+ }
58
+ });
59
+ test("startedAt is null for thread ids that are not valid 26-char Crockford Base32 ULIDs", () => {
60
+ const cases = ["", "TOOSHORT", "TOOLONGAAAAAAAAAAAAAAAAAA", "INVALID!@#$%^&CHARACTERS"];
61
+ const items = cases.map((id) => makeItem(id));
62
+ const payload = toThreadListPayload(items);
63
+ for (const item of payload.items) {
64
+ expect(item.startedAt).toBeNull();
65
+ }
66
+ });
67
+ test("preserves other thread-list item fields verbatim", () => {
68
+ const ts = 1781219097830;
69
+ const ulid = generateUlid(ts);
70
+ const item = {
71
+ thread: ulid,
72
+ workflow: "WORKFLOWHASH9",
73
+ head: "HEADHASH99999",
74
+ status: "running",
75
+ currentRole: "developer",
76
+ statusDisplay: "running",
77
+ workflowName: "solve-issue",
78
+ };
79
+ const payload = toThreadListPayload([item]);
80
+ expect(payload.items[0]).toEqual({
81
+ threadId: ulid,
82
+ workflowHash: "WORKFLOWHASH9",
83
+ workflowName: "solve-issue",
84
+ status: "running",
85
+ currentRole: "developer",
86
+ startedAt: ts,
87
+ completedAt: null,
88
+ });
89
+ });
90
+ });
91
+ describe("output-mappers.ts source — issue #343 refactor", () => {
92
+ test("does NOT contain a local extractUlidTime function (removed in favor of util)", async () => {
93
+ const source = await readFile(OUTPUT_MAPPERS_PATH, "utf8");
94
+ expect(source).not.toMatch(/function\s+extractUlidTime\b/);
95
+ });
96
+ test("imports extractUlidTimestamp from @united-workforce/util", async () => {
97
+ const source = await readFile(OUTPUT_MAPPERS_PATH, "utf8");
98
+ expect(source).toMatch(/extractUlidTimestamp/);
99
+ expect(source).toMatch(/@united-workforce\/util/);
100
+ });
101
+ });
102
+ //# sourceMappingURL=output-mapper-thread-list-startedat.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"output-mapper-thread-list-startedat.test.js","sourceRoot":"","sources":["../../src/__tests__/output-mapper-thread-list-startedat.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=output-mapper-workflow-add.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"output-mapper-workflow-add.test.d.ts","sourceRoot":"","sources":["../../src/__tests__/output-mapper-workflow-add.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,22 @@
1
+ import { describe, expect, test } from "vitest";
2
+ import { toWorkflowAddPayload } from "../output-mappers.js";
3
+ describe("toWorkflowAddPayload — issue #334", () => {
4
+ test("maps WorkflowAddOutput { name, hash } to plain payload shape", () => {
5
+ const out = toWorkflowAddPayload({ name: "review-pr", hash: "2TBP6T37TZAJZ" });
6
+ expect(out).toEqual({ name: "review-pr", hash: "2TBP6T37TZAJZ" });
7
+ });
8
+ test("returns a WorkflowAddPayload type with exactly two fields", () => {
9
+ const out = toWorkflowAddPayload({
10
+ name: "solve-issue",
11
+ hash: "76C98RVXA5E4F",
12
+ });
13
+ expect(Object.keys(out).sort()).toEqual(["hash", "name"]);
14
+ });
15
+ test("performs no I/O — pure data mapping", () => {
16
+ // Repeated calls produce equal results
17
+ const a = toWorkflowAddPayload({ name: "a", hash: "AAA1234567890" });
18
+ const b = toWorkflowAddPayload({ name: "a", hash: "AAA1234567890" });
19
+ expect(a).toEqual(b);
20
+ });
21
+ });
22
+ //# sourceMappingURL=output-mapper-workflow-add.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"output-mapper-workflow-add.test.js","sourceRoot":"","sources":["../../src/__tests__/output-mapper-workflow-add.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAC;AAChD,OAAO,EAAE,oBAAoB,EAA2B,MAAM,sBAAsB,CAAC;AAErF,QAAQ,CAAC,mCAAmC,EAAE,GAAG,EAAE;IACjD,IAAI,CAAC,8DAA8D,EAAE,GAAG,EAAE;QACxE,MAAM,GAAG,GAAG,oBAAoB,CAAC,EAAE,IAAI,EAAE,WAAW,EAAE,IAAI,EAAE,eAAe,EAAE,CAAC,CAAC;QAC/E,MAAM,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,EAAE,IAAI,EAAE,WAAW,EAAE,IAAI,EAAE,eAAe,EAAE,CAAC,CAAC;IACpE,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,2DAA2D,EAAE,GAAG,EAAE;QACrE,MAAM,GAAG,GAAuB,oBAAoB,CAAC;YACnD,IAAI,EAAE,aAAa;YACnB,IAAI,EAAE,eAAe;SACtB,CAAC,CAAC;QACH,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,CAAC;IAC5D,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,qCAAqC,EAAE,GAAG,EAAE;QAC/C,uCAAuC;QACvC,MAAM,CAAC,GAAG,oBAAoB,CAAC,EAAE,IAAI,EAAE,GAAG,EAAE,IAAI,EAAE,eAAe,EAAE,CAAC,CAAC;QACrE,MAAM,CAAC,GAAG,oBAAoB,CAAC,EAAE,IAAI,EAAE,GAAG,EAAE,IAAI,EAAE,eAAe,EAAE,CAAC,CAAC;QACrE,MAAM,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;IACvB,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}