lex-agentic-social 0.1.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 (235) hide show
  1. checksums.yaml +7 -0
  2. data/CHANGELOG.md +12 -0
  3. data/Gemfile +5 -0
  4. data/LICENSE +21 -0
  5. data/README.md +13 -0
  6. data/lex-agentic-social.gemspec +30 -0
  7. data/lib/legion/extensions/agentic/social/apprenticeship/client.rb +28 -0
  8. data/lib/legion/extensions/agentic/social/apprenticeship/helpers/apprenticeship.rb +90 -0
  9. data/lib/legion/extensions/agentic/social/apprenticeship/helpers/apprenticeship_engine.rb +109 -0
  10. data/lib/legion/extensions/agentic/social/apprenticeship/helpers/apprenticeship_model.rb +93 -0
  11. data/lib/legion/extensions/agentic/social/apprenticeship/runners/cognitive_apprenticeship.rb +112 -0
  12. data/lib/legion/extensions/agentic/social/apprenticeship/version.rb +13 -0
  13. data/lib/legion/extensions/agentic/social/apprenticeship.rb +19 -0
  14. data/lib/legion/extensions/agentic/social/conflict/actors/stale_check.rb +45 -0
  15. data/lib/legion/extensions/agentic/social/conflict/client.rb +27 -0
  16. data/lib/legion/extensions/agentic/social/conflict/helpers/conflict_log.rb +70 -0
  17. data/lib/legion/extensions/agentic/social/conflict/helpers/llm_enhancer.rb +130 -0
  18. data/lib/legion/extensions/agentic/social/conflict/helpers/severity.rb +47 -0
  19. data/lib/legion/extensions/agentic/social/conflict/runners/conflict.rb +112 -0
  20. data/lib/legion/extensions/agentic/social/conflict/version.rb +13 -0
  21. data/lib/legion/extensions/agentic/social/conflict.rb +19 -0
  22. data/lib/legion/extensions/agentic/social/conscience/client.rb +26 -0
  23. data/lib/legion/extensions/agentic/social/conscience/helpers/constants.rb +53 -0
  24. data/lib/legion/extensions/agentic/social/conscience/helpers/moral_evaluator.rb +178 -0
  25. data/lib/legion/extensions/agentic/social/conscience/helpers/moral_store.rb +116 -0
  26. data/lib/legion/extensions/agentic/social/conscience/runners/conscience.rb +117 -0
  27. data/lib/legion/extensions/agentic/social/conscience/version.rb +13 -0
  28. data/lib/legion/extensions/agentic/social/conscience.rb +19 -0
  29. data/lib/legion/extensions/agentic/social/consent/actors/tier_evaluation.rb +45 -0
  30. data/lib/legion/extensions/agentic/social/consent/client.rb +27 -0
  31. data/lib/legion/extensions/agentic/social/consent/helpers/consent_map.rb +199 -0
  32. data/lib/legion/extensions/agentic/social/consent/helpers/tiers.rb +54 -0
  33. data/lib/legion/extensions/agentic/social/consent/local_migrations/20260316000010_create_consent_domains.rb +16 -0
  34. data/lib/legion/extensions/agentic/social/consent/runners/consent.rb +228 -0
  35. data/lib/legion/extensions/agentic/social/consent/version.rb +13 -0
  36. data/lib/legion/extensions/agentic/social/consent.rb +25 -0
  37. data/lib/legion/extensions/agentic/social/entrainment/client.rb +19 -0
  38. data/lib/legion/extensions/agentic/social/entrainment/helpers/constants.rb +40 -0
  39. data/lib/legion/extensions/agentic/social/entrainment/helpers/entrainment_engine.rb +120 -0
  40. data/lib/legion/extensions/agentic/social/entrainment/helpers/pairing.rb +86 -0
  41. data/lib/legion/extensions/agentic/social/entrainment/runners/cognitive_entrainment.rb +89 -0
  42. data/lib/legion/extensions/agentic/social/entrainment/version.rb +13 -0
  43. data/lib/legion/extensions/agentic/social/entrainment.rb +19 -0
  44. data/lib/legion/extensions/agentic/social/governance/actors/shadow_ai_scan.rb +19 -0
  45. data/lib/legion/extensions/agentic/social/governance/actors/vote_timeout.rb +45 -0
  46. data/lib/legion/extensions/agentic/social/governance/client.rb +27 -0
  47. data/lib/legion/extensions/agentic/social/governance/helpers/layers.rb +40 -0
  48. data/lib/legion/extensions/agentic/social/governance/helpers/proposal.rb +94 -0
  49. data/lib/legion/extensions/agentic/social/governance/runners/governance.rb +87 -0
  50. data/lib/legion/extensions/agentic/social/governance/runners/shadow_ai.rb +93 -0
  51. data/lib/legion/extensions/agentic/social/governance/version.rb +13 -0
  52. data/lib/legion/extensions/agentic/social/governance.rb +20 -0
  53. data/lib/legion/extensions/agentic/social/joint_attention/actors/decay.rb +45 -0
  54. data/lib/legion/extensions/agentic/social/joint_attention/client.rb +28 -0
  55. data/lib/legion/extensions/agentic/social/joint_attention/helpers/attention_target.rb +124 -0
  56. data/lib/legion/extensions/agentic/social/joint_attention/helpers/constants.rb +34 -0
  57. data/lib/legion/extensions/agentic/social/joint_attention/helpers/joint_focus_manager.rb +157 -0
  58. data/lib/legion/extensions/agentic/social/joint_attention/runners/joint_attention.rb +88 -0
  59. data/lib/legion/extensions/agentic/social/joint_attention/version.rb +13 -0
  60. data/lib/legion/extensions/agentic/social/joint_attention.rb +20 -0
  61. data/lib/legion/extensions/agentic/social/mentalizing/actors/decay.rb +45 -0
  62. data/lib/legion/extensions/agentic/social/mentalizing/client.rb +28 -0
  63. data/lib/legion/extensions/agentic/social/mentalizing/helpers/belief_attribution.rb +58 -0
  64. data/lib/legion/extensions/agentic/social/mentalizing/helpers/constants.rb +33 -0
  65. data/lib/legion/extensions/agentic/social/mentalizing/helpers/mental_model.rb +137 -0
  66. data/lib/legion/extensions/agentic/social/mentalizing/runners/mentalizing.rb +93 -0
  67. data/lib/legion/extensions/agentic/social/mentalizing/version.rb +13 -0
  68. data/lib/legion/extensions/agentic/social/mentalizing.rb +20 -0
  69. data/lib/legion/extensions/agentic/social/mirror/client.rb +33 -0
  70. data/lib/legion/extensions/agentic/social/mirror/helpers/constants.rb +65 -0
  71. data/lib/legion/extensions/agentic/social/mirror/helpers/mirror_engine.rb +132 -0
  72. data/lib/legion/extensions/agentic/social/mirror/helpers/mirror_event.rb +46 -0
  73. data/lib/legion/extensions/agentic/social/mirror/helpers/simulation.rb +43 -0
  74. data/lib/legion/extensions/agentic/social/mirror/runners/observe.rb +52 -0
  75. data/lib/legion/extensions/agentic/social/mirror/runners/resonance.rb +79 -0
  76. data/lib/legion/extensions/agentic/social/mirror/runners/simulate.rb +63 -0
  77. data/lib/legion/extensions/agentic/social/mirror/version.rb +13 -0
  78. data/lib/legion/extensions/agentic/social/mirror.rb +22 -0
  79. data/lib/legion/extensions/agentic/social/mirror_system/actors/decay.rb +45 -0
  80. data/lib/legion/extensions/agentic/social/mirror_system/client.rb +28 -0
  81. data/lib/legion/extensions/agentic/social/mirror_system/helpers/constants.rb +62 -0
  82. data/lib/legion/extensions/agentic/social/mirror_system/helpers/mirror_system.rb +162 -0
  83. data/lib/legion/extensions/agentic/social/mirror_system/helpers/observed_behavior.rb +67 -0
  84. data/lib/legion/extensions/agentic/social/mirror_system/runners/mirror.rb +99 -0
  85. data/lib/legion/extensions/agentic/social/mirror_system/version.rb +13 -0
  86. data/lib/legion/extensions/agentic/social/mirror_system.rb +20 -0
  87. data/lib/legion/extensions/agentic/social/moral_reasoning/client.rb +19 -0
  88. data/lib/legion/extensions/agentic/social/moral_reasoning/helpers/constants.rb +49 -0
  89. data/lib/legion/extensions/agentic/social/moral_reasoning/helpers/dilemma.rb +68 -0
  90. data/lib/legion/extensions/agentic/social/moral_reasoning/helpers/llm_enhancer.rb +140 -0
  91. data/lib/legion/extensions/agentic/social/moral_reasoning/helpers/moral_engine.rb +239 -0
  92. data/lib/legion/extensions/agentic/social/moral_reasoning/helpers/moral_foundation.rb +45 -0
  93. data/lib/legion/extensions/agentic/social/moral_reasoning/runners/moral_reasoning.rb +121 -0
  94. data/lib/legion/extensions/agentic/social/moral_reasoning/version.rb +13 -0
  95. data/lib/legion/extensions/agentic/social/moral_reasoning.rb +21 -0
  96. data/lib/legion/extensions/agentic/social/perspective_shifting/client.rb +29 -0
  97. data/lib/legion/extensions/agentic/social/perspective_shifting/helpers/constants.rb +67 -0
  98. data/lib/legion/extensions/agentic/social/perspective_shifting/helpers/perspective.rb +45 -0
  99. data/lib/legion/extensions/agentic/social/perspective_shifting/helpers/perspective_view.rb +57 -0
  100. data/lib/legion/extensions/agentic/social/perspective_shifting/helpers/shifting_engine.rb +166 -0
  101. data/lib/legion/extensions/agentic/social/perspective_shifting/runners/perspective_shifting.rb +167 -0
  102. data/lib/legion/extensions/agentic/social/perspective_shifting/version.rb +13 -0
  103. data/lib/legion/extensions/agentic/social/perspective_shifting.rb +20 -0
  104. data/lib/legion/extensions/agentic/social/social/client.rb +25 -0
  105. data/lib/legion/extensions/agentic/social/social/helpers/constants.rb +84 -0
  106. data/lib/legion/extensions/agentic/social/social/helpers/social_graph.rb +172 -0
  107. data/lib/legion/extensions/agentic/social/social/runners/social.rb +146 -0
  108. data/lib/legion/extensions/agentic/social/social/version.rb +13 -0
  109. data/lib/legion/extensions/agentic/social/social.rb +18 -0
  110. data/lib/legion/extensions/agentic/social/social_learning/client.rb +25 -0
  111. data/lib/legion/extensions/agentic/social/social_learning/helpers/constants.rb +42 -0
  112. data/lib/legion/extensions/agentic/social/social_learning/helpers/model_agent.rb +82 -0
  113. data/lib/legion/extensions/agentic/social/social_learning/helpers/observed_behavior.rb +61 -0
  114. data/lib/legion/extensions/agentic/social/social_learning/helpers/social_learning_engine.rb +134 -0
  115. data/lib/legion/extensions/agentic/social/social_learning/runners/social_learning.rb +105 -0
  116. data/lib/legion/extensions/agentic/social/social_learning/version.rb +13 -0
  117. data/lib/legion/extensions/agentic/social/social_learning.rb +20 -0
  118. data/lib/legion/extensions/agentic/social/symbiosis/client.rb +23 -0
  119. data/lib/legion/extensions/agentic/social/symbiosis/helpers/constants.rb +50 -0
  120. data/lib/legion/extensions/agentic/social/symbiosis/helpers/ecosystem.rb +113 -0
  121. data/lib/legion/extensions/agentic/social/symbiosis/helpers/symbiosis_engine.rb +104 -0
  122. data/lib/legion/extensions/agentic/social/symbiosis/helpers/symbiotic_bond.rb +112 -0
  123. data/lib/legion/extensions/agentic/social/symbiosis/runners/cognitive_symbiosis.rb +101 -0
  124. data/lib/legion/extensions/agentic/social/symbiosis/version.rb +13 -0
  125. data/lib/legion/extensions/agentic/social/symbiosis.rb +22 -0
  126. data/lib/legion/extensions/agentic/social/theory_of_mind/client.rb +26 -0
  127. data/lib/legion/extensions/agentic/social/theory_of_mind/helpers/agent_model.rb +173 -0
  128. data/lib/legion/extensions/agentic/social/theory_of_mind/helpers/constants.rb +70 -0
  129. data/lib/legion/extensions/agentic/social/theory_of_mind/helpers/mental_state_tracker.rb +169 -0
  130. data/lib/legion/extensions/agentic/social/theory_of_mind/runners/theory_of_mind.rb +159 -0
  131. data/lib/legion/extensions/agentic/social/theory_of_mind/version.rb +13 -0
  132. data/lib/legion/extensions/agentic/social/theory_of_mind.rb +19 -0
  133. data/lib/legion/extensions/agentic/social/trust/actors/decay.rb +45 -0
  134. data/lib/legion/extensions/agentic/social/trust/client.rb +27 -0
  135. data/lib/legion/extensions/agentic/social/trust/helpers/trust_map.rb +160 -0
  136. data/lib/legion/extensions/agentic/social/trust/helpers/trust_model.rb +52 -0
  137. data/lib/legion/extensions/agentic/social/trust/local_migrations/20260316000020_create_trust_entries.rb +23 -0
  138. data/lib/legion/extensions/agentic/social/trust/runners/trust.rb +80 -0
  139. data/lib/legion/extensions/agentic/social/trust/version.rb +13 -0
  140. data/lib/legion/extensions/agentic/social/trust.rb +25 -0
  141. data/lib/legion/extensions/agentic/social/version.rb +11 -0
  142. data/lib/legion/extensions/agentic/social.rb +34 -0
  143. data/spec/legion/extensions/agentic/social/apprenticeship/client_spec.rb +20 -0
  144. data/spec/legion/extensions/agentic/social/apprenticeship/cognitive_apprenticeship_spec.rb +11 -0
  145. data/spec/legion/extensions/agentic/social/apprenticeship/helpers/apprenticeship_engine_spec.rb +146 -0
  146. data/spec/legion/extensions/agentic/social/apprenticeship/helpers/apprenticeship_model_spec.rb +124 -0
  147. data/spec/legion/extensions/agentic/social/apprenticeship/helpers/apprenticeship_spec.rb +136 -0
  148. data/spec/legion/extensions/agentic/social/apprenticeship/runners/cognitive_apprenticeship_spec.rb +154 -0
  149. data/spec/legion/extensions/agentic/social/conflict/actors/stale_check_spec.rb +45 -0
  150. data/spec/legion/extensions/agentic/social/conflict/client_spec.rb +15 -0
  151. data/spec/legion/extensions/agentic/social/conflict/helpers/conflict_log_spec.rb +232 -0
  152. data/spec/legion/extensions/agentic/social/conflict/helpers/llm_enhancer_spec.rb +189 -0
  153. data/spec/legion/extensions/agentic/social/conflict/helpers/severity_spec.rb +215 -0
  154. data/spec/legion/extensions/agentic/social/conflict/runners/conflict_spec.rb +151 -0
  155. data/spec/legion/extensions/agentic/social/conscience/client_spec.rb +58 -0
  156. data/spec/legion/extensions/agentic/social/conscience/helpers/constants_spec.rb +124 -0
  157. data/spec/legion/extensions/agentic/social/conscience/helpers/moral_evaluator_spec.rb +253 -0
  158. data/spec/legion/extensions/agentic/social/conscience/helpers/moral_store_spec.rb +230 -0
  159. data/spec/legion/extensions/agentic/social/conscience/runners/conscience_spec.rb +239 -0
  160. data/spec/legion/extensions/agentic/social/consent/actors/tier_evaluation_spec.rb +46 -0
  161. data/spec/legion/extensions/agentic/social/consent/client_spec.rb +33 -0
  162. data/spec/legion/extensions/agentic/social/consent/helpers/tiers_spec.rb +49 -0
  163. data/spec/legion/extensions/agentic/social/consent/local_persistence_spec.rb +234 -0
  164. data/spec/legion/extensions/agentic/social/consent/runners/consent_spec.rb +224 -0
  165. data/spec/legion/extensions/agentic/social/entrainment/client_spec.rb +21 -0
  166. data/spec/legion/extensions/agentic/social/entrainment/helpers/entrainment_engine_spec.rb +116 -0
  167. data/spec/legion/extensions/agentic/social/entrainment/helpers/pairing_spec.rb +103 -0
  168. data/spec/legion/extensions/agentic/social/entrainment/runners/cognitive_entrainment_spec.rb +87 -0
  169. data/spec/legion/extensions/agentic/social/governance/actors/vote_timeout_spec.rb +45 -0
  170. data/spec/legion/extensions/agentic/social/governance/client_spec.rb +14 -0
  171. data/spec/legion/extensions/agentic/social/governance/helpers/layers_spec.rb +190 -0
  172. data/spec/legion/extensions/agentic/social/governance/helpers/proposal_spec.rb +188 -0
  173. data/spec/legion/extensions/agentic/social/governance/runners/governance_spec.rb +101 -0
  174. data/spec/legion/extensions/agentic/social/governance/runners/shadow_ai_spec.rb +65 -0
  175. data/spec/legion/extensions/agentic/social/joint_attention/client_spec.rb +36 -0
  176. data/spec/legion/extensions/agentic/social/joint_attention/helpers/attention_target_spec.rb +258 -0
  177. data/spec/legion/extensions/agentic/social/joint_attention/helpers/joint_focus_manager_spec.rb +238 -0
  178. data/spec/legion/extensions/agentic/social/joint_attention/runners/joint_attention_spec.rb +228 -0
  179. data/spec/legion/extensions/agentic/social/mentalizing/client_spec.rb +19 -0
  180. data/spec/legion/extensions/agentic/social/mentalizing/helpers/belief_attribution_spec.rb +108 -0
  181. data/spec/legion/extensions/agentic/social/mentalizing/helpers/mental_model_spec.rb +179 -0
  182. data/spec/legion/extensions/agentic/social/mentalizing/runners/mentalizing_spec.rb +162 -0
  183. data/spec/legion/extensions/agentic/social/mirror/client_spec.rb +92 -0
  184. data/spec/legion/extensions/agentic/social/mirror/helpers/constants_spec.rb +123 -0
  185. data/spec/legion/extensions/agentic/social/mirror/helpers/mirror_engine_spec.rb +217 -0
  186. data/spec/legion/extensions/agentic/social/mirror/helpers/mirror_event_spec.rb +102 -0
  187. data/spec/legion/extensions/agentic/social/mirror/helpers/simulation_spec.rb +100 -0
  188. data/spec/legion/extensions/agentic/social/mirror/runners/observe_spec.rb +77 -0
  189. data/spec/legion/extensions/agentic/social/mirror/runners/resonance_spec.rb +123 -0
  190. data/spec/legion/extensions/agentic/social/mirror/runners/simulate_spec.rb +103 -0
  191. data/spec/legion/extensions/agentic/social/mirror_system/client_spec.rb +40 -0
  192. data/spec/legion/extensions/agentic/social/mirror_system/helpers/mirror_system_spec.rb +144 -0
  193. data/spec/legion/extensions/agentic/social/mirror_system/helpers/observed_behavior_spec.rb +98 -0
  194. data/spec/legion/extensions/agentic/social/mirror_system/runners/mirror_spec.rb +122 -0
  195. data/spec/legion/extensions/agentic/social/moral_reasoning/client_spec.rb +34 -0
  196. data/spec/legion/extensions/agentic/social/moral_reasoning/helpers/dilemma_spec.rb +108 -0
  197. data/spec/legion/extensions/agentic/social/moral_reasoning/helpers/llm_enhancer_spec.rb +232 -0
  198. data/spec/legion/extensions/agentic/social/moral_reasoning/helpers/moral_engine_spec.rb +266 -0
  199. data/spec/legion/extensions/agentic/social/moral_reasoning/helpers/moral_foundation_spec.rb +70 -0
  200. data/spec/legion/extensions/agentic/social/moral_reasoning/runners/moral_reasoning_spec.rb +275 -0
  201. data/spec/legion/extensions/agentic/social/perspective_shifting/client_spec.rb +30 -0
  202. data/spec/legion/extensions/agentic/social/perspective_shifting/helpers/constants_spec.rb +99 -0
  203. data/spec/legion/extensions/agentic/social/perspective_shifting/helpers/perspective_spec.rb +77 -0
  204. data/spec/legion/extensions/agentic/social/perspective_shifting/helpers/perspective_view_spec.rb +105 -0
  205. data/spec/legion/extensions/agentic/social/perspective_shifting/helpers/shifting_engine_spec.rb +246 -0
  206. data/spec/legion/extensions/agentic/social/perspective_shifting/runners/perspective_shifting_spec.rb +277 -0
  207. data/spec/legion/extensions/agentic/social/social/client_spec.rb +72 -0
  208. data/spec/legion/extensions/agentic/social/social/helpers/constants_spec.rb +99 -0
  209. data/spec/legion/extensions/agentic/social/social/helpers/social_graph_spec.rb +322 -0
  210. data/spec/legion/extensions/agentic/social/social/runners/social_spec.rb +220 -0
  211. data/spec/legion/extensions/agentic/social/social_learning/client_spec.rb +25 -0
  212. data/spec/legion/extensions/agentic/social/social_learning/helpers/constants_spec.rb +44 -0
  213. data/spec/legion/extensions/agentic/social/social_learning/helpers/model_agent_spec.rb +120 -0
  214. data/spec/legion/extensions/agentic/social/social_learning/helpers/observed_behavior_spec.rb +81 -0
  215. data/spec/legion/extensions/agentic/social/social_learning/helpers/social_learning_engine_spec.rb +196 -0
  216. data/spec/legion/extensions/agentic/social/social_learning/runners/social_learning_spec.rb +150 -0
  217. data/spec/legion/extensions/agentic/social/symbiosis/client_spec.rb +45 -0
  218. data/spec/legion/extensions/agentic/social/symbiosis/helpers/constants_spec.rb +73 -0
  219. data/spec/legion/extensions/agentic/social/symbiosis/helpers/ecosystem_spec.rb +185 -0
  220. data/spec/legion/extensions/agentic/social/symbiosis/helpers/symbiosis_engine_spec.rb +182 -0
  221. data/spec/legion/extensions/agentic/social/symbiosis/helpers/symbiotic_bond_spec.rb +209 -0
  222. data/spec/legion/extensions/agentic/social/symbiosis/runners/cognitive_symbiosis_spec.rb +182 -0
  223. data/spec/legion/extensions/agentic/social/theory_of_mind/client_spec.rb +63 -0
  224. data/spec/legion/extensions/agentic/social/theory_of_mind/helpers/agent_model_spec.rb +244 -0
  225. data/spec/legion/extensions/agentic/social/theory_of_mind/helpers/constants_spec.rb +71 -0
  226. data/spec/legion/extensions/agentic/social/theory_of_mind/helpers/mental_state_tracker_spec.rb +228 -0
  227. data/spec/legion/extensions/agentic/social/theory_of_mind/runners/theory_of_mind_spec.rb +221 -0
  228. data/spec/legion/extensions/agentic/social/trust/actors/decay_spec.rb +62 -0
  229. data/spec/legion/extensions/agentic/social/trust/client_spec.rb +17 -0
  230. data/spec/legion/extensions/agentic/social/trust/helpers/trust_map_spec.rb +299 -0
  231. data/spec/legion/extensions/agentic/social/trust/helpers/trust_model_spec.rb +179 -0
  232. data/spec/legion/extensions/agentic/social/trust/local_persistence_spec.rb +359 -0
  233. data/spec/legion/extensions/agentic/social/trust/runners/trust_spec.rb +84 -0
  234. data/spec/spec_helper.rb +54 -0
  235. metadata +319 -0
