@holoscript/framework 6.0.3

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 (329) hide show
  1. package/ALL-test-results.json +1 -0
  2. package/CHANGELOG.md +8 -0
  3. package/LICENSE +21 -0
  4. package/ROADMAP.md +175 -0
  5. package/dist/AgentManifest-CB4xM-Ma.d.cts +704 -0
  6. package/dist/AgentManifest-CB4xM-Ma.d.ts +704 -0
  7. package/dist/BehaviorTree-BrBFECv5.d.cts +103 -0
  8. package/dist/BehaviorTree-BrBFECv5.d.ts +103 -0
  9. package/dist/InvisibleWallet-BB6tFvRA.d.cts +1732 -0
  10. package/dist/InvisibleWallet-rtRrBOA8.d.ts +1732 -0
  11. package/dist/OrchestratorAgent-BvWgf9uw.d.cts +798 -0
  12. package/dist/OrchestratorAgent-Q_CbVTmO.d.ts +798 -0
  13. package/dist/agents/index.cjs +4790 -0
  14. package/dist/agents/index.d.cts +1788 -0
  15. package/dist/agents/index.d.ts +1788 -0
  16. package/dist/agents/index.js +4695 -0
  17. package/dist/ai/index.cjs +5347 -0
  18. package/dist/ai/index.d.cts +1753 -0
  19. package/dist/ai/index.d.ts +1753 -0
  20. package/dist/ai/index.js +5244 -0
  21. package/dist/behavior.cjs +449 -0
  22. package/dist/behavior.d.cts +130 -0
  23. package/dist/behavior.d.ts +130 -0
  24. package/dist/behavior.js +407 -0
  25. package/dist/economy/index.cjs +3659 -0
  26. package/dist/economy/index.d.cts +747 -0
  27. package/dist/economy/index.d.ts +747 -0
  28. package/dist/economy/index.js +3617 -0
  29. package/dist/implementations-D9T3un9D.d.cts +236 -0
  30. package/dist/implementations-D9T3un9D.d.ts +236 -0
  31. package/dist/index.cjs +24550 -0
  32. package/dist/index.d.cts +1729 -0
  33. package/dist/index.d.ts +1729 -0
  34. package/dist/index.js +24277 -0
  35. package/dist/learning/index.cjs +219 -0
  36. package/dist/learning/index.d.cts +104 -0
  37. package/dist/learning/index.d.ts +104 -0
  38. package/dist/learning/index.js +189 -0
  39. package/dist/negotiation/index.cjs +970 -0
  40. package/dist/negotiation/index.d.cts +610 -0
  41. package/dist/negotiation/index.d.ts +610 -0
  42. package/dist/negotiation/index.js +931 -0
  43. package/dist/skills/index.cjs +1118 -0
  44. package/dist/skills/index.d.cts +289 -0
  45. package/dist/skills/index.d.ts +289 -0
  46. package/dist/skills/index.js +1079 -0
  47. package/dist/swarm/index.cjs +5268 -0
  48. package/dist/swarm/index.d.cts +2433 -0
  49. package/dist/swarm/index.d.ts +2433 -0
  50. package/dist/swarm/index.js +5221 -0
  51. package/dist/training/index.cjs +2745 -0
  52. package/dist/training/index.d.cts +1734 -0
  53. package/dist/training/index.d.ts +1734 -0
  54. package/dist/training/index.js +2687 -0
  55. package/extract-failures.js +10 -0
  56. package/package.json +82 -0
  57. package/src/__tests__/bounty-marketplace.test.ts +374 -0
  58. package/src/__tests__/delegation.test.ts +144 -0
  59. package/src/__tests__/distributed-claimer.test.ts +147 -0
  60. package/src/__tests__/done-log-audit.test.ts +342 -0
  61. package/src/__tests__/framework.test.ts +865 -0
  62. package/src/__tests__/goal-synthesizer.test.ts +236 -0
  63. package/src/__tests__/presence.test.ts +223 -0
  64. package/src/__tests__/protocol-agent.test.ts +254 -0
  65. package/src/__tests__/revenue-splitter.test.ts +114 -0
  66. package/src/__tests__/scenario-driven-todo.test.ts +197 -0
  67. package/src/__tests__/self-improve.test.ts +349 -0
  68. package/src/__tests__/service-lifecycle.test.ts +237 -0
  69. package/src/__tests__/skill-router.test.ts +121 -0
  70. package/src/agents/AgentManifest.ts +493 -0
  71. package/src/agents/AgentRegistry.ts +475 -0
  72. package/src/agents/AgentTypes.ts +585 -0
  73. package/src/agents/AgentWalletRegistry.ts +83 -0
  74. package/src/agents/AuthenticatedCRDT.ts +388 -0
  75. package/src/agents/CapabilityMatcher.ts +453 -0
  76. package/src/agents/CrossRealityHandoff.ts +305 -0
  77. package/src/agents/CulturalMemory.ts +454 -0
  78. package/src/agents/FederatedRegistryAdapter.ts +429 -0
  79. package/src/agents/NormEngine.ts +450 -0
  80. package/src/agents/OrchestratorAgent.ts +414 -0
  81. package/src/agents/SkillWorkflowEngine.ts +472 -0
  82. package/src/agents/TaskDelegationService.ts +551 -0
  83. package/src/agents/__tests__/AgentManifest.prod.test.ts +134 -0
  84. package/src/agents/__tests__/AgentManifest.test.ts +182 -0
  85. package/src/agents/__tests__/AgentModule.test.ts +864 -0
  86. package/src/agents/__tests__/AgentRegistry.prod.test.ts +125 -0
  87. package/src/agents/__tests__/AgentRegistry.test.ts +148 -0
  88. package/src/agents/__tests__/AgentTypes.test.ts +534 -0
  89. package/src/agents/__tests__/AgentWalletRegistry.test.ts +152 -0
  90. package/src/agents/__tests__/AuthenticatedCRDT.test.ts +558 -0
  91. package/src/agents/__tests__/CapabilityMatcher.prod.test.ts +117 -0
  92. package/src/agents/__tests__/CapabilityMatcher.test.ts +178 -0
  93. package/src/agents/__tests__/CrossRealityHandoff.test.ts +402 -0
  94. package/src/agents/__tests__/CulturalMemory.test.ts +200 -0
  95. package/src/agents/__tests__/FederatedRegistryAdapter.test.ts +409 -0
  96. package/src/agents/__tests__/NormEngine.test.ts +276 -0
  97. package/src/agents/__tests__/OrchestratorAgent.test.ts +182 -0
  98. package/src/agents/__tests__/SkillWorkflowEngine.test.ts +357 -0
  99. package/src/agents/__tests__/TaskDelegationService.test.ts +446 -0
  100. package/src/agents/index.ts +107 -0
  101. package/src/agents/spatial-comms/Layer1RealTime.ts +621 -0
  102. package/src/agents/spatial-comms/Layer2A2A.ts +661 -0
  103. package/src/agents/spatial-comms/Layer3MCP.ts +651 -0
  104. package/src/agents/spatial-comms/ProtocolTypes.ts +543 -0
  105. package/src/agents/spatial-comms/SpatialCommClient.ts +483 -0
  106. package/src/agents/spatial-comms/__tests__/performance-benchmark.test.ts +465 -0
  107. package/src/agents/spatial-comms/examples/multi-agent-world-creation.ts +409 -0
  108. package/src/agents/spatial-comms/index.ts +66 -0
  109. package/src/ai/AIAdapter.ts +313 -0
  110. package/src/ai/AICopilot.ts +331 -0
  111. package/src/ai/AIOutputValidator.ts +203 -0
  112. package/src/ai/BTNodes.ts +239 -0
  113. package/src/ai/BehaviorSelector.ts +135 -0
  114. package/src/ai/BehaviorTree.ts +153 -0
  115. package/src/ai/Blackboard.ts +165 -0
  116. package/src/ai/GenerationAnalytics.ts +461 -0
  117. package/src/ai/GenerationCache.ts +265 -0
  118. package/src/ai/GoalPlanner.ts +165 -0
  119. package/src/ai/HoloScriptGenerator.ts +580 -0
  120. package/src/ai/InfluenceMap.ts +180 -0
  121. package/src/ai/NavMesh.ts +168 -0
  122. package/src/ai/PerceptionSystem.ts +178 -0
  123. package/src/ai/PromptTemplates.ts +453 -0
  124. package/src/ai/SemanticSearchService.ts +80 -0
  125. package/src/ai/StateMachine.ts +196 -0
  126. package/src/ai/SteeringBehavior.ts +150 -0
  127. package/src/ai/SteeringBehaviors.ts +244 -0
  128. package/src/ai/TrainingDataGenerator.ts +1082 -0
  129. package/src/ai/UtilityAI.ts +145 -0
  130. package/src/ai/__tests__/AIAdapter.prod.test.ts +259 -0
  131. package/src/ai/__tests__/AIAdapter.test.ts +109 -0
  132. package/src/ai/__tests__/AICopilot.prod.test.ts +341 -0
  133. package/src/ai/__tests__/AICopilot.test.ts +178 -0
  134. package/src/ai/__tests__/AIOutputValidator.prod.test.ts +226 -0
  135. package/src/ai/__tests__/AIOutputValidator.test.ts +138 -0
  136. package/src/ai/__tests__/BTNodes.prod.test.ts +391 -0
  137. package/src/ai/__tests__/BTNodes.test.ts +263 -0
  138. package/src/ai/__tests__/BehaviorSelector.prod.test.ts +129 -0
  139. package/src/ai/__tests__/BehaviorSelector.test.ts +132 -0
  140. package/src/ai/__tests__/BehaviorTree.prod.test.ts +266 -0
  141. package/src/ai/__tests__/BehaviorTree.test.ts +216 -0
  142. package/src/ai/__tests__/Blackboard.prod.test.ts +339 -0
  143. package/src/ai/__tests__/Blackboard.test.ts +183 -0
  144. package/src/ai/__tests__/GenerationAnalytics.prod.test.ts +141 -0
  145. package/src/ai/__tests__/GenerationAnalytics.test.ts +165 -0
  146. package/src/ai/__tests__/GenerationCache.prod.test.ts +144 -0
  147. package/src/ai/__tests__/GenerationCache.test.ts +171 -0
  148. package/src/ai/__tests__/GoalPlanner.prod.test.ts +189 -0
  149. package/src/ai/__tests__/GoalPlanner.test.ts +137 -0
  150. package/src/ai/__tests__/GoalPlannerDepth.prod.test.ts +217 -0
  151. package/src/ai/__tests__/HoloScriptGenerator.test.ts +125 -0
  152. package/src/ai/__tests__/InfluenceMap.prod.test.ts +146 -0
  153. package/src/ai/__tests__/InfluenceMap.test.ts +149 -0
  154. package/src/ai/__tests__/NavMesh.prod.test.ts +141 -0
  155. package/src/ai/__tests__/NavMesh.test.ts +159 -0
  156. package/src/ai/__tests__/PerceptionSystem.prod.test.ts +135 -0
  157. package/src/ai/__tests__/PerceptionSystem.test.ts +250 -0
  158. package/src/ai/__tests__/PromptTemplates.prod.test.ts +313 -0
  159. package/src/ai/__tests__/PromptTemplates.test.ts +146 -0
  160. package/src/ai/__tests__/SemanticSearch.test.ts +37 -0
  161. package/src/ai/__tests__/StateMachine.prod.test.ts +162 -0
  162. package/src/ai/__tests__/StateMachine.test.ts +163 -0
  163. package/src/ai/__tests__/SteeringBehavior.prod.test.ts +251 -0
  164. package/src/ai/__tests__/SteeringBehavior.test.ts +135 -0
  165. package/src/ai/__tests__/SteeringBehaviors.prod.test.ts +133 -0
  166. package/src/ai/__tests__/SteeringBehaviors.test.ts +151 -0
  167. package/src/ai/__tests__/TrainingDataGenerator.prod.test.ts +286 -0
  168. package/src/ai/__tests__/TrainingDataGenerator.test.ts +286 -0
  169. package/src/ai/__tests__/UtilityAI.prod.test.ts +207 -0
  170. package/src/ai/__tests__/UtilityAI.test.ts +155 -0
  171. package/src/ai/__tests__/adapters.prod.test.ts +263 -0
  172. package/src/ai/__tests__/adapters.test.ts +320 -0
  173. package/src/ai/adapters.ts +1585 -0
  174. package/src/ai/index.ts +130 -0
  175. package/src/behavior/BehaviorPresets.ts +140 -0
  176. package/src/behavior/BehaviorTree.ts +236 -0
  177. package/src/behavior/StateMachine.ts +176 -0
  178. package/src/behavior/StateTrait.ts +67 -0
  179. package/src/behavior/index.ts +8 -0
  180. package/src/behavior.ts +8 -0
  181. package/src/board/audit.ts +284 -0
  182. package/src/board/board-ops.ts +336 -0
  183. package/src/board/board-types.ts +302 -0
  184. package/src/board/index.ts +69 -0
  185. package/src/define-agent.ts +46 -0
  186. package/src/define-team.ts +33 -0
  187. package/src/delegation.ts +265 -0
  188. package/src/distributed-claimer.ts +228 -0
  189. package/src/economy/AgentBudgetEnforcer.ts +464 -0
  190. package/src/economy/BountyManager.ts +185 -0
  191. package/src/economy/CreatorRevenueAggregator.ts +460 -0
  192. package/src/economy/InvisibleWallet.ts +82 -0
  193. package/src/economy/KnowledgeMarketplace.ts +193 -0
  194. package/src/economy/PaymentWebhookService.ts +512 -0
  195. package/src/economy/RevenueSplitter.ts +156 -0
  196. package/src/economy/SubscriptionManager.ts +546 -0
  197. package/src/economy/UnifiedBudgetOptimizer.ts +635 -0
  198. package/src/economy/UsageMeter.ts +440 -0
  199. package/src/economy/_core-stubs.ts +219 -0
  200. package/src/economy/index.ts +100 -0
  201. package/src/economy/x402-facilitator.ts +1978 -0
  202. package/src/index.ts +348 -0
  203. package/src/knowledge/__tests__/knowledge-consolidator.test.ts +444 -0
  204. package/src/knowledge/__tests__/knowledge-store-vector.test.ts +291 -0
  205. package/src/knowledge/brain.ts +167 -0
  206. package/src/knowledge/consolidation.ts +581 -0
  207. package/src/knowledge/knowledge-consolidator.ts +510 -0
  208. package/src/knowledge/knowledge-store.ts +616 -0
  209. package/src/learning/MemoryConsolidator.ts +102 -0
  210. package/src/learning/MemoryScorer.ts +69 -0
  211. package/src/learning/ProceduralCompiler.ts +45 -0
  212. package/src/learning/SemanticClusterer.ts +66 -0
  213. package/src/learning/index.ts +8 -0
  214. package/src/llm/llm-adapter.ts +159 -0
  215. package/src/mesh/index.ts +309 -0
  216. package/src/negotiation/NegotiationProtocol.ts +694 -0
  217. package/src/negotiation/NegotiationTypes.ts +473 -0
  218. package/src/negotiation/VotingMechanisms.ts +691 -0
  219. package/src/negotiation/index.ts +49 -0
  220. package/src/protocol/goal-synthesizer.ts +317 -0
  221. package/src/protocol/implementations.ts +474 -0
  222. package/src/protocol/micro-phase-decomposer.ts +299 -0
  223. package/src/protocol/micro-step-decomposer.test.ts +306 -0
  224. package/src/protocol-agent.test.ts +353 -0
  225. package/src/protocol-agent.ts +670 -0
  226. package/src/self-improve/absorb-scanner.ts +252 -0
  227. package/src/self-improve/evolution-engine.ts +149 -0
  228. package/src/self-improve/framework-absorber.ts +214 -0
  229. package/src/self-improve/index.ts +50 -0
  230. package/src/self-improve/prompt-optimizer.ts +212 -0
  231. package/src/self-improve/test-generator.ts +175 -0
  232. package/src/skill-router.ts +186 -0
  233. package/src/skills/index.ts +5 -0
  234. package/src/skills/skill-md-bridge.ts +1699 -0
  235. package/src/swarm/ACOEngine.ts +261 -0
  236. package/src/swarm/CollectiveIntelligence.ts +383 -0
  237. package/src/swarm/ContributionSynthesizer.ts +481 -0
  238. package/src/swarm/LeaderElection.ts +393 -0
  239. package/src/swarm/PSOEngine.ts +206 -0
  240. package/src/swarm/QuorumPolicy.ts +173 -0
  241. package/src/swarm/SwarmCoordinator.ts +335 -0
  242. package/src/swarm/SwarmManager.ts +442 -0
  243. package/src/swarm/SwarmMembership.ts +456 -0
  244. package/src/swarm/VotingRound.ts +255 -0
  245. package/src/swarm/__tests__/ACOEngine.prod.test.ts +164 -0
  246. package/src/swarm/__tests__/ACOEngine.test.ts +117 -0
  247. package/src/swarm/__tests__/CollectiveIntelligence.prod.test.ts +296 -0
  248. package/src/swarm/__tests__/CollectiveIntelligence.test.ts +457 -0
  249. package/src/swarm/__tests__/ContributionSynthesizer.prod.test.ts +269 -0
  250. package/src/swarm/__tests__/ContributionSynthesizer.test.ts +254 -0
  251. package/src/swarm/__tests__/LeaderElection.prod.test.ts +196 -0
  252. package/src/swarm/__tests__/LeaderElection.test.ts +151 -0
  253. package/src/swarm/__tests__/PSOEngine.prod.test.ts +162 -0
  254. package/src/swarm/__tests__/PSOEngine.test.ts +106 -0
  255. package/src/swarm/__tests__/QuorumPolicy.prod.test.ts +216 -0
  256. package/src/swarm/__tests__/QuorumPolicy.test.ts +177 -0
  257. package/src/swarm/__tests__/SwarmCoordinator.prod.test.ts +186 -0
  258. package/src/swarm/__tests__/SwarmCoordinator.test.ts +167 -0
  259. package/src/swarm/__tests__/SwarmManager.prod.test.ts +308 -0
  260. package/src/swarm/__tests__/SwarmManager.test.ts +373 -0
  261. package/src/swarm/__tests__/SwarmMembership.prod.test.ts +273 -0
  262. package/src/swarm/__tests__/SwarmMembership.test.ts +264 -0
  263. package/src/swarm/__tests__/VotingRound.prod.test.ts +233 -0
  264. package/src/swarm/__tests__/VotingRound.test.ts +174 -0
  265. package/src/swarm/analytics/SwarmInspector.ts +476 -0
  266. package/src/swarm/analytics/SwarmMetrics.ts +449 -0
  267. package/src/swarm/analytics/__tests__/SwarmInspector.prod.test.ts +366 -0
  268. package/src/swarm/analytics/__tests__/SwarmInspector.test.ts +454 -0
  269. package/src/swarm/analytics/__tests__/SwarmMetrics.prod.test.ts +254 -0
  270. package/src/swarm/analytics/__tests__/SwarmMetrics.test.ts +370 -0
  271. package/src/swarm/analytics/index.ts +7 -0
  272. package/src/swarm/index.ts +69 -0
  273. package/src/swarm/messaging/BroadcastChannel.ts +509 -0
  274. package/src/swarm/messaging/GossipProtocol.ts +565 -0
  275. package/src/swarm/messaging/SwarmEventBus.ts +443 -0
  276. package/src/swarm/messaging/__tests__/BroadcastChannel.prod.test.ts +331 -0
  277. package/src/swarm/messaging/__tests__/BroadcastChannel.test.ts +333 -0
  278. package/src/swarm/messaging/__tests__/GossipProtocol.prod.test.ts +356 -0
  279. package/src/swarm/messaging/__tests__/GossipProtocol.test.ts +437 -0
  280. package/src/swarm/messaging/__tests__/SwarmEventBus.prod.test.ts +191 -0
  281. package/src/swarm/messaging/__tests__/SwarmEventBus.test.ts +247 -0
  282. package/src/swarm/messaging/index.ts +8 -0
  283. package/src/swarm/spatial/FlockingBehavior.ts +462 -0
  284. package/src/swarm/spatial/FormationController.ts +500 -0
  285. package/src/swarm/spatial/Vector3.ts +170 -0
  286. package/src/swarm/spatial/ZoneClaiming.ts +509 -0
  287. package/src/swarm/spatial/__tests__/FlockingBehavior.prod.test.ts +239 -0
  288. package/src/swarm/spatial/__tests__/FlockingBehavior.test.ts +298 -0
  289. package/src/swarm/spatial/__tests__/FormationController.prod.test.ts +240 -0
  290. package/src/swarm/spatial/__tests__/FormationController.test.ts +297 -0
  291. package/src/swarm/spatial/__tests__/Vector3.prod.test.ts +283 -0
  292. package/src/swarm/spatial/__tests__/Vector3.test.ts +224 -0
  293. package/src/swarm/spatial/__tests__/ZoneClaiming.prod.test.ts +246 -0
  294. package/src/swarm/spatial/__tests__/ZoneClaiming.test.ts +374 -0
  295. package/src/swarm/spatial/index.ts +28 -0
  296. package/src/team.ts +1245 -0
  297. package/src/training/LRScheduler.ts +377 -0
  298. package/src/training/QualityScoringPipeline.ts +139 -0
  299. package/src/training/SoftDedup.ts +461 -0
  300. package/src/training/SparsityMonitor.ts +685 -0
  301. package/src/training/SparsityMonitorTypes.ts +209 -0
  302. package/src/training/SpatialTrainingDataGenerator.ts +1526 -0
  303. package/src/training/SpatialTrainingDataTypes.ts +216 -0
  304. package/src/training/TrainingPipelineConfig.ts +215 -0
  305. package/src/training/constants.ts +94 -0
  306. package/src/training/index.ts +138 -0
  307. package/src/training/schema.ts +147 -0
  308. package/src/training/scripts/generate-novel-use-cases-dataset.ts +272 -0
  309. package/src/training/scripts/generate-spatial-dataset.ts +521 -0
  310. package/src/training/training/data/novel-use-cases.jsonl +153 -0
  311. package/src/training/training/data/spatial-reasoning-10k.jsonl +9354 -0
  312. package/src/training/trainingmonkey/TrainingMonkeyIntegration.ts +477 -0
  313. package/src/training/trainingmonkey/TrainingMonkeyTypes.ts +230 -0
  314. package/src/training/trainingmonkey/index.ts +26 -0
  315. package/src/training/trait-mappings.ts +157 -0
  316. package/src/types/core-stubs.d.ts +113 -0
  317. package/src/types.ts +304 -0
  318. package/test-output.txt +0 -0
  319. package/test-result.json +1 -0
  320. package/tsc-errors.txt +4 -0
  321. package/tsc_output.txt +0 -0
  322. package/tsconfig.json +14 -0
  323. package/tsup-learning-esm.config.ts +12 -0
  324. package/tsup.config.ts +21 -0
  325. package/typescript-errors-2.txt +0 -0
  326. package/typescript-errors.txt +22 -0
  327. package/vitest-log-utf8.txt +268 -0
  328. package/vitest-log.txt +0 -0
  329. package/vitest.config.ts +8 -0
