task-o-matic 0.0.14 → 0.0.16

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 (125) hide show
  1. package/dist/cli/display/progress.d.ts +15 -2
  2. package/dist/cli/display/progress.d.ts.map +1 -1
  3. package/dist/cli/display/progress.js +72 -4
  4. package/dist/commands/benchmark.d.ts.map +1 -1
  5. package/dist/commands/benchmark.js +11 -3
  6. package/dist/commands/init.d.ts.map +1 -1
  7. package/dist/commands/init.js +19 -4
  8. package/dist/commands/prd.js +7 -1
  9. package/dist/commands/tasks/delete.d.ts.map +1 -1
  10. package/dist/commands/tasks/delete.js +2 -1
  11. package/dist/commands/tasks/document/add.d.ts.map +1 -1
  12. package/dist/commands/tasks/document/add.js +2 -1
  13. package/dist/commands/tasks/document/get.d.ts.map +1 -1
  14. package/dist/commands/tasks/document/get.js +2 -1
  15. package/dist/commands/tasks/plan/set.d.ts.map +1 -1
  16. package/dist/commands/tasks/plan/set.js +11 -3
  17. package/dist/commands/tasks/show.d.ts.map +1 -1
  18. package/dist/commands/tasks/show.js +2 -1
  19. package/dist/commands/tasks/status.d.ts.map +1 -1
  20. package/dist/commands/tasks/status.js +2 -1
  21. package/dist/commands/tasks/update.d.ts.map +1 -1
  22. package/dist/commands/tasks/update.js +7 -1
  23. package/dist/commands/workflow.d.ts.map +1 -1
  24. package/dist/commands/workflow.js +15 -2
  25. package/dist/lib/ai-service/base-operations.d.ts +8 -0
  26. package/dist/lib/ai-service/base-operations.d.ts.map +1 -1
  27. package/dist/lib/ai-service/base-operations.js +23 -10
  28. package/dist/lib/ai-service/model-provider.d.ts.map +1 -1
  29. package/dist/lib/ai-service/model-provider.js +37 -6
  30. package/dist/lib/ai-service/prd-operations.d.ts.map +1 -1
  31. package/dist/lib/ai-service/prd-operations.js +50 -7
  32. package/dist/lib/ai-service/task-operations.d.ts +1 -0
  33. package/dist/lib/ai-service/task-operations.d.ts.map +1 -1
  34. package/dist/lib/ai-service/task-operations.js +158 -171
  35. package/dist/lib/benchmark/registry.d.ts.map +1 -1
  36. package/dist/lib/benchmark/registry.js +6 -10
  37. package/dist/lib/config-validation.d.ts +215 -0
  38. package/dist/lib/config-validation.d.ts.map +1 -0
  39. package/dist/lib/config-validation.js +246 -0
  40. package/dist/lib/config.d.ts.map +1 -1
  41. package/dist/lib/config.js +30 -7
  42. package/dist/lib/index.d.ts +1 -1
  43. package/dist/lib/index.d.ts.map +1 -1
  44. package/dist/lib/index.js +2 -1
  45. package/dist/lib/storage/file-system.d.ts.map +1 -1
  46. package/dist/lib/storage/file-system.js +81 -21
  47. package/dist/lib/task-execution-core.d.ts.map +1 -1
  48. package/dist/lib/task-execution-core.js +3 -2
  49. package/dist/services/prd.d.ts +17 -0
  50. package/dist/services/prd.d.ts.map +1 -1
  51. package/dist/services/prd.js +69 -84
  52. package/dist/services/tasks.d.ts +315 -1
  53. package/dist/services/tasks.d.ts.map +1 -1
  54. package/dist/services/tasks.js +486 -121
  55. package/dist/services/workflow-ai-assistant.d.ts.map +1 -1
  56. package/dist/services/workflow-ai-assistant.js +19 -6
  57. package/dist/services/workflow.d.ts.map +1 -1
  58. package/dist/services/workflow.js +7 -1
  59. package/dist/test/lib/ai-service/task-operations.test.d.ts +2 -0
  60. package/dist/test/lib/ai-service/task-operations.test.d.ts.map +1 -0
  61. package/dist/test/lib/ai-service/task-operations.test.js +362 -0
  62. package/dist/test/mocks/mock-ai-operations.d.ts +15 -0
  63. package/dist/test/mocks/mock-ai-operations.d.ts.map +1 -0
  64. package/dist/test/mocks/mock-ai-operations.js +107 -0
  65. package/dist/test/mocks/mock-context-builder.d.ts +10 -0
  66. package/dist/test/mocks/mock-context-builder.d.ts.map +1 -0
  67. package/dist/test/mocks/mock-context-builder.js +81 -0
  68. package/dist/test/mocks/mock-model-provider.d.ts +7 -0
  69. package/dist/test/mocks/mock-model-provider.d.ts.map +1 -0
  70. package/dist/test/mocks/mock-model-provider.js +21 -0
  71. package/dist/test/mocks/mock-service-factory.d.ts +11 -0
  72. package/dist/test/mocks/mock-service-factory.d.ts.map +1 -0
  73. package/dist/test/mocks/mock-service-factory.js +61 -0
  74. package/dist/test/mocks/mock-storage.d.ts +50 -0
  75. package/dist/test/mocks/mock-storage.d.ts.map +1 -0
  76. package/dist/test/mocks/mock-storage.js +145 -0
  77. package/dist/test/services/task-service.test.d.ts +2 -0
  78. package/dist/test/services/task-service.test.d.ts.map +1 -0
  79. package/dist/test/services/task-service.test.js +459 -0
  80. package/dist/test/test-mock-setup.d.ts +26 -0
  81. package/dist/test/test-mock-setup.d.ts.map +1 -0
  82. package/dist/test/test-mock-setup.js +41 -0
  83. package/dist/test/test-setup.d.ts +9 -0
  84. package/dist/test/test-setup.d.ts.map +1 -0
  85. package/dist/test/test-setup.js +44 -0
  86. package/dist/test/test-utils.d.ts +22 -0
  87. package/dist/test/test-utils.d.ts.map +1 -0
  88. package/dist/test/test-utils.js +37 -0
  89. package/dist/test/utils/ai-operation-utility.test.d.ts +2 -0
  90. package/dist/test/utils/ai-operation-utility.test.d.ts.map +1 -0
  91. package/dist/test/utils/ai-operation-utility.test.js +290 -0
  92. package/dist/test/utils/error-handling.test.d.ts +2 -0
  93. package/dist/test/utils/error-handling.test.d.ts.map +1 -0
  94. package/dist/test/utils/error-handling.test.js +231 -0
  95. package/dist/utils/ai-operation-utility.d.ts +142 -0
  96. package/dist/utils/ai-operation-utility.d.ts.map +1 -0
  97. package/dist/utils/ai-operation-utility.js +279 -0
  98. package/dist/utils/ai-service-factory.d.ts +10 -0
  99. package/dist/utils/ai-service-factory.d.ts.map +1 -1
  100. package/dist/utils/ai-service-factory.js +19 -1
  101. package/dist/utils/cli-validators.d.ts +2 -2
  102. package/dist/utils/cli-validators.d.ts.map +1 -1
  103. package/dist/utils/cli-validators.js +7 -6
  104. package/dist/utils/error-utils.d.ts +3 -3
  105. package/dist/utils/error-utils.d.ts.map +1 -1
  106. package/dist/utils/error-utils.js +5 -4
  107. package/dist/utils/file-utils.d.ts +27 -4
  108. package/dist/utils/file-utils.d.ts.map +1 -1
  109. package/dist/utils/file-utils.js +46 -6
  110. package/dist/utils/id-generator.d.ts +1 -1
  111. package/dist/utils/id-generator.d.ts.map +1 -1
  112. package/dist/utils/id-generator.js +8 -2
  113. package/dist/utils/metadata-utils.d.ts +40 -0
  114. package/dist/utils/metadata-utils.d.ts.map +1 -0
  115. package/dist/utils/metadata-utils.js +43 -0
  116. package/dist/utils/model-executor-parser.d.ts +1 -1
  117. package/dist/utils/model-executor-parser.d.ts.map +1 -1
  118. package/dist/utils/model-executor-parser.js +3 -2
  119. package/dist/utils/storage-utils.d.ts +3 -3
  120. package/dist/utils/storage-utils.d.ts.map +1 -1
  121. package/dist/utils/storage-utils.js +7 -6
  122. package/dist/utils/task-o-matic-error.d.ts +206 -0
  123. package/dist/utils/task-o-matic-error.d.ts.map +1 -0
  124. package/dist/utils/task-o-matic-error.js +304 -0
  125. package/package.json +7 -2
