claude-flow-novice 2.2.4 → 2.2.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (288) hide show
  1. package/package.json +9 -8
  2. package/scripts/.claude-flow/metrics/agent-metrics.json +1 -0
  3. package/scripts/.claude-flow/metrics/performance.json +9 -0
  4. package/scripts/.claude-flow/metrics/task-metrics.json +10 -0
  5. package/scripts/CLEANUP_OPTIMIZATION_REPORT.json +312 -0
  6. package/scripts/CLEANUP_PERFORMANCE_OPTIMIZATION.md +387 -0
  7. package/scripts/CLEANUP_QUICK_START.md +268 -0
  8. package/scripts/CLEANUP_TEST_RESULTS.md +205 -0
  9. package/scripts/README.md +339 -0
  10. package/scripts/ace-query.sh +384 -0
  11. package/scripts/agent-token-analysis.js +430 -0
  12. package/scripts/auto-setup.js +332 -0
  13. package/scripts/build/README.md +167 -0
  14. package/scripts/build/build-config.js +27 -0
  15. package/scripts/build/build-prompt-copier.sh +30 -0
  16. package/scripts/build/performance-monitor.js +869 -0
  17. package/scripts/build/prepare-publish.js +150 -0
  18. package/scripts/build/typescript-fixer.js +621 -0
  19. package/scripts/build/unified-builder.sh +428 -0
  20. package/scripts/build/update-bin-version.js +32 -0
  21. package/scripts/build/validate-agents.js +238 -0
  22. package/scripts/build-index.js +43 -0
  23. package/scripts/build-orchestrator.js +320 -0
  24. package/scripts/check-routing-stats.cjs +122 -0
  25. package/scripts/ci-validation.js +375 -0
  26. package/scripts/cleanup-blocking-coordination.sh +420 -0
  27. package/scripts/cleanup-idle-sessions.sh +59 -0
  28. package/scripts/collect-build-metrics.js +65 -0
  29. package/scripts/demo/README.md +79 -0
  30. package/scripts/demo/autoscaling-demo-simplified.js +963 -0
  31. package/scripts/demo/comprehensive-dashboard-test.js +693 -0
  32. package/scripts/demo/confidence-log.js +87 -0
  33. package/scripts/demo/confidence-report.js +82 -0
  34. package/scripts/demo/demo-multi-swarm-coordination.js +325 -0
  35. package/scripts/demo/demo-production-deployment.js +399 -0
  36. package/scripts/demo/demo-visualization-system.js +149 -0
  37. package/scripts/demo/performance-analysis.cjs +71 -0
  38. package/scripts/demo/performance-analysis.js +71 -0
  39. package/scripts/demo/test-autoscaling-demo.js +314 -0
  40. package/scripts/dependency-optimizer.js +349 -0
  41. package/scripts/dependency-security-assessment.js +331 -0
  42. package/scripts/deploy-sdk.sh +176 -0
  43. package/scripts/deployment-readiness-report.json +179 -0
  44. package/scripts/dev/README.md +264 -0
  45. package/scripts/dev/claude-flow-wrapper.sh +35 -0
  46. package/scripts/dev/claude-monitor.py +419 -0
  47. package/scripts/dev/claude-sparc.sh +562 -0
  48. package/scripts/dev/claude-wrapper.sh +17 -0
  49. package/scripts/dev/demo-phase3-compliance.js +172 -0
  50. package/scripts/dev/demo-task-system.ts +224 -0
  51. package/scripts/dev/deployment-validator.js +315 -0
  52. package/scripts/dev/spawn-claude-terminal.sh +32 -0
  53. package/scripts/dev/start-portal.sh +506 -0
  54. package/scripts/dev/start-web-ui.js +15 -0
  55. package/scripts/dev/stop-portal.sh +311 -0
  56. package/scripts/dev/validate-examples.ts +288 -0
  57. package/scripts/dev/validate-phase2.cjs +451 -0
  58. package/scripts/dev/validate-phase2.js +785 -0
  59. package/scripts/dev/validate-phase3.cjs +208 -0
  60. package/scripts/dev/validate-security-remediation.js +1 -0
  61. package/scripts/ecosystem.config.cjs +90 -0
  62. package/scripts/fix-js-extensions.js +167 -0
  63. package/scripts/generate-basic-types.js +73 -0
  64. package/scripts/generate-changelog.js +318 -0
  65. package/scripts/git-hooks/pre-commit.sh +143 -0
  66. package/scripts/health-checks.js +634 -0
  67. package/scripts/hook-wrapper.sh +54 -0
  68. package/scripts/install/README.md +375 -0
  69. package/scripts/install/REDIS_SETUP_VALIDATION.json +245 -0
  70. package/scripts/install/check-prerequisites.js +303 -0
  71. package/scripts/install/config-wizard.js +606 -0
  72. package/scripts/install/dependency-checker.js +385 -0
  73. package/scripts/install/health-check.js +765 -0
  74. package/scripts/install/install.js +256 -0
  75. package/scripts/install/installation-benchmark.js +461 -0
  76. package/scripts/install/quick-install.js +720 -0
  77. package/scripts/install/quick-start-wizard.js +295 -0
  78. package/scripts/install/redis-cli.js +289 -0
  79. package/scripts/install/redis-install-guides.md +407 -0
  80. package/scripts/install/redis-setup.js +559 -0
  81. package/scripts/install/redis-test.js +278 -0
  82. package/scripts/install/service-manager.js +672 -0
  83. package/scripts/install/setup.js +832 -0
  84. package/scripts/install/uninstall.js +526 -0
  85. package/scripts/install/update.js +461 -0
  86. package/scripts/install-pre-commit-hook.sh +127 -0
  87. package/scripts/legacy/README.md +272 -0
  88. package/scripts/legacy/batch-fix-ts.sh +54 -0
  89. package/scripts/legacy/build-migration.sh +105 -0
  90. package/scripts/legacy/build-monitor.js +209 -0
  91. package/scripts/legacy/build-with-filter.sh +84 -0
  92. package/scripts/legacy/build-workaround.sh +71 -0
  93. package/scripts/legacy/fix-ts-advanced.js +358 -0
  94. package/scripts/legacy/fix-ts-final.sh +50 -0
  95. package/scripts/legacy/fix-ts-targeted.sh +49 -0
  96. package/scripts/legacy/fix-typescript-errors.js +305 -0
  97. package/scripts/legacy/force-build.sh +63 -0
  98. package/scripts/legacy/optimize-performance.js +400 -0
  99. package/scripts/legacy/performance-monitor.js +263 -0
  100. package/scripts/legacy/performance-monitoring.js +532 -0
  101. package/scripts/legacy/performance-test-runner.js +645 -0
  102. package/scripts/legacy/quick-fix-ts.js +281 -0
  103. package/scripts/legacy/safe-build.sh +63 -0
  104. package/scripts/memory-monitor-coordinator.js +322 -0
  105. package/scripts/migrate-to-sdk.sh +520 -0
  106. package/scripts/migration/QUICK-START.md +189 -0
  107. package/scripts/migration/QUICK-START.md.backup-1760135091363 +189 -0
  108. package/scripts/migration/README.md +464 -0
  109. package/scripts/migration/TASK-1.3.2-COMPLETION-REPORT.md +500 -0
  110. package/scripts/migration/TASK-1.3.2-COMPLETION-REPORT.md.backup-1760135091348 +500 -0
  111. package/scripts/migration/UPDATE-PATHS-README.md +464 -0
  112. package/scripts/migration/UPDATE-PATHS-README.md.backup-1760135091337 +464 -0
  113. package/scripts/migration/example-patterns.json +19 -0
  114. package/scripts/migration/install-arm64.js +78 -0
  115. package/scripts/migration/install.js +83 -0
  116. package/scripts/migration/migrate-hooks.js +173 -0
  117. package/scripts/migration/migration-examples.ts +318 -0
  118. package/scripts/migration/reorganize-workspace.js +504 -0
  119. package/scripts/migration/test-update-paths.js +359 -0
  120. package/scripts/migration/update-paths.js +664 -0
  121. package/scripts/migration/validate-migration.js +647 -0
  122. package/scripts/monitor-loop.sh +65 -0
  123. package/scripts/monitor-memory.sh +47 -0
  124. package/scripts/monitor-migration.js +339 -0
  125. package/scripts/monitor.py +43 -0
  126. package/scripts/monitoring/README.md +178 -0
  127. package/scripts/monitoring/alert-monitor.sh +220 -0
  128. package/scripts/monitoring/analyze-resources.sh +199 -0
  129. package/scripts/monitoring/dashboards/rate-limiting-dashboard.json +211 -0
  130. package/scripts/monitoring/dynamic-monitor.sh +85 -0
  131. package/scripts/monitoring/launch-stability-test.sh +184 -0
  132. package/scripts/monitoring/monitor-test.sh +93 -0
  133. package/scripts/monitoring/pre-test-validation.sh +208 -0
  134. package/scripts/monitoring/quick-test-alerting.sh +118 -0
  135. package/scripts/monitoring/quick-test-rate-limiting.sh +206 -0
  136. package/scripts/monitoring/rate-limiting-monitor.sh +380 -0
  137. package/scripts/monitoring/resource-monitor.sh +126 -0
  138. package/scripts/monitoring/stability-monitor.js +429 -0
  139. package/scripts/monitoring/test-monitor-quick.sh +54 -0
  140. package/scripts/monitoring/view-alerts.sh +307 -0
  141. package/scripts/npm-metrics-collector.js +482 -0
  142. package/scripts/npm-package-validation.cjs +299 -0
  143. package/scripts/optimization/build-optimizer.js +438 -0
  144. package/scripts/optimization/config-validator.js +761 -0
  145. package/scripts/optimization/test-optimization.js +432 -0
  146. package/scripts/optimization/unified-activation.js +839 -0
  147. package/scripts/optimize-package-swarm.js +54 -0
  148. package/scripts/performance/ACTIVATION_COMMANDS.md +292 -0
  149. package/scripts/performance/sqlite-enhanced-activation.sh +583 -0
  150. package/scripts/performance/test-enhanced-backend.sh +504 -0
  151. package/scripts/performance-monitor.js +644 -0
  152. package/scripts/performance-test-runner.js +698 -0
  153. package/scripts/post-deployment-monitoring.js +350 -0
  154. package/scripts/post-edit-pipeline.js +2091 -0
  155. package/scripts/post-install-claude-md.js +78 -0
  156. package/scripts/postinstall.js +79 -0
  157. package/scripts/pre-publish-validation.cjs +212 -0
  158. package/scripts/pre-publish-validation.js +429 -0
  159. package/scripts/redis-lua/cleanup-blocking-coordination.lua +198 -0
  160. package/scripts/release-announcement.js +425 -0
  161. package/scripts/release-notification.js +248 -0
  162. package/scripts/release-rollback.js +376 -0
  163. package/scripts/release-validation.js +460 -0
  164. package/scripts/rollback-sdk.sh +66 -0
  165. package/scripts/run-production-validation.ts +590 -0
  166. package/scripts/run-stability-validation.sh +687 -0
  167. package/scripts/security/README.md +339 -0
  168. package/scripts/security/deployment-validation.cjs +279 -0
  169. package/scripts/security/envelope-encryption-confidence-report.cjs +422 -0
  170. package/scripts/security/install-git-hooks.sh +132 -0
  171. package/scripts/security/install-git-secrets.sh +295 -0
  172. package/scripts/security/rotate-api-keys.js +469 -0
  173. package/scripts/security/ruv-swarm-safe.js +74 -0
  174. package/scripts/security/security-audit.cjs +538 -0
  175. package/scripts/security/setup-redis-auth.sh +397 -0
  176. package/scripts/security/validate-envelope-encryption.cjs +340 -0
  177. package/scripts/security-scan.js +492 -0
  178. package/scripts/src/web/frontend/.claude-flow/metrics/agent-metrics.json +1 -0
  179. package/scripts/src/web/frontend/.claude-flow/metrics/performance.json +9 -0
  180. package/scripts/src/web/frontend/.claude-flow/metrics/task-metrics.json +10 -0
  181. package/scripts/switch-api.sh +158 -0
  182. package/scripts/sync-agents.js +290 -0
  183. package/scripts/test/50-agent-test.js +625 -0
  184. package/scripts/test/NEW_STABILITY_TEST_GUIDE.md +407 -0
  185. package/scripts/test/README.md +236 -0
  186. package/scripts/test/STABILITY_TEST_EXAMPLE.md +347 -0
  187. package/scripts/test/STABILITY_TEST_README.md +480 -0
  188. package/scripts/test/agent-worker.js +309 -0
  189. package/scripts/test/ai-coordination-test.js +650 -0
  190. package/scripts/test/ai-mesh-coordination-test.js +416 -0
  191. package/scripts/test/check-links.ts +274 -0
  192. package/scripts/test/check-performance-regression.ts +168 -0
  193. package/scripts/test/cli-agent-coordination-test.js +313 -0
  194. package/scripts/test/coordinator-multilingual-test.js +396 -0
  195. package/scripts/test/coordinator-transparency-demo.js +585 -0
  196. package/scripts/test/coverage-report.ts +692 -0
  197. package/scripts/test/generate-swarm-tests.js +633 -0
  198. package/scripts/test/integration-test-validation.cjs +253 -0
  199. package/scripts/test/load-test-swarm.js +576 -0
  200. package/scripts/test/mesh-coordination-zero-overlap-test.js +740 -0
  201. package/scripts/test/multilingual-hello-world-test.js +390 -0
  202. package/scripts/test/quick-multilingual-demo.js +464 -0
  203. package/scripts/test/real-agent-test.js +312 -0
  204. package/scripts/test/run-phase3-compliance-tests.js +427 -0
  205. package/scripts/test/run-stability-test-examples.sh +292 -0
  206. package/scripts/test/stability-results/stability-metrics.jsonl +83 -0
  207. package/scripts/test/stability-results/stability-test-report.json +128 -0
  208. package/scripts/test/stability-results/stability-test.log +1827 -0
  209. package/scripts/test/stability-test-50-agents.js +734 -0
  210. package/scripts/test/test-batch-tasks.ts +29 -0
  211. package/scripts/test/test-byzantine-resolution.js +246 -0
  212. package/scripts/test/test-claude-spawn-options.sh +63 -0
  213. package/scripts/test/test-cli-wizard.js +331 -0
  214. package/scripts/test/test-comprehensive.js +401 -0
  215. package/scripts/test/test-coordination-features.ts +238 -0
  216. package/scripts/test/test-fallback-systems.js +276 -0
  217. package/scripts/test/test-init-command.ts +302 -0
  218. package/scripts/test/test-mcp.ts +251 -0
  219. package/scripts/test/test-runner.ts +568 -0
  220. package/scripts/test/test-swarm-integration.sh +92 -0
  221. package/scripts/test/test-swarm.ts +142 -0
  222. package/scripts/test/validation-summary.ts +408 -0
  223. package/scripts/test-cleanup-performance.sh +416 -0
  224. package/scripts/test-dashboard-auth.cjs +203 -0
  225. package/scripts/test-docker-deployment.sh +207 -0
  226. package/scripts/test-npm-package.cjs +167 -0
  227. package/scripts/test-provider-routing.cjs +226 -0
  228. package/scripts/test-routing-telemetry.cjs +147 -0
  229. package/scripts/test-runner.cjs +154 -0
  230. package/scripts/test-zai-10k.cjs +81 -0
  231. package/scripts/test-zai-api.cjs +191 -0
  232. package/scripts/test-zai-diagnostic.cjs +151 -0
  233. package/scripts/test-zai-final.cjs +128 -0
  234. package/scripts/test-zai-with-env.cjs +85 -0
  235. package/scripts/utils/README.md +261 -0
  236. package/scripts/utils/clean-build-artifacts.sh +94 -0
  237. package/scripts/utils/cleanup-root.sh +69 -0
  238. package/scripts/utils/fix-cliffy-imports.js +307 -0
  239. package/scripts/utils/fix-duplicate-imports.js +114 -0
  240. package/scripts/utils/fix-error-handling.cjs +70 -0
  241. package/scripts/utils/fix-import-paths.js +104 -0
  242. package/scripts/utils/fix-imports.js +116 -0
  243. package/scripts/utils/fix-shebang.js +78 -0
  244. package/scripts/utils/fix-test-modules.js +27 -0
  245. package/scripts/utils/fix-timezone-issue-246.js +200 -0
  246. package/scripts/utils/fix-ts-comprehensive.py +182 -0
  247. package/scripts/utils/fix-ts-targeted-batch.js +250 -0
  248. package/scripts/utils/remove-benchmark-conflicts.sh +140 -0
  249. package/scripts/utils/simple-test-fixer.js +190 -0
  250. package/scripts/utils/validate-metrics-structure.cjs +144 -0
  251. package/scripts/validate-agent-hooks.js +506 -0
  252. package/scripts/validate-changelog.js +241 -0
  253. package/scripts/validate-coordination-cli.js +69 -0
  254. package/scripts/validate-coordination-toggle-integration.cjs +501 -0
  255. package/scripts/validate-docker-infrastructure.sh +502 -0
  256. package/scripts/validate-entry-points.js +300 -0
  257. package/scripts/validate-stage3-performance.ts +377 -0
  258. package/scripts/validate-template-bundling.js +180 -0
  259. package/scripts/validation/README.md +33 -0
  260. package/scripts/validation/acl-security-validation.cjs +214 -0
  261. package/scripts/validation/acl-security-validation.js +402 -0
  262. package/scripts/validation/byzantine-verification.js +407 -0
  263. package/scripts/validation/final-phase-2-consensus.cjs +219 -0
  264. package/scripts/validation/final-security-validation.js +791 -0
  265. package/scripts/validation/final-wasm-validation.cjs +840 -0
  266. package/scripts/validation/integration-test-analysis.js +105 -0
  267. package/scripts/validation/phase-0-comprehensive-validation.js +474 -0
  268. package/scripts/validation/phase-0-consensus-report.js +139 -0
  269. package/scripts/validation/phase-0-final-report.js +112 -0
  270. package/scripts/validation/phase-0-redis-consensus-report.js +129 -0
  271. package/scripts/validation/phase-0-validation-improved.js +490 -0
  272. package/scripts/validation/phase-0-validation-test.js +65 -0
  273. package/scripts/validation/phase-1-consensus-report.cjs +342 -0
  274. package/scripts/validation/phase-1-consensus-validation.cjs +551 -0
  275. package/scripts/validation/phase-1-consensus-validation.js +551 -0
  276. package/scripts/validation/phase-2-consensus-report.cjs +186 -0
  277. package/scripts/validation/phase-2-validation.cjs +171 -0
  278. package/scripts/validation/phase-2-validation.js +171 -0
  279. package/scripts/validation/phase-4-consensus-report.js +181 -0
  280. package/scripts/validation/phase-4-final-validation.js +351 -0
  281. package/scripts/validation/phase-5-consensus-report.cjs +113 -0
  282. package/scripts/validation/phase-5-consensus-report.js +113 -0
  283. package/scripts/validation/security-analysis.js +49 -0
  284. package/scripts/validation/security-validation.js +492 -0
  285. package/scripts/validation/simple-security-validation.js +464 -0
  286. package/scripts/verify-installation.js +112 -0
  287. package/scripts/verify-mcp-server.js +86 -0
  288. package/scripts/verify-sdk-phase1.cjs +293 -0