@@ -0,0 +1,457 @@
1
+ /**
2
+ * CollectiveIntelligence Tests
3
+ */
4
+
5
+ import { describe, it, expect, beforeEach } from 'vitest';
6
+ import { CollectiveIntelligence } from '../CollectiveIntelligence';
7
+
8
+ describe('CollectiveIntelligence', () => {
9
+ let service: CollectiveIntelligence;
10
+
11
+ beforeEach(() => {
12
+ service = new CollectiveIntelligence();
13
+ });
14
+
15
+ describe('createSession', () => {
16
+ it('should create a new hive session', () => {
17
+ const session = service.createSession('Problem Solving', 'Find optimal solution', 'agent-1');
18
+
19
+ expect(session.id).toBeDefined();
20
+ expect(session.topic).toBe('Problem Solving');
21
+ expect(session.goal).toBe('Find optimal solution');
22
+ expect(session.initiator).toBe('agent-1');
23
+ expect(session.status).toBe('active');
24
+ expect(session.participants).toContain('agent-1');
25
+ expect(session.contributions).toHaveLength(0);
26
+ });
27
+
28
+ it('should generate unique session IDs', () => {
29
+ const s1 = service.createSession('Topic 1', 'Goal 1', 'agent-1');
30
+ const s2 = service.createSession('Topic 2', 'Goal 2', 'agent-2');
31
+
32
+ expect(s1.id).not.toBe(s2.id);
33
+ });
34
+ });
35
+
36
+ describe('join', () => {
37
+ it('should add agent to session', () => {
38
+ const session = service.createSession('Topic', 'Goal', 'initiator');
39
+
40
+ service.join(session.id, 'agent-2');
41
+
42
+ const updated = service.getSession(session.id);
43
+ expect(updated?.participants).toContain('agent-2');
44
+ });
45
+
46
+ it('should not duplicate participants', () => {
47
+ const session = service.createSession('Topic', 'Goal', 'initiator');
48
+
49
+ service.join(session.id, 'agent-2');
50
+ service.join(session.id, 'agent-2');
51
+
52
+ const updated = service.getSession(session.id);
53
+ expect(updated?.participants.filter((p: any) => p === 'agent-2')).toHaveLength(1);
54
+ });
55
+
56
+ it('should throw for non-existent session', () => {
57
+ expect(() => service.join('unknown', 'agent-1')).toThrow('not found');
58
+ });
59
+
60
+ it('should throw if session is resolved', () => {
61
+ const session = service.createSession('Topic', 'Goal', 'initiator');
62
+ service.resolve(session.id, 'Final resolution');
63
+
64
+ expect(() => service.join(session.id, 'agent-2')).toThrow('resolved');
65
+ });
66
+
67
+ it('should enforce max participants', () => {
68
+ service = new CollectiveIntelligence({ maxParticipants: 2 });
69
+ const session = service.createSession('Topic', 'Goal', 'agent-1');
70
+ service.join(session.id, 'agent-2');
71
+
72
+ expect(() => service.join(session.id, 'agent-3')).toThrow('full');
73
+ });
74
+ });
75
+
76
+ describe('leave', () => {
77
+ it('should remove agent from session', () => {
78
+ const session = service.createSession('Topic', 'Goal', 'initiator');
79
+ service.join(session.id, 'agent-2');
80
+
81
+ service.leave(session.id, 'agent-2');
82
+
83
+ const updated = service.getSession(session.id);
84
+ expect(updated?.participants).not.toContain('agent-2');
85
+ });
86
+
87
+ it('should handle leaving when not a participant', () => {
88
+ const session = service.createSession('Topic', 'Goal', 'initiator');
89
+
90
+ // Should not throw
91
+ service.leave(session.id, 'non-participant');
92
+ });
93
+ });
94
+
95
+ describe('contribute', () => {
96
+ it('should add contribution to session', () => {
97
+ const session = service.createSession('Topic', 'Goal', 'agent-1');
98
+
99
+ const contribution = service.contribute(session.id, {
100
+ agentId: 'agent-1',
101
+ type: 'idea',
102
+ content: 'My brilliant idea',
103
+ confidence: 0.9,
104
+ });
105
+
106
+ expect(contribution.id).toBeDefined();
107
+ expect(contribution.timestamp).toBeGreaterThan(0);
108
+ expect(contribution.type).toBe('idea');
109
+ expect(contribution.content).toBe('My brilliant idea');
110
+
111
+ const updated = service.getSession(session.id);
112
+ expect(updated?.contributions).toHaveLength(1);
113
+ });
114
+
115
+ it('should throw if agent not a participant', () => {
116
+ const session = service.createSession('Topic', 'Goal', 'agent-1');
117
+
118
+ expect(() =>
119
+ service.contribute(session.id, {
120
+ agentId: 'outsider',
121
+ type: 'idea',
122
+ content: 'Attempt to contribute',
123
+ confidence: 0.5,
124
+ })
125
+ ).toThrow('not a participant');
126
+ });
127
+
128
+ it('should throw if session is not active', () => {
129
+ const session = service.createSession('Topic', 'Goal', 'agent-1');
130
+ service.closeSession(session.id);
131
+
132
+ expect(() =>
133
+ service.contribute(session.id, {
134
+ agentId: 'agent-1',
135
+ type: 'idea',
136
+ content: 'Late contribution',
137
+ confidence: 0.5,
138
+ })
139
+ ).toThrow('closed');
140
+ });
141
+
142
+ it('should support all contribution types', () => {
143
+ const session = service.createSession('Topic', 'Goal', 'agent-1');
144
+
145
+ const idea = service.contribute(session.id, {
146
+ agentId: 'agent-1',
147
+ type: 'idea',
148
+ content: 'Idea',
149
+ confidence: 0.8,
150
+ });
151
+ const critique = service.contribute(session.id, {
152
+ agentId: 'agent-1',
153
+ type: 'critique',
154
+ content: 'Critique',
155
+ confidence: 0.7,
156
+ });
157
+ const consensus = service.contribute(session.id, {
158
+ agentId: 'agent-1',
159
+ type: 'consensus',
160
+ content: 'Consensus',
161
+ confidence: 0.9,
162
+ });
163
+ const solution = service.contribute(session.id, {
164
+ agentId: 'agent-1',
165
+ type: 'solution',
166
+ content: 'Solution',
167
+ confidence: 0.95,
168
+ });
169
+
170
+ expect(idea.type).toBe('idea');
171
+ expect(critique.type).toBe('critique');
172
+ expect(consensus.type).toBe('consensus');
173
+ expect(solution.type).toBe('solution');
174
+ });
175
+ });
176
+
177
+ describe('vote', () => {
178
+ it('should record votes on contributions', () => {
179
+ const session = service.createSession('Topic', 'Goal', 'agent-1');
180
+ service.join(session.id, 'agent-2');
181
+
182
+ const contribution = service.contribute(session.id, {
183
+ agentId: 'agent-1',
184
+ type: 'idea',
185
+ content: 'Vote on this',
186
+ confidence: 0.8,
187
+ });
188
+
189
+ service.vote(session.id, contribution.id, 'agent-2', 'support');
190
+
191
+ const results = service.getVotingResults(session.id);
192
+ expect(results[0].supportVotes).toBe(1);
193
+ });
194
+
195
+ it('should throw if voter is not a participant', () => {
196
+ const session = service.createSession('Topic', 'Goal', 'agent-1');
197
+ const contribution = service.contribute(session.id, {
198
+ agentId: 'agent-1',
199
+ type: 'idea',
200
+ content: 'Content',
201
+ confidence: 0.8,
202
+ });
203
+
204
+ expect(() => service.vote(session.id, contribution.id, 'outsider', 'support')).toThrow(
205
+ 'not a participant'
206
+ );
207
+ });
208
+ });
209
+
210
+ describe('synthesize', () => {
211
+ it('should return empty result with too few contributions', () => {
212
+ service = new CollectiveIntelligence({ synthesisMinContributions: 3 });
213
+ const session = service.createSession('Topic', 'Goal', 'agent-1');
214
+
215
+ service.contribute(session.id, {
216
+ agentId: 'agent-1',
217
+ type: 'idea',
218
+ content: 'Single idea',
219
+ confidence: 0.8,
220
+ });
221
+
222
+ const result = service.synthesize(session.id);
223
+ expect(result.synthesizedContent).toBe('');
224
+ });
225
+
226
+ it('should synthesize contributions', () => {
227
+ service = new CollectiveIntelligence({ synthesisMinContributions: 2 });
228
+ const session = service.createSession('Topic', 'Goal', 'agent-1');
229
+
230
+ service.contribute(session.id, {
231
+ agentId: 'agent-1',
232
+ type: 'idea',
233
+ content: 'First idea',
234
+ confidence: 0.8,
235
+ });
236
+ service.contribute(session.id, {
237
+ agentId: 'agent-1',
238
+ type: 'idea',
239
+ content: 'Second idea',
240
+ confidence: 0.9,
241
+ });
242
+
243
+ const result = service.synthesize(session.id);
244
+ expect(result.synthesizedContent.length).toBeGreaterThan(0);
245
+ expect(result.metadata.totalContributions).toBe(2);
246
+ });
247
+
248
+ it('should throw for non-existent session', () => {
249
+ expect(() => service.synthesize('unknown')).toThrow('not found');
250
+ });
251
+ });
252
+
253
+ describe('resolve', () => {
254
+ it('should mark session as resolved', () => {
255
+ const session = service.createSession('Topic', 'Goal', 'agent-1');
256
+
257
+ service.resolve(session.id, 'Final decision reached');
258
+
259
+ const updated = service.getSession(session.id);
260
+ expect(updated?.status).toBe('resolved');
261
+ expect(updated?.resolution).toBe('Final decision reached');
262
+ });
263
+ });
264
+
265
+ describe('getActiveSessions', () => {
266
+ it('should return only active sessions', () => {
267
+ const s1 = service.createSession('Topic 1', 'Goal 1', 'agent-1');
268
+ const s2 = service.createSession('Topic 2', 'Goal 2', 'agent-2');
269
+ service.closeSession(s1.id);
270
+
271
+ const active = service.getActiveSessions();
272
+ expect(active).toHaveLength(1);
273
+ expect(active[0].id).toBe(s2.id);
274
+ });
275
+ });
276
+
277
+ describe('getTopContribution', () => {
278
+ it('should return highest voted contribution', () => {
279
+ const session = service.createSession('Topic', 'Goal', 'agent-1');
280
+ service.join(session.id, 'agent-2');
281
+ service.join(session.id, 'agent-3');
282
+
283
+ const c1 = service.contribute(session.id, {
284
+ agentId: 'agent-1',
285
+ type: 'idea',
286
+ content: 'Idea 1',
287
+ confidence: 0.8,
288
+ });
289
+ const c2 = service.contribute(session.id, {
290
+ agentId: 'agent-2',
291
+ type: 'idea',
292
+ content: 'Idea 2',
293
+ confidence: 0.9,
294
+ });
295
+
296
+ service.vote(session.id, c1.id, 'agent-2', 'support');
297
+ service.vote(session.id, c2.id, 'agent-1', 'support');
298
+ service.vote(session.id, c2.id, 'agent-3', 'support');
299
+
300
+ const top = service.getTopContribution(session.id);
301
+ expect(top?.id).toBe(c2.id);
302
+ });
303
+ });
304
+
305
+ describe('getSessionStats', () => {
306
+ it('should compute session statistics', () => {
307
+ const session = service.createSession('Topic', 'Goal', 'agent-1');
308
+ service.join(session.id, 'agent-2');
309
+
310
+ service.contribute(session.id, {
311
+ agentId: 'agent-1',
312
+ type: 'idea',
313
+ content: 'Idea',
314
+ confidence: 0.8,
315
+ });
316
+ service.contribute(session.id, {
317
+ agentId: 'agent-1',
318
+ type: 'solution',
319
+ content: 'Solution',
320
+ confidence: 0.9,
321
+ });
322
+
323
+ const stats = service.getSessionStats(session.id);
324
+
325
+ expect(stats?.participantCount).toBe(2);
326
+ expect(stats?.contributionCount).toBe(2);
327
+ expect(stats?.contributionsByType.idea).toBe(1);
328
+ expect(stats?.contributionsByType.solution).toBe(1);
329
+ expect(stats?.averageConfidence).toBeCloseTo(0.85, 2);
330
+ });
331
+
332
+ it('should return undefined for non-existent session', () => {
333
+ const stats = service.getSessionStats('unknown');
334
+ expect(stats).toBeUndefined();
335
+ });
336
+ });
337
+
338
+ describe('checkForConsensus', () => {
339
+ it('should auto-resolve when consensus reached', () => {
340
+ service = new CollectiveIntelligence({
341
+ autoCloseOnResolution: true,
342
+ votingThreshold: 0.5,
343
+ });
344
+ const session = service.createSession('Topic', 'Goal', 'agent-1');
345
+ service.join(session.id, 'agent-2');
346
+ service.join(session.id, 'agent-3');
347
+
348
+ const contribution = service.contribute(session.id, {
349
+ agentId: 'agent-1',
350
+ type: 'solution',
351
+ content: 'The solution',
352
+ confidence: 0.9,
353
+ });
354
+
355
+ service.vote(session.id, contribution.id, 'agent-2', 'support');
356
+ service.vote(session.id, contribution.id, 'agent-3', 'support');
357
+
358
+ const resolved = service.checkForConsensus(session.id);
359
+ expect(resolved).toBe(true);
360
+
361
+ const updated = service.getSession(session.id);
362
+ expect(updated?.status).toBe('resolved');
363
+ });
364
+
365
+ it('should not resolve without consensus', () => {
366
+ service = new CollectiveIntelligence({ votingThreshold: 0.8 });
367
+ const session = service.createSession('Topic', 'Goal', 'agent-1');
368
+ service.join(session.id, 'agent-2');
369
+ service.join(session.id, 'agent-3');
370
+
371
+ const contribution = service.contribute(session.id, {
372
+ agentId: 'agent-1',
373
+ type: 'idea',
374
+ content: 'Controversial idea',
375
+ confidence: 0.8,
376
+ });
377
+
378
+ service.vote(session.id, contribution.id, 'agent-2', 'support');
379
+ service.vote(session.id, contribution.id, 'agent-3', 'oppose');
380
+
381
+ const resolved = service.checkForConsensus(session.id);
382
+ expect(resolved).toBe(false);
383
+ });
384
+ });
385
+
386
+ describe('getAgentContributions', () => {
387
+ it('should filter contributions by agent', () => {
388
+ const session = service.createSession('Topic', 'Goal', 'agent-1');
389
+ service.join(session.id, 'agent-2');
390
+
391
+ service.contribute(session.id, {
392
+ agentId: 'agent-1',
393
+ type: 'idea',
394
+ content: 'A1 idea',
395
+ confidence: 0.8,
396
+ });
397
+ service.contribute(session.id, {
398
+ agentId: 'agent-2',
399
+ type: 'idea',
400
+ content: 'A2 idea',
401
+ confidence: 0.9,
402
+ });
403
+ service.contribute(session.id, {
404
+ agentId: 'agent-1',
405
+ type: 'critique',
406
+ content: 'A1 critique',
407
+ confidence: 0.7,
408
+ });
409
+
410
+ const agent1Contribs = service.getAgentContributions(session.id, 'agent-1');
411
+ expect(agent1Contribs).toHaveLength(2);
412
+ expect(agent1Contribs.every((c: any) => c.agentId === 'agent-1')).toBe(true);
413
+ });
414
+
415
+ it('should return empty for non-existent session', () => {
416
+ const contribs = service.getAgentContributions('unknown', 'agent-1');
417
+ expect(contribs).toHaveLength(0);
418
+ });
419
+ });
420
+
421
+ describe('findSimilarContributions', () => {
422
+ it('should find similar contributions in session', () => {
423
+ const session = service.createSession('Topic', 'Goal', 'agent-1');
424
+
425
+ const c1 = service.contribute(session.id, {
426
+ agentId: 'agent-1',
427
+ type: 'idea',
428
+ content: 'distributed caching performance optimization layer',
429
+ confidence: 0.8,
430
+ });
431
+
432
+ service.contribute(session.id, {
433
+ agentId: 'agent-1',
434
+ type: 'idea',
435
+ content: 'caching distributed system performance optimization',
436
+ confidence: 0.9,
437
+ });
438
+
439
+ service.contribute(session.id, {
440
+ agentId: 'agent-1',
441
+ type: 'idea',
442
+ content: 'database indexing query strategies foreign keys',
443
+ confidence: 0.7,
444
+ });
445
+
446
+ const similar = service.findSimilarContributions(session.id, c1.id);
447
+
448
+ // Should find at least the similar caching contribution
449
+ expect(similar.length).toBeGreaterThanOrEqual(1);
450
+ });
451
+
452
+ it('should return empty for non-existent session', () => {
453
+ const similar = service.findSimilarContributions('unknown', 'c1');
454
+ expect(similar).toHaveLength(0);
455
+ });
456
+ });
457
+ });