@@ -0,0 +1,228 @@
1
+ # frozen_string_literal: true
2
+
3
+ require 'spec_helper'
4
+
5
+ RSpec.describe Legion::Extensions::Agentic::Social::TheoryOfMind::Helpers::MentalStateTracker do
6
+ subject(:tracker) { described_class.new }
7
+
8
+ describe '#initialize' do
9
+ it 'starts with empty agent models' do
10
+ expect(tracker.agent_models).to be_empty
11
+ end
12
+
13
+ it 'starts with empty prediction log' do
14
+ expect(tracker.prediction_log).to be_empty
15
+ end
16
+ end
17
+
18
+ describe '#model_for' do
19
+ it 'creates a new model for unknown agent' do
20
+ model = tracker.model_for(:a1)
21
+ expect(model).to be_a(Legion::Extensions::Agentic::Social::TheoryOfMind::Helpers::AgentModel)
22
+ expect(model.agent_id).to eq(:a1)
23
+ end
24
+
25
+ it 'returns the same model on repeat call' do
26
+ model1 = tracker.model_for(:a1)
27
+ model2 = tracker.model_for(:a1)
28
+ expect(model1).to equal(model2)
29
+ end
30
+
31
+ it 'trims models beyond MAX_AGENT_MODELS' do
32
+ max = Legion::Extensions::Agentic::Social::TheoryOfMind::Helpers::Constants::MAX_AGENT_MODELS
33
+ (max + 5).times { |i| tracker.model_for(:"agent_#{i}") }
34
+ expect(tracker.agents_tracked).to eq(max)
35
+ end
36
+ end
37
+
38
+ describe '#update_belief' do
39
+ it 'stores a belief on the agent model' do
40
+ tracker.update_belief(agent_id: :a1, domain: :skill, content: 'expert', confidence: 0.9)
41
+ model = tracker.agent_models[:a1]
42
+ expect(model.beliefs[:skill][:content]).to eq('expert')
43
+ end
44
+ end
45
+
46
+ describe '#update_desire' do
47
+ it 'stores a desire on the agent model' do
48
+ tracker.update_desire(agent_id: :a1, goal: 'deploy', priority: :high)
49
+ model = tracker.agent_models[:a1]
50
+ expect(model.desires.first[:goal]).to eq('deploy')
51
+ end
52
+ end
53
+
54
+ describe '#infer_intention' do
55
+ it 'stores an intention on the agent model' do
56
+ tracker.infer_intention(agent_id: :a1, action: :request_help, confidence: :likely)
57
+ model = tracker.agent_models[:a1]
58
+ expect(model.intentions.first[:action]).to eq(:request_help)
59
+ end
60
+ end
61
+
62
+ describe '#predict_behavior' do
63
+ before do
64
+ tracker.update_desire(agent_id: :a1, goal: 'optimize', priority: :critical)
65
+ tracker.infer_intention(agent_id: :a1, action: :refactor, confidence: :certain)
66
+ end
67
+
68
+ it 'returns a prediction hash' do
69
+ result = tracker.predict_behavior(agent_id: :a1)
70
+ expect(result[:predicted_action]).to eq(:refactor)
71
+ expect(result[:underlying_desire]).to eq('optimize')
72
+ end
73
+
74
+ it 'adds to prediction log' do
75
+ tracker.predict_behavior(agent_id: :a1)
76
+ expect(tracker.prediction_log.size).to eq(1)
77
+ end
78
+
79
+ it 'returns nil for unknown agent' do
80
+ expect(tracker.predict_behavior(agent_id: :unknown)).to be_nil
81
+ end
82
+
83
+ it 'includes model accuracy' do
84
+ result = tracker.predict_behavior(agent_id: :a1)
85
+ expect(result[:model_accuracy]).to be_a(Float)
86
+ end
87
+ end
88
+
89
+ describe '#record_prediction_outcome' do
90
+ before { tracker.model_for(:a1) }
91
+
92
+ it 'updates the model prediction accuracy' do
93
+ initial = tracker.agent_models[:a1].prediction_accuracy
94
+ tracker.record_prediction_outcome(agent_id: :a1, outcome: :correct)
95
+ expect(tracker.agent_models[:a1].prediction_accuracy).to be > initial
96
+ end
97
+
98
+ it 'returns nil for unknown agent' do
99
+ expect(tracker.record_prediction_outcome(agent_id: :unknown, outcome: :correct)).to be_nil
100
+ end
101
+ end
102
+
103
+ describe '#false_belief_check' do
104
+ before do
105
+ tracker.update_belief(agent_id: :a1, domain: :status, content: 'online', confidence: 0.8)
106
+ end
107
+
108
+ it 'identifies false beliefs' do
109
+ result = tracker.false_belief_check(agent_id: :a1, known_truths: { status: 'offline' })
110
+ expect(result).to have_key(:status)
111
+ expect(result[:status][:agent_believes]).to eq('online')
112
+ end
113
+
114
+ it 'returns empty hash when beliefs are correct' do
115
+ result = tracker.false_belief_check(agent_id: :a1, known_truths: { status: 'online' })
116
+ expect(result).to be_empty
117
+ end
118
+
119
+ it 'returns nil for unknown agent' do
120
+ expect(tracker.false_belief_check(agent_id: :unknown, known_truths: {})).to be_nil
121
+ end
122
+ end
123
+
124
+ describe '#perspective_take' do
125
+ before do
126
+ tracker.update_belief(agent_id: :a1, domain: :task, content: 'building', confidence: 0.9)
127
+ tracker.update_desire(agent_id: :a1, goal: 'ship_feature', priority: :high)
128
+ end
129
+
130
+ it 'returns the perspective hash' do
131
+ result = tracker.perspective_take(agent_id: :a1)
132
+ expect(result[:knowledge][:task]).to eq('building')
133
+ expect(result[:goals]).to include('ship_feature')
134
+ end
135
+
136
+ it 'returns nil for unknown agent' do
137
+ expect(tracker.perspective_take(agent_id: :unknown)).to be_nil
138
+ end
139
+ end
140
+
141
+ describe '#compare_agents' do
142
+ before do
143
+ tracker.update_belief(agent_id: :a1, domain: :color, content: 'blue', confidence: 0.9)
144
+ tracker.update_belief(agent_id: :a2, domain: :color, content: 'blue', confidence: 0.8)
145
+ tracker.update_desire(agent_id: :a1, goal: 'win', priority: :high)
146
+ tracker.update_desire(agent_id: :a2, goal: 'win', priority: :critical)
147
+ end
148
+
149
+ it 'returns a comparison hash' do
150
+ result = tracker.compare_agents(agent_ids: %i[a1 a2])
151
+ expect(result[:agents].size).to eq(2)
152
+ end
153
+
154
+ it 'finds shared beliefs with consensus' do
155
+ result = tracker.compare_agents(agent_ids: %i[a1 a2])
156
+ shared = result[:shared_beliefs].find { |s| s[:domain] == :color }
157
+ expect(shared[:consensus]).to be true
158
+ end
159
+
160
+ it 'finds conflicting goals' do
161
+ result = tracker.compare_agents(agent_ids: %i[a1 a2])
162
+ expect(result[:conflicting_goals]).not_to be_empty
163
+ end
164
+
165
+ it 'returns nil when no agents match' do
166
+ expect(tracker.compare_agents(agent_ids: %i[unknown1 unknown2])).to be_nil
167
+ end
168
+ end
169
+
170
+ describe '#decay_all' do
171
+ it 'decays beliefs across all models' do
172
+ tracker.update_belief(agent_id: :a1, domain: :test, content: 'val', confidence: 0.5)
173
+ initial = tracker.agent_models[:a1].beliefs[:test][:confidence]
174
+ tracker.decay_all
175
+ expect(tracker.agent_models[:a1].beliefs[:test][:confidence]).to be < initial
176
+ end
177
+
178
+ it 'removes models with no state left' do
179
+ threshold = Legion::Extensions::Agentic::Social::TheoryOfMind::Helpers::Constants::CONFIDENCE_THRESHOLD
180
+ tracker.update_belief(agent_id: :weak, domain: :x, content: 'v', confidence: threshold + 0.005)
181
+ tracker.decay_all
182
+ expect(tracker.agent_models).not_to have_key(:weak)
183
+ end
184
+ end
185
+
186
+ describe '#agents_tracked' do
187
+ it 'returns 0 initially' do
188
+ expect(tracker.agents_tracked).to eq(0)
189
+ end
190
+
191
+ it 'counts tracked agents' do
192
+ tracker.model_for(:a1)
193
+ tracker.model_for(:a2)
194
+ expect(tracker.agents_tracked).to eq(2)
195
+ end
196
+ end
197
+
198
+ describe '#total_beliefs' do
199
+ it 'sums beliefs across all models' do
200
+ tracker.update_belief(agent_id: :a1, domain: :x, content: 'v', confidence: 0.9)
201
+ tracker.update_belief(agent_id: :a1, domain: :y, content: 'v', confidence: 0.9)
202
+ tracker.update_belief(agent_id: :a2, domain: :z, content: 'v', confidence: 0.9)
203
+ expect(tracker.total_beliefs).to eq(3)
204
+ end
205
+ end
206
+
207
+ describe '#avg_prediction_accuracy' do
208
+ it 'returns 0.0 when empty' do
209
+ expect(tracker.avg_prediction_accuracy).to eq(0.0)
210
+ end
211
+
212
+ it 'averages accuracy across models' do
213
+ tracker.model_for(:a1)
214
+ tracker.model_for(:a2)
215
+ expect(tracker.avg_prediction_accuracy).to eq(0.5)
216
+ end
217
+ end
218
+
219
+ describe '#to_h' do
220
+ it 'returns a summary hash' do
221
+ result = tracker.to_h
222
+ expect(result).to have_key(:agents_tracked)
223
+ expect(result).to have_key(:total_beliefs)
224
+ expect(result).to have_key(:avg_prediction_accuracy)
225
+ expect(result).to have_key(:prediction_log_size)
226
+ end
227
+ end
228
+ end
@@ -0,0 +1,221 @@
1
+ # frozen_string_literal: true
2
+
3
+ require 'spec_helper'
4
+
5
+ RSpec.describe Legion::Extensions::Agentic::Social::TheoryOfMind::Runners::TheoryOfMind do
6
+ let(:mental_tracker) { Legion::Extensions::Agentic::Social::TheoryOfMind::Helpers::MentalStateTracker.new }
7
+
8
+ let(:host) do
9
+ Object.new.tap do |obj|
10
+ obj.extend(described_class)
11
+ obj.instance_variable_set(:@tracker, mental_tracker)
12
+ end
13
+ end
14
+
15
+ describe '#observe_agent' do
16
+ it 'records a belief' do
17
+ result = host.observe_agent(agent_id: :a1, observations: { domain: :location, belief: 'office', confidence: 0.9 })
18
+ expect(result[:success]).to be true
19
+ expect(mental_tracker.agent_models[:a1].beliefs[:location][:content]).to eq('office')
20
+ end
21
+
22
+ it 'records a desire' do
23
+ result = host.observe_agent(agent_id: :a1, observations: { goal: 'deploy' })
24
+ expect(result[:success]).to be true
25
+ end
26
+
27
+ it 'records an intention' do
28
+ result = host.observe_agent(agent_id: :a1, observations: { action: :send_message, action_confidence: :certain })
29
+ expect(result[:success]).to be true
30
+ end
31
+
32
+ it 'records all three at once' do
33
+ host.observe_agent(
34
+ agent_id: :a1,
35
+ observations: {
36
+ domain: :mood, belief: 'happy', confidence: 0.8,
37
+ goal: 'rest', goal_priority: :low,
38
+ action: :idle, action_confidence: :likely
39
+ }
40
+ )
41
+ model = mental_tracker.agent_models[:a1]
42
+ expect(model.beliefs[:mood][:content]).to eq('happy')
43
+ expect(model.desires.first[:goal]).to eq('rest')
44
+ expect(model.intentions.first[:action]).to eq(:idle)
45
+ end
46
+
47
+ it 'returns the updated model summary' do
48
+ result = host.observe_agent(agent_id: :a1, observations: { domain: :x, belief: 'y', confidence: 0.5 })
49
+ expect(result[:model]).to have_key(:agent_id)
50
+ expect(result[:model][:belief_count]).to eq(1)
51
+ end
52
+ end
53
+
54
+ describe '#predict_behavior' do
55
+ before do
56
+ host.observe_agent(agent_id: :a1, observations: { goal: 'optimize', action: :refactor, action_confidence: :certain })
57
+ end
58
+
59
+ it 'returns a prediction' do
60
+ result = host.predict_behavior(agent_id: :a1)
61
+ expect(result[:predicted_action]).to eq(:refactor)
62
+ expect(result[:underlying_desire]).to eq('optimize')
63
+ end
64
+
65
+ it 'returns error for unknown agent' do
66
+ result = host.predict_behavior(agent_id: :unknown)
67
+ expect(result[:error]).to eq('unknown agent')
68
+ end
69
+ end
70
+
71
+ describe '#record_outcome' do
72
+ before do
73
+ host.observe_agent(agent_id: :a1, observations: { domain: :x, belief: 'y', confidence: 0.5 })
74
+ end
75
+
76
+ it 'returns success with updated accuracy' do
77
+ result = host.record_outcome(agent_id: :a1, outcome: :correct)
78
+ expect(result[:success]).to be true
79
+ expect(result[:accuracy]).to be > 0.5
80
+ end
81
+
82
+ it 'accepts string outcomes' do
83
+ result = host.record_outcome(agent_id: :a1, outcome: 'incorrect')
84
+ expect(result[:success]).to be true
85
+ end
86
+
87
+ it 'returns error for unknown agent' do
88
+ result = host.record_outcome(agent_id: :unknown, outcome: :correct)
89
+ expect(result[:error]).to eq('unknown agent')
90
+ end
91
+ end
92
+
93
+ describe '#check_false_beliefs' do
94
+ before do
95
+ host.observe_agent(agent_id: :a1, observations: { domain: :weather, belief: 'sunny', confidence: 0.9 })
96
+ host.observe_agent(agent_id: :a1, observations: { domain: :day, belief: 'monday', confidence: 0.8 })
97
+ end
98
+
99
+ it 'identifies false beliefs' do
100
+ result = host.check_false_beliefs(agent_id: :a1, known_truths: { weather: 'rainy', day: 'monday' })
101
+ expect(result[:count]).to eq(1)
102
+ expect(result[:false_beliefs]).to have_key(:weather)
103
+ end
104
+
105
+ it 'returns error for unknown agent' do
106
+ result = host.check_false_beliefs(agent_id: :unknown, known_truths: {})
107
+ expect(result[:error]).to eq('unknown agent')
108
+ end
109
+ end
110
+
111
+ describe '#perspective_take' do
112
+ before do
113
+ host.observe_agent(agent_id: :a1, observations: { domain: :task, belief: 'coding', confidence: 0.9, goal: 'ship' })
114
+ end
115
+
116
+ it 'returns the perspective' do
117
+ result = host.perspective_take(agent_id: :a1)
118
+ expect(result[:agent_id]).to eq(:a1)
119
+ expect(result[:perspective][:knowledge][:task]).to eq('coding')
120
+ expect(result[:perspective][:goals]).to include('ship')
121
+ end
122
+
123
+ it 'returns error for unknown agent' do
124
+ result = host.perspective_take(agent_id: :unknown)
125
+ expect(result[:error]).to eq('unknown agent')
126
+ end
127
+ end
128
+
129
+ describe '#compare_agents' do
130
+ before do
131
+ host.observe_agent(agent_id: :a1, observations: { domain: :lang, belief: 'ruby', confidence: 0.9, goal: 'refactor' })
132
+ host.observe_agent(agent_id: :a2, observations: { domain: :lang, belief: 'ruby', confidence: 0.8, goal: 'refactor' })
133
+ end
134
+
135
+ it 'returns comparison data' do
136
+ result = host.compare_agents(agent_ids: %i[a1 a2])
137
+ expect(result[:agents].size).to eq(2)
138
+ expect(result[:shared_beliefs]).not_to be_empty
139
+ end
140
+
141
+ it 'returns error when no agents match' do
142
+ result = host.compare_agents(agent_ids: %i[x1 x2])
143
+ expect(result[:error]).to eq('no matching agents')
144
+ end
145
+ end
146
+
147
+ describe '#mental_state' do
148
+ before do
149
+ host.observe_agent(agent_id: :a1, observations: { domain: :role, belief: 'dev', confidence: 0.8, goal: 'learn' })
150
+ end
151
+
152
+ it 'returns full mental state' do
153
+ result = host.mental_state(agent_id: :a1)
154
+ expect(result[:agent_id]).to eq(:a1)
155
+ expect(result[:beliefs]).to have_key(:role)
156
+ expect(result[:desires]).not_to be_empty
157
+ expect(result[:perspective]).to be_a(Hash)
158
+ end
159
+
160
+ it 'returns error for unknown agent' do
161
+ result = host.mental_state(agent_id: :unknown)
162
+ expect(result[:error]).to eq('unknown agent')
163
+ end
164
+ end
165
+
166
+ describe '#tom_stats' do
167
+ it 'returns aggregate statistics' do
168
+ host.observe_agent(agent_id: :a1, observations: { domain: :x, belief: 'y', confidence: 0.5 })
169
+ result = host.tom_stats
170
+ expect(result[:agents_tracked]).to eq(1)
171
+ expect(result[:total_beliefs]).to eq(1)
172
+ expect(result[:models]).to be_a(Hash)
173
+ end
174
+ end
175
+
176
+ describe '#update_theory_of_mind' do
177
+ it 'returns tracker summary' do
178
+ result = host.update_theory_of_mind(tick_results: {})
179
+ expect(result).to have_key(:agents_tracked)
180
+ end
181
+
182
+ it 'extracts social observations from tick results' do
183
+ tick = {
184
+ social: {
185
+ reputation_updates: [
186
+ { agent_id: :a1, standing: :respected, composite: 0.7 },
187
+ { agent_id: :a2, standing: :neutral, composite: 0.5 }
188
+ ]
189
+ }
190
+ }
191
+ host.update_theory_of_mind(tick_results: tick)
192
+ expect(mental_tracker.agents_tracked).to eq(2)
193
+ expect(mental_tracker.agent_models[:a1].beliefs[:social_standing][:content]).to eq(:respected)
194
+ end
195
+
196
+ it 'extracts mesh observations from tick results' do
197
+ tick = {
198
+ mesh_interface: {
199
+ received_messages: [
200
+ { from: :a1, type: :request },
201
+ { from: :a2, type: :broadcast }
202
+ ]
203
+ }
204
+ }
205
+ host.update_theory_of_mind(tick_results: tick)
206
+ expect(mental_tracker.agent_models[:a1].intentions.first[:action]).to eq(:request)
207
+ end
208
+
209
+ it 'handles empty tick results' do
210
+ result = host.update_theory_of_mind(tick_results: {})
211
+ expect(result[:agents_tracked]).to eq(0)
212
+ end
213
+
214
+ it 'decays beliefs during tick' do
215
+ host.observe_agent(agent_id: :a1, observations: { domain: :test, belief: 'val', confidence: 0.5 })
216
+ initial = mental_tracker.agent_models[:a1].beliefs[:test][:confidence]
217
+ host.update_theory_of_mind(tick_results: {})
218
+ expect(mental_tracker.agent_models[:a1].beliefs[:test][:confidence]).to be < initial
219
+ end
220
+ end
221
+ end
@@ -0,0 +1,62 @@
1
+ # frozen_string_literal: true
2
+
3
+ # Stub the framework actor base class since legionio gem is not available in test
4
+ module Legion
5
+ module Extensions
6
+ module Actors
7
+ class Every # rubocop:disable Lint/EmptyClass
8
+ end
9
+ end
10
+ end
11
+ end
12
+
13
+ # Intercept the require in the actor file so it doesn't fail
14
+ $LOADED_FEATURES << 'legion/extensions/actors/every'
15
+
16
+ require 'legion/extensions/agentic/social/trust/actors/decay'
17
+
18
+ RSpec.describe Legion::Extensions::Agentic::Social::Trust::Actor::Decay do
19
+ subject(:actor) { described_class.new }
20
+
21
+ describe '#runner_class' do
22
+ it 'returns the Trust module' do
23
+ expect(actor.runner_class).to eq(Legion::Extensions::Agentic::Social::Trust::Runners::Trust)
24
+ end
25
+ end
26
+
27
+ describe '#runner_function' do
28
+ it 'returns decay_trust' do
29
+ expect(actor.runner_function).to eq('decay_trust')
30
+ end
31
+ end
32
+
33
+ describe '#time' do
34
+ it 'returns 300 seconds' do
35
+ expect(actor.time).to eq(300)
36
+ end
37
+ end
38
+
39
+ describe '#run_now?' do
40
+ it 'returns false' do
41
+ expect(actor.run_now?).to be false
42
+ end
43
+ end
44
+
45
+ describe '#use_runner?' do
46
+ it 'returns false' do
47
+ expect(actor.use_runner?).to be false
48
+ end
49
+ end
50
+
51
+ describe '#check_subtask?' do
52
+ it 'returns false' do
53
+ expect(actor.check_subtask?).to be false
54
+ end
55
+ end
56
+
57
+ describe '#generate_task?' do
58
+ it 'returns false' do
59
+ expect(actor.generate_task?).to be false
60
+ end
61
+ end
62
+ end
@@ -0,0 +1,17 @@
1
+ # frozen_string_literal: true
2
+
3
+ require 'legion/extensions/agentic/social/trust/client'
4
+
5
+ RSpec.describe Legion::Extensions::Agentic::Social::Trust::Client do
6
+ let(:client) { described_class.new }
7
+
8
+ it 'responds to trust runner methods' do
9
+ expect(client).to respond_to(:get_trust)
10
+ expect(client).to respond_to(:record_trust_interaction)
11
+ expect(client).to respond_to(:reinforce_trust_dimension)
12
+ expect(client).to respond_to(:decay_trust)
13
+ expect(client).to respond_to(:trusted_agents)
14
+ expect(client).to respond_to(:delegatable_agents)
15
+ expect(client).to respond_to(:trust_status)
16
+ end
17
+ end