@@ -0,0 +1,309 @@
1
+ #!/usr/bin/env node
2
+
3
+ /**
4
+ * Agent Worker Process
5
+ *
6
+ * A minimal Node.js process that participates in agent coordination tests.
7
+ * Responds to coordination messages via /dev/shm file-based messaging.
8
+ */
9
+
10
+ import fs from 'fs';
11
+ import path from 'path';
12
+ import os from 'os';
13
+ import { fileURLToPath } from 'url';
14
+
15
+ const __filename = fileURLToPath(import.meta.url);
16
+ const __dirname = path.dirname(__filename);
17
+
18
+ class AgentWorker {
19
+ constructor(agentId, coordinationDir = '/dev/shm/agent-coordination') {
20
+ this.agentId = agentId;
21
+ this.coordinationDir = coordinationDir;
22
+ this.messageDir = path.join(coordinationDir, 'messages');
23
+ this.responseDir = path.join(coordinationDir, 'responses');
24
+ this.statusDir = path.join(coordinationDir, 'status');
25
+
26
+ this.isRunning = false;
27
+ this.startTime = Date.now();
28
+ this.coordinationCount = 0;
29
+ this.errorCount = 0;
30
+ this.lastCoordinationTime = 0;
31
+
32
+ // Memory tracking
33
+ this.memorySnapshots = [];
34
+ this.maxMemorySnapshots = 100; // Keep last 100 snapshots
35
+
36
+ this.setupDirectories();
37
+ this.setupSignalHandlers();
38
+ }
39
+
40
+ setupDirectories() {
41
+ [this.coordinationDir, this.messageDir, this.responseDir, this.statusDir].forEach(dir => {
42
+ try {
43
+ fs.mkdirSync(dir, { recursive: true });
44
+ } catch (error) {
45
+ console.error(`[Agent ${this.agentId}] Failed to create directory ${dir}:`, error.message);
46
+ process.exit(1);
47
+ }
48
+ });
49
+ }
50
+
51
+ setupSignalHandlers() {
52
+ const gracefulShutdown = (signal) => {
53
+ console.log(`[Agent ${this.agentId}] Received ${signal}, shutting down gracefully...`);
54
+ this.writeStatus('shutdown');
55
+ process.exit(0);
56
+ };
57
+
58
+ process.on('SIGTERM', () => gracefulShutdown('SIGTERM'));
59
+ process.on('SIGINT', () => gracefulShutdown('SIGINT'));
60
+ process.on('SIGHUP', () => gracefulShutdown('SIGHUP'));
61
+
62
+ process.on('uncaughtException', (error) => {
63
+ console.error(`[Agent ${this.agentId}] Uncaught exception:`, error);
64
+ this.errorCount++;
65
+ this.writeStatus('error', { error: error.message, stack: error.stack });
66
+ });
67
+
68
+ process.on('unhandledRejection', (reason, promise) => {
69
+ console.error(`[Agent ${this.agentId}] Unhandled rejection at:`, promise, 'reason:', reason);
70
+ this.errorCount++;
71
+ this.writeStatus('error', { error: reason.toString() });
72
+ });
73
+ }
74
+
75
+ takeMemorySnapshot() {
76
+ const memUsage = process.memoryUsage();
77
+ const snapshot = {
78
+ timestamp: Date.now(),
79
+ rss: memUsage.rss,
80
+ heapUsed: memUsage.heapUsed,
81
+ heapTotal: memUsage.heapTotal,
82
+ external: memUsage.external,
83
+ arrayBuffers: memUsage.arrayBuffers
84
+ };
85
+
86
+ this.memorySnapshots.push(snapshot);
87
+
88
+ // Keep only the last N snapshots to prevent memory growth in the tracking
89
+ if (this.memorySnapshots.length > this.maxMemorySnapshots) {
90
+ this.memorySnapshots.shift();
91
+ }
92
+
93
+ return snapshot;
94
+ }
95
+
96
+ getMemoryGrowthRate() {
97
+ if (this.memorySnapshots.length < 2) return 0;
98
+
99
+ const recent = this.memorySnapshots.slice(-10); // Last 10 snapshots
100
+ const oldest = recent[0];
101
+ const newest = recent[recent.length - 1];
102
+
103
+ const timeDiff = newest.timestamp - oldest.timestamp;
104
+ if (timeDiff === 0) return 0;
105
+
106
+ const memoryDiff = newest.heapUsed - oldest.heapUsed;
107
+ return (memoryDiff / timeDiff) * 1000; // bytes per second
108
+ }
109
+
110
+ async waitForCoordinationMessage() {
111
+ const messageFile = path.join(this.messageDir, `coordination-${this.agentId}.json`);
112
+
113
+ return new Promise((resolve, reject) => {
114
+ const checkInterval = setInterval(() => {
115
+ try {
116
+ if (fs.existsSync(messageFile)) {
117
+ clearInterval(checkInterval);
118
+ const messageData = fs.readFileSync(messageFile, 'utf8');
119
+ fs.unlinkSync(messageFile); // Remove message after reading
120
+
121
+ const message = JSON.parse(messageData);
122
+ resolve(message);
123
+ }
124
+ } catch (error) {
125
+ clearInterval(checkInterval);
126
+ reject(error);
127
+ }
128
+ }, 100); // Check every 100ms
129
+ });
130
+ }
131
+
132
+ async processCoordinationMessage(message) {
133
+ const startTime = Date.now();
134
+ this.coordinationCount++;
135
+ this.lastCoordinationTime = startTime;
136
+
137
+ try {
138
+ // Simulate some work based on message type
139
+ let responsePayload = {};
140
+
141
+ switch (message.type) {
142
+ case 'ping':
143
+ responsePayload = { pong: true, timestamp: Date.now() };
144
+ break;
145
+
146
+ case 'compute':
147
+ // Simulate computational work
148
+ const iterations = message.data?.iterations || 1000;
149
+ let result = 0;
150
+ for (let i = 0; i < iterations; i++) {
151
+ result += Math.random();
152
+ }
153
+ responsePayload = { result, iterations };
154
+ break;
155
+
156
+ case 'memory_test':
157
+ // Allocate some memory to test memory tracking
158
+ const testArray = new Array(message.data?.size || 1000).fill(0).map(() => Math.random());
159
+ responsePayload = {
160
+ arrayLength: testArray.length,
161
+ sampleValue: testArray[0]
162
+ };
163
+ // Let GC clean this up
164
+ break;
165
+
166
+ default:
167
+ responsePayload = { status: 'unknown_command', command: message.type };
168
+ }
169
+
170
+ const processingTime = Date.now() - startTime;
171
+ const memorySnapshot = this.takeMemorySnapshot();
172
+ const memoryGrowthRate = this.getMemoryGrowthRate();
173
+
174
+ const response = {
175
+ agentId: this.agentId,
176
+ messageId: message.messageId,
177
+ timestamp: Date.now(),
178
+ processingTime,
179
+ coordinationCount: this.coordinationCount,
180
+ errorCount: this.errorCount,
181
+ uptime: Date.now() - this.startTime,
182
+ memory: memorySnapshot,
183
+ memoryGrowthRate: Math.round(memoryGrowthRate),
184
+ response: responsePayload
185
+ };
186
+
187
+ await this.writeResponse(response);
188
+ this.writeStatus('active', {
189
+ lastCoordination: this.lastCoordinationTime,
190
+ coordinationCount: this.coordinationCount,
191
+ processingTime,
192
+ memory: memorySnapshot
193
+ });
194
+
195
+ return response;
196
+
197
+ } catch (error) {
198
+ this.errorCount++;
199
+ const errorResponse = {
200
+ agentId: this.agentId,
201
+ messageId: message.messageId,
202
+ timestamp: Date.now(),
203
+ error: error.message,
204
+ coordinationCount: this.coordinationCount,
205
+ errorCount: this.errorCount
206
+ };
207
+
208
+ await this.writeResponse(errorResponse);
209
+ this.writeStatus('error', { error: error.message });
210
+
211
+ throw error;
212
+ }
213
+ }
214
+
215
+ async writeResponse(response) {
216
+ const responseFile = path.join(this.responseDir, `response-${this.agentId}-${response.messageId}.json`);
217
+
218
+ try {
219
+ fs.writeFileSync(responseFile, JSON.stringify(response, null, 2));
220
+ } catch (error) {
221
+ console.error(`[Agent ${this.agentId}] Failed to write response:`, error.message);
222
+ throw error;
223
+ }
224
+ }
225
+
226
+ writeStatus(status, additionalData = {}) {
227
+ const statusFile = path.join(this.statusDir, `agent-${this.agentId}-status.json`);
228
+
229
+ const statusData = {
230
+ agentId: this.agentId,
231
+ status,
232
+ timestamp: Date.now(),
233
+ startTime: this.startTime,
234
+ uptime: Date.now() - this.startTime,
235
+ coordinationCount: this.coordinationCount,
236
+ errorCount: this.errorCount,
237
+ lastCoordinationTime: this.lastCoordinationTime,
238
+ memory: process.memoryUsage(),
239
+ pid: process.pid,
240
+ ...additionalData
241
+ };
242
+
243
+ try {
244
+ fs.writeFileSync(statusFile, JSON.stringify(statusData, null, 2));
245
+ } catch (error) {
246
+ console.error(`[Agent ${this.agentId}] Failed to write status:`, error.message);
247
+ }
248
+ }
249
+
250
+ async start() {
251
+ console.log(`[Agent ${this.agentId}] Starting worker process...`);
252
+ this.isRunning = true;
253
+ this.writeStatus('starting');
254
+
255
+ // Initial memory snapshot
256
+ this.takeMemorySnapshot();
257
+
258
+ console.log(`[Agent ${this.agentId}] Worker started, waiting for coordination messages...`);
259
+ this.writeStatus('ready');
260
+
261
+ // Main coordination loop
262
+ while (this.isRunning) {
263
+ try {
264
+ const message = await this.waitForCoordinationMessage();
265
+ await this.processCoordinationMessage(message);
266
+ } catch (error) {
267
+ console.error(`[Agent ${this.agentId}] Error processing coordination:`, error.message);
268
+ this.errorCount++;
269
+ this.writeStatus('error', { error: error.message });
270
+
271
+ // Continue running even after errors
272
+ await new Promise(resolve => setTimeout(resolve, 1000));
273
+ }
274
+ }
275
+ }
276
+
277
+ stop() {
278
+ console.log(`[Agent ${this.agentId}] Stopping worker...`);
279
+ this.isRunning = false;
280
+ this.writeStatus('stopped');
281
+ }
282
+ }
283
+
284
+ // CLI interface
285
+ if (import.meta.url === `file://${process.argv[1]}`) {
286
+ const args = process.argv.slice(2);
287
+
288
+ if (args.length < 1) {
289
+ console.error('Usage: node agent-worker.js <agent-id> [coordination-dir]');
290
+ process.exit(1);
291
+ }
292
+
293
+ const agentId = args[0];
294
+ const coordinationDir = args[1] || '/dev/shm/agent-coordination';
295
+
296
+ if (!/^\d+$/.test(agentId)) {
297
+ console.error('Agent ID must be a number');
298
+ process.exit(1);
299
+ }
300
+
301
+ const worker = new AgentWorker(parseInt(agentId), coordinationDir);
302
+
303
+ worker.start().catch(error => {
304
+ console.error(`[Agent ${agentId}] Fatal error:`, error);
305
+ process.exit(1);
306
+ });
307
+ }
308
+
309
+ export default AgentWorker;