@@ -0,0 +1,304 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.TaskOMaticErrorCodes = exports.TaskOMaticError = void 0;
4
+ exports.createStandardError = createStandardError;
5
+ exports.formatStandardError = formatStandardError;
6
+ exports.isTaskOMaticError = isTaskOMaticError;
7
+ exports.formatTaskNotFoundError = formatTaskNotFoundError;
8
+ exports.formatInvalidStatusTransitionError = formatInvalidStatusTransitionError;
9
+ exports.formatStorageError = formatStorageError;
10
+ exports.formatAIOperationError = formatAIOperationError;
11
+ exports.wrapErrorForBackwardCompatibility = wrapErrorForBackwardCompatibility;
12
+ const error_utils_1 = require("./error-utils");
13
+ /**
14
+ * TaskOMaticError - Standardized error class for TaskOMatic
15
+ *
16
+ * Provides consistent error handling with context, suggestions, and typing.
17
+ * All errors in the system should use this class or one of the helper functions
18
+ * to ensure consistent error reporting and debugging experience.
19
+ *
20
+ * @example Basic usage
21
+ * ```typescript
22
+ * throw new TaskOMaticError("Task not found", {
23
+ * code: "TASK_NOT_FOUND",
24
+ * context: "Attempted to retrieve task ID: 123",
25
+ * suggestions: [
26
+ * "Verify the task ID is correct",
27
+ * "Check if the task was deleted"
28
+ * ]
29
+ * });
30
+ * ```
31
+ *
32
+ * @example With cause chain
33
+ * ```typescript
34
+ * try {
35
+ * await storage.getTask(id);
36
+ * } catch (error) {
37
+ * throw new TaskOMaticError("Failed to retrieve task", {
38
+ * code: "STORAGE_ERROR",
39
+ * cause: error instanceof Error ? error : new Error(String(error)),
40
+ * context: `Task ID: ${id}`,
41
+ * suggestions: ["Check storage permissions", "Verify storage is initialized"]
42
+ * });
43
+ * }
44
+ * ```
45
+ *
46
+ * @example With metadata
47
+ * ```typescript
48
+ * throw new TaskOMaticError("AI operation timed out", {
49
+ * code: "AI_OPERATION_FAILED",
50
+ * metadata: {
51
+ * operation: "task-breakdown",
52
+ * duration: 30000,
53
+ * retryAttempts: 3
54
+ * },
55
+ * suggestions: ["Increase timeout", "Check AI service status"]
56
+ * });
57
+ * ```
58
+ */
59
+ class TaskOMaticError extends Error {
60
+ /**
61
+ * Error code for categorization
62
+ */
63
+ code;
64
+ /**
65
+ * Additional context information
66
+ */
67
+ context;
68
+ /**
69
+ * Actionable suggestions for resolving the error
70
+ */
71
+ suggestions;
72
+ /**
73
+ * Original error that caused this error (if applicable)
74
+ */
75
+ cause;
76
+ /**
77
+ * Timestamp when the error occurred
78
+ */
79
+ timestamp;
80
+ /**
81
+ * Additional metadata for debugging
82
+ */
83
+ metadata;
84
+ /**
85
+ * Create a new TaskOMaticError
86
+ *
87
+ * @param message - Error message
88
+ * @param options - Additional error options
89
+ */
90
+ constructor(message, options) {
91
+ super(message);
92
+ this.name = "TaskOMaticError";
93
+ this.code = options.code;
94
+ this.context = options.context;
95
+ this.suggestions = options.suggestions;
96
+ this.cause = options.cause;
97
+ this.timestamp = Date.now();
98
+ this.metadata = options.metadata;
99
+ // Maintain proper stack trace
100
+ if (Error.captureStackTrace) {
101
+ Error.captureStackTrace(this, TaskOMaticError);
102
+ }
103
+ }
104
+ /**
105
+ * Get full error details as a formatted string
106
+ */
107
+ getDetails() {
108
+ let details = `[${this.code}] ${this.message}`;
109
+ if (this.context) {
110
+ details += `\nContext: ${this.context}`;
111
+ }
112
+ if (this.suggestions && this.suggestions.length > 0) {
113
+ details += `\nSuggestions:\n- ${this.suggestions.join("\n- ")}`;
114
+ }
115
+ if (this.cause) {
116
+ details += `\nCaused by: ${this.cause.message}`;
117
+ }
118
+ if (this.metadata && Object.keys(this.metadata).length > 0) {
119
+ details += `\nMetadata: ${JSON.stringify(this.metadata, null, 2)}`;
120
+ }
121
+ return details;
122
+ }
123
+ /**
124
+ * Get error details as a structured object
125
+ */
126
+ toJSON() {
127
+ return {
128
+ name: this.name,
129
+ code: this.code,
130
+ message: this.message,
131
+ context: this.context,
132
+ suggestions: this.suggestions,
133
+ cause: this.cause?.message,
134
+ timestamp: this.timestamp,
135
+ metadata: this.metadata,
136
+ stack: this.stack,
137
+ };
138
+ }
139
+ }
140
+ exports.TaskOMaticError = TaskOMaticError;
141
+ /**
142
+ * Standard error codes for TaskOMatic
143
+ */
144
+ exports.TaskOMaticErrorCodes = {
145
+ // General errors
146
+ UNEXPECTED_ERROR: "TASK_O_MATIC_001",
147
+ INVALID_INPUT: "TASK_O_MATIC_002",
148
+ CONFIGURATION_ERROR: "TASK_O_MATIC_003",
149
+ // Task-related errors
150
+ TASK_NOT_FOUND: "TASK_O_MATIC_101",
151
+ TASK_ALREADY_EXISTS: "TASK_O_MATIC_102",
152
+ INVALID_TASK_STATUS: "TASK_O_MATIC_103",
153
+ TASK_OPERATION_FAILED: "TASK_O_MATIC_104",
154
+ // Storage errors
155
+ STORAGE_ERROR: "TASK_O_MATIC_201",
156
+ STORAGE_NOT_INITIALIZED: "TASK_O_MATIC_202",
157
+ STORAGE_INTEGRITY_ERROR: "TASK_O_MATIC_203",
158
+ // AI operation errors
159
+ AI_OPERATION_FAILED: "TASK_O_MATIC_301",
160
+ AI_CONFIGURATION_ERROR: "TASK_O_MATIC_302",
161
+ AI_RATE_LIMIT: "TASK_O_MATIC_303",
162
+ // Workflow errors
163
+ WORKFLOW_VALIDATION_ERROR: "TASK_O_MATIC_401",
164
+ WORKFLOW_EXECUTION_ERROR: "TASK_O_MATIC_402",
165
+ // PRD errors
166
+ PRD_PARSING_ERROR: "TASK_O_MATIC_501",
167
+ PRD_GENERATION_ERROR: "TASK_O_MATIC_502",
168
+ PRD_VALIDATION_ERROR: "TASK_O_MATIC_503",
169
+ };
170
+ /**
171
+ * Create a standardized error with context and suggestions
172
+ *
173
+ * Helper function to create TaskOMaticError instances with proper error codes
174
+ * from the TaskOMaticErrorCodes constants.
175
+ *
176
+ * @param code - Error code from TaskOMaticErrorCodes
177
+ * @param message - Human-readable error message
178
+ * @param options - Additional error options
179
+ * @returns Configured TaskOMaticError instance
180
+ *
181
+ * @example
182
+ * ```typescript
183
+ * throw createStandardError(
184
+ * TaskOMaticErrorCodes.TASK_NOT_FOUND,
185
+ * "Task with ID '123' not found",
186
+ * {
187
+ * context: "User attempted to retrieve non-existent task",
188
+ * suggestions: ["Verify task ID", "List all tasks to see available IDs"]
189
+ * }
190
+ * );
191
+ * ```
192
+ */
193
+ function createStandardError(code, message, options = {}) {
194
+ return new TaskOMaticError(message, {
195
+ code,
196
+ context: options.context,
197
+ suggestions: options.suggestions,
198
+ cause: options.cause,
199
+ metadata: options.metadata,
200
+ });
201
+ }
202
+ /**
203
+ * Format an existing error into a TaskOMaticError with context and suggestions
204
+ *
205
+ * Useful for wrapping caught errors with additional context while preserving
206
+ * the original error as the cause.
207
+ *
208
+ * @param error - Original error to wrap
209
+ * @param code - Error code from TaskOMaticErrorCodes
210
+ * @param options - Additional error options
211
+ * @returns TaskOMaticError wrapping the original error
212
+ *
213
+ * @example
214
+ * ```typescript
215
+ * try {
216
+ * await dangerousOperation();
217
+ * } catch (error) {
218
+ * throw formatStandardError(
219
+ * error,
220
+ * TaskOMaticErrorCodes.STORAGE_ERROR,
221
+ * {
222
+ * context: "Failed during task persistence",
223
+ * suggestions: ["Check disk space", "Verify write permissions"]
224
+ * }
225
+ * );
226
+ * }
227
+ * ```
228
+ */
229
+ function formatStandardError(error, code, options = {}) {
230
+ const message = (0, error_utils_1.getErrorMessage)(error);
231
+ const cause = error instanceof Error ? error : undefined;
232
+ return new TaskOMaticError(message, {
233
+ code,
234
+ context: options.context,
235
+ suggestions: options.suggestions,
236
+ cause,
237
+ metadata: options.metadata,
238
+ });
239
+ }
240
+ /**
241
+ * Type guard for TaskOMaticError
242
+ */
243
+ function isTaskOMaticError(error) {
244
+ return error instanceof TaskOMaticError;
245
+ }
246
+ /**
247
+ * Common error formatting functions
248
+ */
249
+ function formatTaskNotFoundError(taskId) {
250
+ return createStandardError(exports.TaskOMaticErrorCodes.TASK_NOT_FOUND, `Task with ID "${taskId}" not found`, {
251
+ context: `The task "${taskId}" could not be found in the storage.`,
252
+ suggestions: [
253
+ "Verify the task ID is correct",
254
+ "Check if the task was deleted",
255
+ "List all tasks to see available IDs",
256
+ ],
257
+ });
258
+ }
259
+ function formatInvalidStatusTransitionError(fromStatus, toStatus) {
260
+ return createStandardError(exports.TaskOMaticErrorCodes.INVALID_TASK_STATUS, `Invalid status transition from "${fromStatus}" to "${toStatus}"`, {
261
+ context: `Task status transitions must follow the workflow: todo -> in-progress -> completed.`,
262
+ suggestions: [
263
+ "Use a valid status transition",
264
+ "Check the current task status",
265
+ "Review the workflow documentation",
266
+ ],
267
+ });
268
+ }
269
+ function formatStorageError(operation, cause) {
270
+ return createStandardError(exports.TaskOMaticErrorCodes.STORAGE_ERROR, `Storage operation "${operation}" failed`, {
271
+ context: `The storage operation "${operation}" could not be completed.`,
272
+ suggestions: [
273
+ "Check storage permissions",
274
+ "Verify storage configuration",
275
+ "Review storage logs for details",
276
+ ],
277
+ cause,
278
+ });
279
+ }
280
+ function formatAIOperationError(operation, cause) {
281
+ return createStandardError(exports.TaskOMaticErrorCodes.AI_OPERATION_FAILED, `AI operation "${operation}" failed`, {
282
+ context: `The AI operation "${operation}" could not be completed.`,
283
+ suggestions: [
284
+ "Check AI configuration",
285
+ "Verify API keys and endpoints",
286
+ "Review AI service status",
287
+ "Check rate limits",
288
+ ],
289
+ cause,
290
+ });
291
+ }
292
+ /**
293
+ * Backward compatibility wrapper
294
+ * Maintains existing error handling patterns while using new error system
295
+ */
296
+ function wrapErrorForBackwardCompatibility(error, context) {
297
+ if (isTaskOMaticError(error)) {
298
+ return error;
299
+ }
300
+ if (error instanceof Error) {
301
+ return error;
302
+ }
303
+ return new Error((0, error_utils_1.formatError)(error, context));
304
+ }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "task-o-matic",
3
- "version": "0.0.14",
3
+ "version": "0.0.16",
4
4
  "description": "AI-powered task management CLI",
5
5
  "keywords": [
6
6
  "task-management",
@@ -34,6 +34,11 @@
34
34
  "types": "./dist/types/index.d.ts",
35
35
  "require": "./dist/types/index.js",
36
36
  "default": "./dist/types/index.js"
37
+ },
38
+ "./cli": {
39
+ "types": "./dist/index.d.ts",
40
+ "require": "./dist/index.js",
41
+ "default": "./dist/index.js"
37
42
  }
38
43
  },
39
44
  "files": [
@@ -50,7 +55,7 @@
50
55
  "dev:mcp": "tsx src/mcp/server.ts",
51
56
  "start": "node dist/cli/bin.js",
52
57
  "check-types": "tsc --noEmit --skipLibCheck",
53
- "test": "mocha -r tsx/cjs src/test/**/*.test.ts",
58
+ "test": "mocha -r tsx/cjs src/test/test-setup.ts src/test/**/*.test.ts",
54
59
  "prepare": "npm run build && chmod +x dist/cli/bin.js",
55
60
  "prepublishOnly": "bun run build && chmod +x dist/cli/bin.js && bun test"
56
61
  },