sqlew 3.8.0 → 3.9.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 (881) hide show
  1. package/CHANGELOG.md +251 -285
  2. package/README.md +150 -32
  3. package/assets/sample-agents/sqlew-architect.md +72 -17
  4. package/assets/sample-agents/sqlew-researcher.md +62 -1
  5. package/assets/sample-agents/sqlew-scrum-master.md +5 -1
  6. package/assets/sample-commands/README.md +57 -0
  7. package/assets/sample-commands/sqw-documentor.md +158 -0
  8. package/assets/sample-commands/sqw-plan.md +301 -0
  9. package/assets/sample-commands/sqw-research.md +298 -0
  10. package/assets/sample-commands/sqw-review.md +340 -0
  11. package/assets/sample-commands/sqw-scrum.md +423 -0
  12. package/assets/sample-commands/sqw-secretary.md +187 -0
  13. package/dist/adapters/sqlite-adapter.d.ts +0 -6
  14. package/dist/adapters/sqlite-adapter.d.ts.map +1 -1
  15. package/dist/adapters/sqlite-adapter.js +10 -14
  16. package/dist/adapters/sqlite-adapter.js.map +1 -1
  17. package/dist/cli/db-dump.d.ts +1 -1
  18. package/dist/cli/db-dump.d.ts.map +1 -1
  19. package/dist/cli/db-dump.js +1 -1
  20. package/dist/cli/db-dump.js.map +1 -1
  21. package/dist/config/knex/bootstrap/20251025021352_fix_mysql_index_syntax.d.ts +4 -0
  22. package/dist/config/knex/bootstrap/20251025021352_fix_mysql_index_syntax.d.ts.map +1 -0
  23. package/dist/config/knex/bootstrap/20251025021352_fix_mysql_index_syntax.js +146 -0
  24. package/dist/config/knex/bootstrap/20251025021352_fix_mysql_index_syntax.js.map +1 -0
  25. package/dist/config/knex/enhancements/20251112000001_fix_task_file_links_schema_v3_9_0.d.ts +22 -0
  26. package/dist/config/knex/enhancements/20251112000001_fix_task_file_links_schema_v3_9_0.d.ts.map +1 -0
  27. package/dist/config/knex/enhancements/20251112000001_fix_task_file_links_schema_v3_9_0.js +106 -0
  28. package/dist/config/knex/enhancements/20251112000001_fix_task_file_links_schema_v3_9_0.js.map +1 -0
  29. package/dist/config/knex/enhancements/20251112000002_fix_task_pruned_files_schema_v3_9_0.d.ts +21 -0
  30. package/dist/config/knex/enhancements/20251112000002_fix_task_pruned_files_schema_v3_9_0.d.ts.map +1 -0
  31. package/dist/config/knex/enhancements/20251112000002_fix_task_pruned_files_schema_v3_9_0.js +106 -0
  32. package/dist/config/knex/enhancements/20251112000002_fix_task_pruned_files_schema_v3_9_0.js.map +1 -0
  33. package/dist/config/knex/enhancements/20251114000000_fix_v_tagged_decisions_numeric_support.d.ts +21 -0
  34. package/dist/config/knex/enhancements/20251114000000_fix_v_tagged_decisions_numeric_support.d.ts.map +1 -0
  35. package/dist/config/knex/enhancements/20251114000000_fix_v_tagged_decisions_numeric_support.js +91 -0
  36. package/dist/config/knex/enhancements/20251114000000_fix_v_tagged_decisions_numeric_support.js.map +1 -0
  37. package/dist/config/knex/enhancements/20251114120000_add_suggest_tool_to_help_system_v3_9_0.d.ts +15 -0
  38. package/dist/config/knex/enhancements/20251114120000_add_suggest_tool_to_help_system_v3_9_0.d.ts.map +1 -0
  39. package/dist/config/knex/enhancements/20251114120000_add_suggest_tool_to_help_system_v3_9_0.js +270 -0
  40. package/dist/config/knex/enhancements/20251114120000_add_suggest_tool_to_help_system_v3_9_0.js.map +1 -0
  41. package/dist/config/knex/enhancements/20251114121000_add_suggest_tool_use_cases_v3_9_0.d.ts +15 -0
  42. package/dist/config/knex/enhancements/20251114121000_add_suggest_tool_use_cases_v3_9_0.d.ts.map +1 -0
  43. package/dist/config/knex/enhancements/20251114121000_add_suggest_tool_use_cases_v3_9_0.js +241 -0
  44. package/dist/config/knex/enhancements/20251114121000_add_suggest_tool_use_cases_v3_9_0.js.map +1 -0
  45. package/dist/config/knex/enhancements/20251114130000_seed_builtin_policies_v3_9_0.d.ts +16 -0
  46. package/dist/config/knex/enhancements/20251114130000_seed_builtin_policies_v3_9_0.d.ts.map +1 -0
  47. package/dist/config/knex/enhancements/20251114130000_seed_builtin_policies_v3_9_0.js +168 -0
  48. package/dist/config/knex/enhancements/20251114130000_seed_builtin_policies_v3_9_0.js.map +1 -0
  49. package/dist/config/knex/enhancements/20251114140000_add_policy_help_v3_9_0.d.ts +14 -0
  50. package/dist/config/knex/enhancements/20251114140000_add_policy_help_v3_9_0.d.ts.map +1 -0
  51. package/dist/config/knex/enhancements/20251114140000_add_policy_help_v3_9_0.js +228 -0
  52. package/dist/config/knex/enhancements/20251114140000_add_policy_help_v3_9_0.js.map +1 -0
  53. package/dist/config/knex/enhancements/20251114141000_add_policy_use_cases_v3_9_0.d.ts +14 -0
  54. package/dist/config/knex/enhancements/20251114141000_add_policy_use_cases_v3_9_0.d.ts.map +1 -0
  55. package/dist/config/knex/enhancements/20251114141000_add_policy_use_cases_v3_9_0.js +237 -0
  56. package/dist/config/knex/enhancements/20251114141000_add_policy_use_cases_v3_9_0.js.map +1 -0
  57. package/dist/config/knex/enhancements/20251114150000_fix_policy_unique_constraint_v3_9_0.d.ts +14 -0
  58. package/dist/config/knex/enhancements/20251114150000_fix_policy_unique_constraint_v3_9_0.d.ts.map +1 -0
  59. package/dist/config/knex/enhancements/20251114150000_fix_policy_unique_constraint_v3_9_0.js +61 -0
  60. package/dist/config/knex/enhancements/20251114150000_fix_policy_unique_constraint_v3_9_0.js.map +1 -0
  61. package/dist/config/knex/enhancements/20251115000000_fix_task_decision_links_unique_constraint.d.ts +21 -0
  62. package/dist/config/knex/enhancements/20251115000000_fix_task_decision_links_unique_constraint.d.ts.map +1 -0
  63. package/dist/config/knex/enhancements/20251115000000_fix_task_decision_links_unique_constraint.js +127 -0
  64. package/dist/config/knex/enhancements/20251115000000_fix_task_decision_links_unique_constraint.js.map +1 -0
  65. package/dist/config/knex/enhancements/20251115100000_fix_read_keyword_index_v3_9_0.d.ts +15 -0
  66. package/dist/config/knex/enhancements/20251115100000_fix_read_keyword_index_v3_9_0.d.ts.map +1 -0
  67. package/dist/config/knex/enhancements/20251115100000_fix_read_keyword_index_v3_9_0.js +69 -0
  68. package/dist/config/knex/enhancements/20251115100000_fix_read_keyword_index_v3_9_0.js.map +1 -0
  69. package/dist/config/knex/enhancements/20251115110000_fix_cross_database_timestamps_v3_9_0.d.ts +15 -0
  70. package/dist/config/knex/enhancements/20251115110000_fix_cross_database_timestamps_v3_9_0.d.ts.map +1 -0
  71. package/dist/config/knex/enhancements/20251115110000_fix_cross_database_timestamps_v3_9_0.js +132 -0
  72. package/dist/config/knex/enhancements/20251115110000_fix_cross_database_timestamps_v3_9_0.js.map +1 -0
  73. package/dist/config/knex/enhancements/20251115120000_fix_all_cross_db_issues_v3_9_0.d.ts +18 -0
  74. package/dist/config/knex/enhancements/20251115120000_fix_all_cross_db_issues_v3_9_0.d.ts.map +1 -0
  75. package/dist/config/knex/enhancements/20251115120000_fix_all_cross_db_issues_v3_9_0.js +47 -0
  76. package/dist/config/knex/enhancements/20251115120000_fix_all_cross_db_issues_v3_9_0.js.map +1 -0
  77. package/dist/config/knex/enhancements/20251118000000_fix_native_db_test_issues_v3_9_1.d.ts +20 -0
  78. package/dist/config/knex/enhancements/20251118000000_fix_native_db_test_issues_v3_9_1.d.ts.map +1 -0
  79. package/dist/config/knex/enhancements/20251118000000_fix_native_db_test_issues_v3_9_1.js +119 -0
  80. package/dist/config/knex/enhancements/20251118000000_fix_native_db_test_issues_v3_9_1.js.map +1 -0
  81. package/dist/config/knex/upgrades/20251111235959_preemptive_fix_cross_database_v3_9_0.d.ts +19 -0
  82. package/dist/config/knex/upgrades/20251111235959_preemptive_fix_cross_database_v3_9_0.d.ts.map +1 -0
  83. package/dist/config/knex/upgrades/20251111235959_preemptive_fix_cross_database_v3_9_0.js +196 -0
  84. package/dist/config/knex/upgrades/20251111235959_preemptive_fix_cross_database_v3_9_0.js.map +1 -0
  85. package/dist/config/knex/upgrades/20251112000000_decision_intelligence_v3_9_0.d.ts +22 -0
  86. package/dist/config/knex/upgrades/20251112000000_decision_intelligence_v3_9_0.d.ts.map +1 -0
  87. package/dist/config/knex/upgrades/20251112000000_decision_intelligence_v3_9_0.js +375 -0
  88. package/dist/config/knex/upgrades/20251112000000_decision_intelligence_v3_9_0.js.map +1 -0
  89. package/dist/config/loader.d.ts.map +1 -1
  90. package/dist/config/loader.js +4 -0
  91. package/dist/config/loader.js.map +1 -1
  92. package/dist/config/minimal-generator.d.ts.map +1 -1
  93. package/dist/config/minimal-generator.js +34 -0
  94. package/dist/config/minimal-generator.js.map +1 -1
  95. package/dist/config/types.d.ts +19 -0
  96. package/dist/config/types.d.ts.map +1 -1
  97. package/dist/config/types.js +8 -0
  98. package/dist/config/types.js.map +1 -1
  99. package/dist/constants.d.ts +30 -0
  100. package/dist/constants.d.ts.map +1 -1
  101. package/dist/constants.js +33 -0
  102. package/dist/constants.js.map +1 -1
  103. package/dist/database/initialization/cleanup.d.ts +1 -1
  104. package/dist/database/initialization/cleanup.d.ts.map +1 -1
  105. package/dist/database/initialization/cleanup.js +15 -1
  106. package/dist/database/initialization/cleanup.js.map +1 -1
  107. package/dist/database/initialization/init.d.ts.map +1 -1
  108. package/dist/database/initialization/init.js +3 -0
  109. package/dist/database/initialization/init.js.map +1 -1
  110. package/dist/database/migrations/20251024010000_upgrade_v1_0_to_v1_1.d.ts +16 -0
  111. package/dist/database/migrations/20251024010000_upgrade_v1_0_to_v1_1.d.ts.map +1 -0
  112. package/dist/database/migrations/20251024010000_upgrade_v1_0_to_v1_1.js +84 -0
  113. package/dist/database/migrations/20251024010000_upgrade_v1_0_to_v1_1.js.map +1 -0
  114. package/dist/database/migrations/20251024020000_upgrade_v2_0_to_v2_1.d.ts +14 -0
  115. package/dist/database/migrations/20251024020000_upgrade_v2_0_to_v2_1.d.ts.map +1 -0
  116. package/dist/database/migrations/20251024020000_upgrade_v2_0_to_v2_1.js +42 -0
  117. package/dist/database/migrations/20251024020000_upgrade_v2_0_to_v2_1.js.map +1 -0
  118. package/dist/database/migrations/20251024030000_upgrade_v2_1_to_v3_0.d.ts +17 -0
  119. package/dist/database/migrations/20251024030000_upgrade_v2_1_to_v3_0.d.ts.map +1 -0
  120. package/dist/database/migrations/20251024030000_upgrade_v2_1_to_v3_0.js +122 -0
  121. package/dist/database/migrations/20251024030000_upgrade_v2_1_to_v3_0.js.map +1 -0
  122. package/dist/database/migrations/20251024040000_upgrade_v3_0_to_v3_2.d.ts +12 -0
  123. package/dist/database/migrations/20251024040000_upgrade_v3_0_to_v3_2.d.ts.map +1 -0
  124. package/dist/database/migrations/20251024040000_upgrade_v3_0_to_v3_2.js +49 -0
  125. package/dist/database/migrations/20251024040000_upgrade_v3_0_to_v3_2.js.map +1 -0
  126. package/dist/database/migrations/20251024050000_upgrade_v3_2_0_to_v3_2_2.d.ts +12 -0
  127. package/dist/database/migrations/20251024050000_upgrade_v3_2_0_to_v3_2_2.d.ts.map +1 -0
  128. package/dist/database/migrations/20251024050000_upgrade_v3_2_0_to_v3_2_2.js +53 -0
  129. package/dist/database/migrations/20251024050000_upgrade_v3_2_0_to_v3_2_2.js.map +1 -0
  130. package/dist/database/migrations/20251024060000_upgrade_v3_4_to_v3_5.d.ts +12 -0
  131. package/dist/database/migrations/20251024060000_upgrade_v3_4_to_v3_5.d.ts.map +1 -0
  132. package/dist/database/migrations/20251024060000_upgrade_v3_4_to_v3_5.js +44 -0
  133. package/dist/database/migrations/20251024060000_upgrade_v3_4_to_v3_5.js.map +1 -0
  134. package/dist/database/migrations/20251024070000_upgrade_v3_5_to_v3_6.d.ts +13 -0
  135. package/dist/database/migrations/20251024070000_upgrade_v3_5_to_v3_6.d.ts.map +1 -0
  136. package/dist/database/migrations/20251024070000_upgrade_v3_5_to_v3_6.js +33 -0
  137. package/dist/database/migrations/20251024070000_upgrade_v3_5_to_v3_6.js.map +1 -0
  138. package/dist/database/migrations/20251025020452_create_master_tables_wrapper.d.ts +17 -0
  139. package/dist/database/migrations/20251025020452_create_master_tables_wrapper.d.ts.map +1 -0
  140. package/dist/database/migrations/20251025020452_create_master_tables_wrapper.js +119 -0
  141. package/dist/database/migrations/20251025020452_create_master_tables_wrapper.js.map +1 -0
  142. package/dist/database/migrations/20251025021152_create_transaction_tables_wrapper.d.ts +15 -0
  143. package/dist/database/migrations/20251025021152_create_transaction_tables_wrapper.d.ts.map +1 -0
  144. package/dist/database/migrations/20251025021152_create_transaction_tables_wrapper.js +282 -0
  145. package/dist/database/migrations/20251025021152_create_transaction_tables_wrapper.js.map +1 -0
  146. package/dist/database/migrations/20251025021351_create_indexes_wrapper.d.ts +21 -0
  147. package/dist/database/migrations/20251025021351_create_indexes_wrapper.d.ts.map +1 -0
  148. package/dist/database/migrations/20251025021351_create_indexes_wrapper.js +83 -0
  149. package/dist/database/migrations/20251025021351_create_indexes_wrapper.js.map +1 -0
  150. package/dist/database/migrations/20251025021352_fix_mysql_index_syntax_wrapper.d.ts +22 -0
  151. package/dist/database/migrations/20251025021352_fix_mysql_index_syntax_wrapper.d.ts.map +1 -0
  152. package/dist/database/migrations/20251025021352_fix_mysql_index_syntax_wrapper.js +94 -0
  153. package/dist/database/migrations/20251025021352_fix_mysql_index_syntax_wrapper.js.map +1 -0
  154. package/dist/database/migrations/20251025021416_seed_master_data_wrapper.d.ts +19 -0
  155. package/dist/database/migrations/20251025021416_seed_master_data_wrapper.d.ts.map +1 -0
  156. package/dist/database/migrations/20251025021416_seed_master_data_wrapper.js +120 -0
  157. package/dist/database/migrations/20251025021416_seed_master_data_wrapper.js.map +1 -0
  158. package/dist/database/migrations/20251025070349_create_views_wrapper.d.ts +14 -0
  159. package/dist/database/migrations/20251025070349_create_views_wrapper.d.ts.map +1 -0
  160. package/dist/database/migrations/20251025070349_create_views_wrapper.js +160 -0
  161. package/dist/database/migrations/20251025070349_create_views_wrapper.js.map +1 -0
  162. package/dist/database/migrations/20251025081221_add_link_type_to_task_decision_links.d.ts +9 -0
  163. package/dist/database/migrations/20251025081221_add_link_type_to_task_decision_links.d.ts.map +1 -0
  164. package/dist/database/migrations/20251025081221_add_link_type_to_task_decision_links.js +21 -0
  165. package/dist/database/migrations/20251025081221_add_link_type_to_task_decision_links.js.map +1 -0
  166. package/dist/database/migrations/20251025082220_fix_task_dependencies_columns.d.ts +13 -0
  167. package/dist/database/migrations/20251025082220_fix_task_dependencies_columns.d.ts.map +1 -0
  168. package/dist/database/migrations/20251025082220_fix_task_dependencies_columns.js +17 -0
  169. package/dist/database/migrations/20251025082220_fix_task_dependencies_columns.js.map +1 -0
  170. package/dist/database/migrations/20251025090000_create_help_system_tables.d.ts +27 -0
  171. package/dist/database/migrations/20251025090000_create_help_system_tables.d.ts.map +1 -0
  172. package/dist/database/migrations/20251025090000_create_help_system_tables.js +120 -0
  173. package/dist/database/migrations/20251025090000_create_help_system_tables.js.map +1 -0
  174. package/dist/database/migrations/20251025090100_seed_help_categories_and_use_cases.d.ts +18 -0
  175. package/dist/database/migrations/20251025090100_seed_help_categories_and_use_cases.d.ts.map +1 -0
  176. package/dist/database/migrations/20251025090100_seed_help_categories_and_use_cases.js +388 -0
  177. package/dist/database/migrations/20251025090100_seed_help_categories_and_use_cases.js.map +1 -0
  178. package/dist/database/migrations/20251025100000_seed_help_metadata.d.ts +20 -0
  179. package/dist/database/migrations/20251025100000_seed_help_metadata.d.ts.map +1 -0
  180. package/dist/database/migrations/20251025100000_seed_help_metadata.js +264 -0
  181. package/dist/database/migrations/20251025100000_seed_help_metadata.js.map +1 -0
  182. package/dist/database/migrations/20251025100100_seed_remaining_use_cases.d.ts +21 -0
  183. package/dist/database/migrations/20251025100100_seed_remaining_use_cases.d.ts.map +1 -0
  184. package/dist/database/migrations/20251025100100_seed_remaining_use_cases.js +281 -0
  185. package/dist/database/migrations/20251025100100_seed_remaining_use_cases.js.map +1 -0
  186. package/dist/database/migrations/20251025120000_add_cascade_to_task_dependencies.d.ts +13 -0
  187. package/dist/database/migrations/20251025120000_add_cascade_to_task_dependencies.d.ts.map +1 -0
  188. package/dist/database/migrations/20251025120000_add_cascade_to_task_dependencies.js +76 -0
  189. package/dist/database/migrations/20251025120000_add_cascade_to_task_dependencies.js.map +1 -0
  190. package/dist/database/migrations/20251027000000_add_agent_reuse_system.d.ts +17 -0
  191. package/dist/database/migrations/20251027000000_add_agent_reuse_system.d.ts.map +1 -0
  192. package/dist/database/migrations/20251027000000_add_agent_reuse_system.js +42 -0
  193. package/dist/database/migrations/20251027000000_add_agent_reuse_system.js.map +1 -0
  194. package/dist/database/migrations/20251027010000_add_task_constraint_to_decision_context.d.ts +10 -0
  195. package/dist/database/migrations/20251027010000_add_task_constraint_to_decision_context.d.ts.map +1 -0
  196. package/dist/database/migrations/20251027010000_add_task_constraint_to_decision_context.js +28 -0
  197. package/dist/database/migrations/20251027010000_add_task_constraint_to_decision_context.js.map +1 -0
  198. package/dist/database/migrations/20251027020000_update_agent_reusability.d.ts +21 -0
  199. package/dist/database/migrations/20251027020000_update_agent_reusability.d.ts.map +1 -0
  200. package/dist/database/migrations/20251027020000_update_agent_reusability.js +38 -0
  201. package/dist/database/migrations/20251027020000_update_agent_reusability.js.map +1 -0
  202. package/dist/database/migrations/20251028000000_simplify_agent_system.d.ts +26 -0
  203. package/dist/database/migrations/20251028000000_simplify_agent_system.d.ts.map +1 -0
  204. package/dist/database/migrations/20251028000000_simplify_agent_system.js +56 -0
  205. package/dist/database/migrations/20251028000000_simplify_agent_system.js.map +1 -0
  206. package/dist/database/migrations/20251031000000_drop_orphaned_message_view.d.ts +16 -0
  207. package/dist/database/migrations/20251031000000_drop_orphaned_message_view.d.ts.map +1 -0
  208. package/dist/database/migrations/20251031000000_drop_orphaned_message_view.js +52 -0
  209. package/dist/database/migrations/20251031000000_drop_orphaned_message_view.js.map +1 -0
  210. package/dist/database/migrations/20251104000000_add_multi_project_v3_7_0.d.ts +56 -0
  211. package/dist/database/migrations/20251104000000_add_multi_project_v3_7_0.d.ts.map +1 -0
  212. package/dist/database/migrations/20251104000000_add_multi_project_v3_7_0.js +701 -0
  213. package/dist/database/migrations/20251104000000_add_multi_project_v3_7_0.js.map +1 -0
  214. package/dist/database/migrations/20251104000003_rename_constraints_created_by_to_agent_id.d.ts +30 -0
  215. package/dist/database/migrations/20251104000003_rename_constraints_created_by_to_agent_id.d.ts.map +1 -0
  216. package/dist/database/migrations/20251104000003_rename_constraints_created_by_to_agent_id.js +180 -0
  217. package/dist/database/migrations/20251104000003_rename_constraints_created_by_to_agent_id.js.map +1 -0
  218. package/dist/database/migrations/20251105000000_add_token_usage_table.d.ts +19 -0
  219. package/dist/database/migrations/20251105000000_add_token_usage_table.d.ts.map +1 -0
  220. package/dist/database/migrations/20251105000000_add_token_usage_table.js +47 -0
  221. package/dist/database/migrations/20251105000000_add_token_usage_table.js.map +1 -0
  222. package/dist/database/migrations/20251105000001_rename_decision_context_decided_by_to_agent_id.d.ts +28 -0
  223. package/dist/database/migrations/20251105000001_rename_decision_context_decided_by_to_agent_id.d.ts.map +1 -0
  224. package/dist/database/migrations/20251105000001_rename_decision_context_decided_by_to_agent_id.js +123 -0
  225. package/dist/database/migrations/20251105000001_rename_decision_context_decided_by_to_agent_id.js.map +1 -0
  226. package/dist/database/migrations/20251106000000_fix_master_tables_project_id_v3_7_3.d.ts +36 -0
  227. package/dist/database/migrations/20251106000000_fix_master_tables_project_id_v3_7_3.d.ts.map +1 -0
  228. package/dist/database/migrations/20251106000000_fix_master_tables_project_id_v3_7_3.js +559 -0
  229. package/dist/database/migrations/20251106000000_fix_master_tables_project_id_v3_7_3.js.map +1 -0
  230. package/dist/database/migrations/20251108000000_add_planning_layers_v3_8_0.d.ts +26 -0
  231. package/dist/database/migrations/20251108000000_add_planning_layers_v3_8_0.d.ts.map +1 -0
  232. package/dist/database/migrations/20251108000000_add_planning_layers_v3_8_0.js +78 -0
  233. package/dist/database/migrations/20251108000000_add_planning_layers_v3_8_0.js.map +1 -0
  234. package/dist/database/migrations/20251108000000_hotfix_v_tagged_constraints_project_id.d.ts +17 -0
  235. package/dist/database/migrations/20251108000000_hotfix_v_tagged_constraints_project_id.d.ts.map +1 -0
  236. package/dist/database/migrations/20251108000000_hotfix_v_tagged_constraints_project_id.js +78 -0
  237. package/dist/database/migrations/20251108000000_hotfix_v_tagged_constraints_project_id.js.map +1 -0
  238. package/dist/database/migrations/20251109000000_fix_task_file_links_unique_constraint_v3_8_0.d.ts +24 -0
  239. package/dist/database/migrations/20251109000000_fix_task_file_links_unique_constraint_v3_8_0.d.ts.map +1 -0
  240. package/dist/database/migrations/20251109000000_fix_task_file_links_unique_constraint_v3_8_0.js +63 -0
  241. package/dist/database/migrations/20251109000000_fix_task_file_links_unique_constraint_v3_8_0.js.map +1 -0
  242. package/dist/database/migrations/20251109000002_multi_project_cross_db_compat_v3_7_5.d.ts +27 -0
  243. package/dist/database/migrations/20251109000002_multi_project_cross_db_compat_v3_7_5.d.ts.map +1 -0
  244. package/dist/database/migrations/20251109000002_multi_project_cross_db_compat_v3_7_5.js +276 -0
  245. package/dist/database/migrations/20251109000002_multi_project_cross_db_compat_v3_7_5.js.map +1 -0
  246. package/dist/database/migrations/20251109000003_token_usage_cross_db_compat_v3_7_5.d.ts +27 -0
  247. package/dist/database/migrations/20251109000003_token_usage_cross_db_compat_v3_7_5.d.ts.map +1 -0
  248. package/dist/database/migrations/20251109000003_token_usage_cross_db_compat_v3_7_5.js +67 -0
  249. package/dist/database/migrations/20251109000003_token_usage_cross_db_compat_v3_7_5.js.map +1 -0
  250. package/dist/database/migrations/20251109010000_tool_cleanup_v3_8_0.d.ts +32 -0
  251. package/dist/database/migrations/20251109010000_tool_cleanup_v3_8_0.d.ts.map +1 -0
  252. package/dist/database/migrations/20251109010000_tool_cleanup_v3_8_0.js +352 -0
  253. package/dist/database/migrations/20251109010000_tool_cleanup_v3_8_0.js.map +1 -0
  254. package/dist/database/migrations/20251109020000_fix_missing_help_actions_v3_8_0.d.ts +35 -0
  255. package/dist/database/migrations/20251109020000_fix_missing_help_actions_v3_8_0.d.ts.map +1 -0
  256. package/dist/database/migrations/20251109020000_fix_missing_help_actions_v3_8_0.js +237 -0
  257. package/dist/database/migrations/20251109020000_fix_missing_help_actions_v3_8_0.js.map +1 -0
  258. package/dist/database/migrations/20251111235959_preemptive_fix_cross_database_v3_9_0.d.ts +22 -0
  259. package/dist/database/migrations/20251111235959_preemptive_fix_cross_database_v3_9_0.d.ts.map +1 -0
  260. package/dist/database/migrations/20251111235959_preemptive_fix_cross_database_v3_9_0.js +190 -0
  261. package/dist/database/migrations/20251111235959_preemptive_fix_cross_database_v3_9_0.js.map +1 -0
  262. package/dist/database/migrations/20251112000000_decision_intelligence_v3_9_0.d.ts +32 -0
  263. package/dist/database/migrations/20251112000000_decision_intelligence_v3_9_0.d.ts.map +1 -0
  264. package/dist/database/migrations/20251112000000_decision_intelligence_v3_9_0.js +342 -0
  265. package/dist/database/migrations/20251112000000_decision_intelligence_v3_9_0.js.map +1 -0
  266. package/dist/database/migrations/20251112000001_fix_task_file_links_schema_v3_9_0.d.ts +25 -0
  267. package/dist/database/migrations/20251112000001_fix_task_file_links_schema_v3_9_0.d.ts.map +1 -0
  268. package/dist/database/migrations/20251112000001_fix_task_file_links_schema_v3_9_0.js +109 -0
  269. package/dist/database/migrations/20251112000001_fix_task_file_links_schema_v3_9_0.js.map +1 -0
  270. package/dist/database/migrations/20251112000002_fix_task_pruned_files_schema_v3_9_0.d.ts +24 -0
  271. package/dist/database/migrations/20251112000002_fix_task_pruned_files_schema_v3_9_0.d.ts.map +1 -0
  272. package/dist/database/migrations/20251112000002_fix_task_pruned_files_schema_v3_9_0.js +111 -0
  273. package/dist/database/migrations/20251112000002_fix_task_pruned_files_schema_v3_9_0.js.map +1 -0
  274. package/dist/database/migrations/20251114000000_fix_v_tagged_decisions_numeric_support.d.ts +24 -0
  275. package/dist/database/migrations/20251114000000_fix_v_tagged_decisions_numeric_support.d.ts.map +1 -0
  276. package/dist/database/migrations/20251114000000_fix_v_tagged_decisions_numeric_support.js +90 -0
  277. package/dist/database/migrations/20251114000000_fix_v_tagged_decisions_numeric_support.js.map +1 -0
  278. package/dist/database/migrations/20251114120000_add_suggest_tool_to_help_system_v3_9_0.d.ts +20 -0
  279. package/dist/database/migrations/20251114120000_add_suggest_tool_to_help_system_v3_9_0.d.ts.map +1 -0
  280. package/dist/database/migrations/20251114120000_add_suggest_tool_to_help_system_v3_9_0.js +275 -0
  281. package/dist/database/migrations/20251114120000_add_suggest_tool_to_help_system_v3_9_0.js.map +1 -0
  282. package/dist/database/migrations/20251114121000_add_suggest_tool_use_cases_v3_9_0.d.ts +20 -0
  283. package/dist/database/migrations/20251114121000_add_suggest_tool_use_cases_v3_9_0.d.ts.map +1 -0
  284. package/dist/database/migrations/20251114121000_add_suggest_tool_use_cases_v3_9_0.js +246 -0
  285. package/dist/database/migrations/20251114121000_add_suggest_tool_use_cases_v3_9_0.js.map +1 -0
  286. package/dist/database/migrations/20251114130000_seed_builtin_policies_v3_9_0.d.ts +23 -0
  287. package/dist/database/migrations/20251114130000_seed_builtin_policies_v3_9_0.d.ts.map +1 -0
  288. package/dist/database/migrations/20251114130000_seed_builtin_policies_v3_9_0.js +175 -0
  289. package/dist/database/migrations/20251114130000_seed_builtin_policies_v3_9_0.js.map +1 -0
  290. package/dist/database/migrations/20251114140000_add_policy_help_v3_9_0.d.ts +21 -0
  291. package/dist/database/migrations/20251114140000_add_policy_help_v3_9_0.d.ts.map +1 -0
  292. package/dist/database/migrations/20251114140000_add_policy_help_v3_9_0.js +235 -0
  293. package/dist/database/migrations/20251114140000_add_policy_help_v3_9_0.js.map +1 -0
  294. package/dist/database/migrations/20251114141000_add_policy_use_cases_v3_9_0.d.ts +21 -0
  295. package/dist/database/migrations/20251114141000_add_policy_use_cases_v3_9_0.d.ts.map +1 -0
  296. package/dist/database/migrations/20251114141000_add_policy_use_cases_v3_9_0.js +244 -0
  297. package/dist/database/migrations/20251114141000_add_policy_use_cases_v3_9_0.js.map +1 -0
  298. package/dist/database/migrations/20251114150000_fix_policy_unique_constraint_v3_9_0.d.ts +23 -0
  299. package/dist/database/migrations/20251114150000_fix_policy_unique_constraint_v3_9_0.d.ts.map +1 -0
  300. package/dist/database/migrations/20251114150000_fix_policy_unique_constraint_v3_9_0.js +70 -0
  301. package/dist/database/migrations/20251114150000_fix_policy_unique_constraint_v3_9_0.js.map +1 -0
  302. package/dist/database/migrations/20251115000000_fix_task_decision_links_unique_constraint.d.ts +29 -0
  303. package/dist/database/migrations/20251115000000_fix_task_decision_links_unique_constraint.d.ts.map +1 -0
  304. package/dist/database/migrations/20251115000000_fix_task_decision_links_unique_constraint.js +135 -0
  305. package/dist/database/migrations/20251115000000_fix_task_decision_links_unique_constraint.js.map +1 -0
  306. package/dist/database/migrations/20251115100000_fix_read_keyword_index_v3_9_0.d.ts +23 -0
  307. package/dist/database/migrations/20251115100000_fix_read_keyword_index_v3_9_0.d.ts.map +1 -0
  308. package/dist/database/migrations/20251115100000_fix_read_keyword_index_v3_9_0.js +42 -0
  309. package/dist/database/migrations/20251115100000_fix_read_keyword_index_v3_9_0.js.map +1 -0
  310. package/dist/database/migrations/20251115110000_fix_cross_database_timestamps_v3_9_0.d.ts +25 -0
  311. package/dist/database/migrations/20251115110000_fix_cross_database_timestamps_v3_9_0.d.ts.map +1 -0
  312. package/dist/database/migrations/20251115110000_fix_cross_database_timestamps_v3_9_0.js +102 -0
  313. package/dist/database/migrations/20251115110000_fix_cross_database_timestamps_v3_9_0.js.map +1 -0
  314. package/dist/database/migrations/20251115120000_fix_all_cross_db_issues_v3_9_0.d.ts +25 -0
  315. package/dist/database/migrations/20251115120000_fix_all_cross_db_issues_v3_9_0.d.ts.map +1 -0
  316. package/dist/database/migrations/20251115120000_fix_all_cross_db_issues_v3_9_0.js +55 -0
  317. package/dist/database/migrations/20251115120000_fix_all_cross_db_issues_v3_9_0.js.map +1 -0
  318. package/dist/database/migrations/20251118000000_eliminate_views_v3_9_0.d.ts +29 -0
  319. package/dist/database/migrations/20251118000000_eliminate_views_v3_9_0.d.ts.map +1 -0
  320. package/dist/database/migrations/20251118000000_eliminate_views_v3_9_0.js +62 -0
  321. package/dist/database/migrations/20251118000000_eliminate_views_v3_9_0.js.map +1 -0
  322. package/dist/database/migrations/20251119000000_add_constraint_text_hash_v3_9_1.d.ts +25 -0
  323. package/dist/database/migrations/20251119000000_add_constraint_text_hash_v3_9_1.d.ts.map +1 -0
  324. package/dist/database/migrations/20251119000000_add_constraint_text_hash_v3_9_1.js +100 -0
  325. package/dist/database/migrations/20251119000000_add_constraint_text_hash_v3_9_1.js.map +1 -0
  326. package/dist/init-commands.d.ts +7 -0
  327. package/dist/init-commands.d.ts.map +1 -0
  328. package/dist/init-commands.js +185 -0
  329. package/dist/init-commands.js.map +1 -0
  330. package/dist/schema.d.ts +11 -19
  331. package/dist/schema.d.ts.map +1 -1
  332. package/dist/schema.js +51 -63
  333. package/dist/schema.js.map +1 -1
  334. package/dist/server/tool-handlers.d.ts.map +1 -1
  335. package/dist/server/tool-handlers.js +20 -1
  336. package/dist/server/tool-handlers.js.map +1 -1
  337. package/dist/server/tool-registry.d.ts.map +1 -1
  338. package/dist/server/tool-registry.js +42 -1
  339. package/dist/server/tool-registry.js.map +1 -1
  340. package/dist/sync-commands.d.ts +13 -0
  341. package/dist/sync-commands.d.ts.map +1 -0
  342. package/dist/sync-commands.js +115 -0
  343. package/dist/sync-commands.js.map +1 -0
  344. package/dist/tests/database/connection/connection-manager-integration.test.d.ts.map +1 -0
  345. package/dist/tests/{connection-manager-integration.test.js → database/connection/connection-manager-integration.test.js} +1 -1
  346. package/dist/tests/database/connection/connection-manager-integration.test.js.map +1 -0
  347. package/dist/tests/database/connection/connection-manager.test.d.ts.map +1 -0
  348. package/dist/tests/{connection-manager.test.js → database/connection/connection-manager.test.js} +1 -1
  349. package/dist/tests/database/connection/connection-manager.test.js.map +1 -0
  350. package/dist/tests/database/migrations/idempotency.test.d.ts +2 -0
  351. package/dist/tests/database/migrations/idempotency.test.d.ts.map +1 -0
  352. package/dist/tests/{migration-idempotency.test.js → database/migrations/idempotency.test.js} +1 -1
  353. package/dist/tests/database/migrations/idempotency.test.js.map +1 -0
  354. package/dist/tests/database/migrations/upgrade-paths.test.d.ts +2 -0
  355. package/dist/tests/database/migrations/upgrade-paths.test.d.ts.map +1 -0
  356. package/dist/tests/{migration-upgrade-paths.test.js → database/migrations/upgrade-paths.test.js} +1 -1
  357. package/dist/tests/database/migrations/upgrade-paths.test.js.map +1 -0
  358. package/dist/tests/database/multi-project/multi-project.test.d.ts.map +1 -0
  359. package/dist/tests/{multi-project.test.js → database/multi-project/multi-project.test.js} +5 -5
  360. package/dist/tests/database/multi-project/multi-project.test.js.map +1 -0
  361. package/dist/tests/{sql-dump-converters.test.d.ts → database/sql-dump/converters.test.d.ts} +1 -1
  362. package/dist/tests/database/sql-dump/converters.test.d.ts.map +1 -0
  363. package/dist/tests/{sql-dump-converters.test.js → database/sql-dump/converters.test.js} +2 -2
  364. package/dist/tests/database/sql-dump/converters.test.js.map +1 -0
  365. package/dist/tests/{sql-dump-default-conversions.test.d.ts → database/sql-dump/default-conversions.test.d.ts} +1 -1
  366. package/dist/tests/database/sql-dump/default-conversions.test.d.ts.map +1 -0
  367. package/dist/tests/{sql-dump-default-conversions.test.js → database/sql-dump/default-conversions.test.js} +2 -2
  368. package/dist/tests/database/sql-dump/default-conversions.test.js.map +1 -0
  369. package/dist/tests/database/sql-dump/table-ordering.test.d.ts +27 -0
  370. package/dist/tests/database/sql-dump/table-ordering.test.d.ts.map +1 -0
  371. package/dist/tests/{sql-dump-table-ordering.test.js → database/sql-dump/table-ordering.test.js} +34 -8
  372. package/dist/tests/database/sql-dump/table-ordering.test.js.map +1 -0
  373. package/dist/tests/database/sql-dump/type-conversion.test.d.ts.map +1 -0
  374. package/dist/tests/{type-conversion.test.js → database/sql-dump/type-conversion.test.js} +1 -1
  375. package/dist/tests/database/sql-dump/type-conversion.test.js.map +1 -0
  376. package/dist/tests/database/testing-config.d.ts +105 -0
  377. package/dist/tests/database/testing-config.d.ts.map +1 -0
  378. package/dist/tests/database/testing-config.js +192 -0
  379. package/dist/tests/database/testing-config.js.map +1 -0
  380. package/dist/tests/{sql-dump-cross-database.test.d.ts → docker/cross-database.test.d.ts} +1 -1
  381. package/dist/tests/docker/cross-database.test.d.ts.map +1 -0
  382. package/dist/tests/{sql-dump-cross-database.test.js → docker/cross-database.test.js} +3 -3
  383. package/dist/tests/docker/cross-database.test.js.map +1 -0
  384. package/dist/tests/docker/dump-import.test.d.ts.map +1 -0
  385. package/dist/tests/{dump-import.test.js → docker/dump-import.test.js} +25 -31
  386. package/dist/tests/docker/dump-import.test.js.map +1 -0
  387. package/dist/tests/{sql-dump-fk-constraints.test.d.ts → docker/fk-constraints.test.d.ts} +1 -1
  388. package/dist/tests/docker/fk-constraints.test.d.ts.map +1 -0
  389. package/dist/tests/{sql-dump-fk-constraints.test.js → docker/fk-constraints.test.js} +3 -3
  390. package/dist/tests/docker/fk-constraints.test.js.map +1 -0
  391. package/dist/tests/{sql-dump-indexes.test.d.ts → docker/indexes.test.d.ts} +1 -1
  392. package/dist/tests/docker/indexes.test.d.ts.map +1 -0
  393. package/dist/tests/{sql-dump-indexes.test.js → docker/indexes.test.js} +10 -29
  394. package/dist/tests/docker/indexes.test.js.map +1 -0
  395. package/dist/tests/{sql-dump-integration.test.d.ts → docker/integration.test.d.ts} +1 -1
  396. package/dist/tests/docker/integration.test.d.ts.map +1 -0
  397. package/dist/tests/{sql-dump-integration.test.js → docker/integration.test.js} +9 -28
  398. package/dist/tests/docker/integration.test.js.map +1 -0
  399. package/dist/tests/docker/multi-project-migration.test.d.ts.map +1 -0
  400. package/dist/tests/{multi-project-migration.test.js → docker/multi-project-migration.test.js} +20 -8
  401. package/dist/tests/docker/multi-project-migration.test.js.map +1 -0
  402. package/dist/tests/docker/native/constraint-operations.test.d.ts +23 -0
  403. package/dist/tests/docker/native/constraint-operations.test.d.ts.map +1 -0
  404. package/dist/tests/docker/native/constraint-operations.test.js +693 -0
  405. package/dist/tests/docker/native/constraint-operations.test.js.map +1 -0
  406. package/dist/tests/docker/native/db-init.d.ts +59 -0
  407. package/dist/tests/docker/native/db-init.d.ts.map +1 -0
  408. package/dist/tests/docker/native/db-init.js +207 -0
  409. package/dist/tests/docker/native/db-init.js.map +1 -0
  410. package/dist/tests/docker/native/decision-operations.test.d.ts +16 -0
  411. package/dist/tests/docker/native/decision-operations.test.d.ts.map +1 -0
  412. package/dist/tests/docker/native/decision-operations.test.js +590 -0
  413. package/dist/tests/docker/native/decision-operations.test.js.map +1 -0
  414. package/dist/tests/docker/native/help-system.test.d.ts +10 -0
  415. package/dist/tests/docker/native/help-system.test.d.ts.map +1 -0
  416. package/dist/tests/docker/native/help-system.test.js +568 -0
  417. package/dist/tests/docker/native/help-system.test.js.map +1 -0
  418. package/dist/tests/docker/native/suggest-tool.test.d.ts +16 -0
  419. package/dist/tests/docker/native/suggest-tool.test.d.ts.map +1 -0
  420. package/dist/tests/docker/native/suggest-tool.test.js +607 -0
  421. package/dist/tests/docker/native/suggest-tool.test.js.map +1 -0
  422. package/dist/tests/docker/native/task-operations.test.d.ts +16 -0
  423. package/dist/tests/docker/native/task-operations.test.d.ts.map +1 -0
  424. package/dist/tests/docker/native/task-operations.test.js +836 -0
  425. package/dist/tests/docker/native/task-operations.test.js.map +1 -0
  426. package/dist/tests/docker/native/test-harness.d.ts +129 -0
  427. package/dist/tests/docker/native/test-harness.d.ts.map +1 -0
  428. package/dist/tests/docker/native/test-harness.js +314 -0
  429. package/dist/tests/docker/native/test-harness.js.map +1 -0
  430. package/dist/tests/docker/schema-migration.test.d.ts.map +1 -0
  431. package/dist/tests/{schema-migration.test.js → docker/schema-migration.test.js} +8 -18
  432. package/dist/tests/docker/schema-migration.test.js.map +1 -0
  433. package/dist/tests/feature/decision/analytics.test.d.ts +7 -0
  434. package/dist/tests/feature/decision/analytics.test.d.ts.map +1 -0
  435. package/dist/tests/feature/decision/analytics.test.js +140 -0
  436. package/dist/tests/feature/decision/analytics.test.js.map +1 -0
  437. package/dist/tests/feature/decision/batch-validation-comprehensive.test.d.ts.map +1 -0
  438. package/dist/tests/{batch-validation-comprehensive.test.js → feature/decision/batch-validation-comprehensive.test.js} +5 -5
  439. package/dist/tests/feature/decision/batch-validation-comprehensive.test.js.map +1 -0
  440. package/dist/tests/feature/decision/batch-validation-integration.test.d.ts.map +1 -0
  441. package/dist/tests/{batch-validation-integration.test.js → feature/decision/batch-validation-integration.test.js} +3 -3
  442. package/dist/tests/feature/decision/batch-validation-integration.test.js.map +1 -0
  443. package/dist/tests/{decision-batch-validation.test.d.ts → feature/decision/batch-validation.test.d.ts} +1 -1
  444. package/dist/tests/feature/decision/batch-validation.test.d.ts.map +1 -0
  445. package/dist/tests/{decision-batch-validation.test.js → feature/decision/batch-validation.test.js} +4 -4
  446. package/dist/tests/feature/decision/batch-validation.test.js.map +1 -0
  447. package/dist/tests/feature/decision/context-modular.test.d.ts.map +1 -0
  448. package/dist/tests/{context-modular.test.js → feature/decision/context-modular.test.js} +17 -8
  449. package/dist/tests/feature/decision/context-modular.test.js.map +1 -0
  450. package/dist/tests/feature/help/help-system.test.d.ts.map +1 -0
  451. package/dist/tests/{help-system.test.js → feature/help/help-system.test.js} +9 -9
  452. package/dist/tests/feature/help/help-system.test.js.map +1 -0
  453. package/dist/tests/{tasks.auto-pruning-decision-link.test.d.ts → feature/task/auto-pruning-decision-link.test.d.ts} +1 -1
  454. package/dist/tests/feature/task/auto-pruning-decision-link.test.d.ts.map +1 -0
  455. package/dist/tests/{tasks.auto-pruning-decision-link.test.js → feature/task/auto-pruning-decision-link.test.js} +30 -8
  456. package/dist/tests/feature/task/auto-pruning-decision-link.test.js.map +1 -0
  457. package/dist/tests/{tasks.auto-pruning-partial.test.d.ts → feature/task/auto-pruning-partial.test.d.ts} +1 -1
  458. package/dist/tests/feature/task/auto-pruning-partial.test.d.ts.map +1 -0
  459. package/dist/tests/{tasks.auto-pruning-partial.test.js → feature/task/auto-pruning-partial.test.js} +26 -4
  460. package/dist/tests/feature/task/auto-pruning-partial.test.js.map +1 -0
  461. package/dist/tests/{tasks.auto-pruning-persistence.test.d.ts → feature/task/auto-pruning-persistence.test.d.ts} +1 -1
  462. package/dist/tests/feature/task/auto-pruning-persistence.test.d.ts.map +1 -0
  463. package/dist/tests/{tasks.auto-pruning-persistence.test.js → feature/task/auto-pruning-persistence.test.js} +23 -3
  464. package/dist/tests/feature/task/auto-pruning-persistence.test.js.map +1 -0
  465. package/dist/tests/{tasks.auto-pruning-safety.test.d.ts → feature/task/auto-pruning-safety.test.d.ts} +1 -1
  466. package/dist/tests/feature/task/auto-pruning-safety.test.d.ts.map +1 -0
  467. package/dist/tests/{tasks.auto-pruning-safety.test.js → feature/task/auto-pruning-safety.test.js} +46 -20
  468. package/dist/tests/feature/task/auto-pruning-safety.test.js.map +1 -0
  469. package/dist/tests/{tasks.dependencies.test.d.ts → feature/task/dependencies.test.d.ts} +1 -1
  470. package/dist/tests/feature/task/dependencies.test.d.ts.map +1 -0
  471. package/dist/tests/{tasks.dependencies.test.js → feature/task/dependencies.test.js} +46 -30
  472. package/dist/tests/feature/task/dependencies.test.js.map +1 -0
  473. package/dist/tests/{tasks.file-actions-integration.test.d.ts → feature/task/file-actions-integration.test.d.ts} +1 -1
  474. package/dist/tests/feature/task/file-actions-integration.test.d.ts.map +1 -0
  475. package/dist/tests/{tasks.file-actions-integration.test.js → feature/task/file-actions-integration.test.js} +6 -6
  476. package/dist/tests/feature/task/file-actions-integration.test.js.map +1 -0
  477. package/dist/tests/{tasks.file-actions-validation.test.d.ts → feature/task/file-actions-validation.test.d.ts} +1 -1
  478. package/dist/tests/feature/task/file-actions-validation.test.d.ts.map +1 -0
  479. package/dist/tests/{tasks.file-actions-validation.test.js → feature/task/file-actions-validation.test.js} +11 -4
  480. package/dist/tests/feature/task/file-actions-validation.test.js.map +1 -0
  481. package/dist/tests/{tasks.link-file-backward-compat.test.d.ts → feature/task/link-file-backward-compat.test.d.ts} +1 -1
  482. package/dist/tests/feature/task/link-file-backward-compat.test.d.ts.map +1 -0
  483. package/dist/tests/{tasks.link-file-backward-compat.test.js → feature/task/link-file-backward-compat.test.js} +65 -40
  484. package/dist/tests/feature/task/link-file-backward-compat.test.js.map +1 -0
  485. package/dist/tests/{tasks.watch-files-action.test.d.ts → feature/task/watch-files-action.test.d.ts} +3 -1
  486. package/dist/tests/feature/task/watch-files-action.test.d.ts.map +1 -0
  487. package/dist/tests/{tasks.watch-files-action.test.js → feature/task/watch-files-action.test.js} +58 -36
  488. package/dist/tests/feature/task/watch-files-action.test.js.map +1 -0
  489. package/dist/tests/{tasks.watch-files-parameter.test.d.ts → feature/task/watch-files-parameter.test.d.ts} +3 -1
  490. package/dist/tests/feature/task/watch-files-parameter.test.d.ts.map +1 -0
  491. package/dist/tests/{tasks.watch-files-parameter.test.js → feature/task/watch-files-parameter.test.js} +64 -39
  492. package/dist/tests/feature/task/watch-files-parameter.test.js.map +1 -0
  493. package/dist/tests/feature/vcs/git-aware-completion.test.d.ts.map +1 -0
  494. package/dist/tests/{git-aware-completion.test.js → feature/vcs/git-aware-completion.test.js} +25 -11
  495. package/dist/tests/feature/vcs/git-aware-completion.test.js.map +1 -0
  496. package/dist/tests/feature/vcs/two-step-git-completion.test.d.ts.map +1 -0
  497. package/dist/tests/{two-step-git-completion.test.js → feature/vcs/two-step-git-completion.test.js} +2 -2
  498. package/dist/tests/feature/vcs/two-step-git-completion.test.js.map +1 -0
  499. package/dist/tests/feature/vcs/vcs-staging.test.d.ts.map +1 -0
  500. package/dist/tests/{vcs-staging.test.js → feature/vcs/vcs-staging.test.js} +8 -3
  501. package/dist/tests/feature/vcs/vcs-staging.test.js.map +1 -0
  502. package/dist/tests/{all-features.test.d.ts → integration/all-features.standalone.d.ts} +1 -1
  503. package/dist/tests/integration/all-features.standalone.d.ts.map +1 -0
  504. package/dist/tests/{all-features.test.js → integration/all-features.standalone.js} +7 -9
  505. package/dist/tests/integration/all-features.standalone.js.map +1 -0
  506. package/dist/tests/integration/auto-trigger-suggestions.test.d.ts +7 -0
  507. package/dist/tests/integration/auto-trigger-suggestions.test.d.ts.map +1 -0
  508. package/dist/tests/integration/auto-trigger-suggestions.test.js +331 -0
  509. package/dist/tests/integration/auto-trigger-suggestions.test.js.map +1 -0
  510. package/dist/tests/integration/decision-intelligence-e2e.test.d.ts +13 -0
  511. package/dist/tests/integration/decision-intelligence-e2e.test.d.ts.map +1 -0
  512. package/dist/tests/integration/decision-intelligence-e2e.test.js +558 -0
  513. package/dist/tests/integration/decision-intelligence-e2e.test.js.map +1 -0
  514. package/dist/tests/integration/e2e-workflow1-debug.test.d.ts +5 -0
  515. package/dist/tests/integration/e2e-workflow1-debug.test.d.ts.map +1 -0
  516. package/dist/tests/integration/e2e-workflow1-debug.test.js +99 -0
  517. package/dist/tests/integration/e2e-workflow1-debug.test.js.map +1 -0
  518. package/dist/tests/integration/hybrid-similarity-detection.test.d.ts +7 -0
  519. package/dist/tests/integration/hybrid-similarity-detection.test.d.ts.map +1 -0
  520. package/dist/tests/integration/hybrid-similarity-detection.test.js +512 -0
  521. package/dist/tests/integration/hybrid-similarity-detection.test.js.map +1 -0
  522. package/dist/tests/integration/suggest-simple.test.d.ts +5 -0
  523. package/dist/tests/integration/suggest-simple.test.d.ts.map +1 -0
  524. package/dist/tests/integration/suggest-simple.test.js +72 -0
  525. package/dist/tests/integration/suggest-simple.test.js.map +1 -0
  526. package/dist/tests/unit/universal-knex.test.d.ts +2 -0
  527. package/dist/tests/unit/universal-knex.test.d.ts.map +1 -0
  528. package/dist/tests/unit/universal-knex.test.js +250 -0
  529. package/dist/tests/unit/universal-knex.test.js.map +1 -0
  530. package/dist/tests/unit/utils/config-loader.test.d.ts.map +1 -0
  531. package/dist/tests/{config-loader.test.js → unit/utils/config-loader.test.js} +63 -42
  532. package/dist/tests/unit/utils/config-loader.test.js.map +1 -0
  533. package/dist/tests/unit/utils/project-detector.test.d.ts.map +1 -0
  534. package/dist/tests/{project-detector.test.js → unit/utils/project-detector.test.js} +1 -1
  535. package/dist/tests/unit/utils/project-detector.test.js.map +1 -0
  536. package/dist/tests/unit/utils/semver.test.d.ts +2 -0
  537. package/dist/tests/unit/utils/semver.test.d.ts.map +1 -0
  538. package/dist/tests/unit/utils/semver.test.js +72 -0
  539. package/dist/tests/unit/utils/semver.test.js.map +1 -0
  540. package/dist/tests/unit/validation/batch-validation.test.d.ts.map +1 -0
  541. package/dist/tests/{batch-validation.test.js → unit/validation/batch-validation.test.js} +2 -2
  542. package/dist/tests/unit/validation/batch-validation.test.js.map +1 -0
  543. package/dist/tests/unit/validation/parameter-validation.test.d.ts.map +1 -0
  544. package/dist/tests/{parameter-validation.test.js → unit/validation/parameter-validation.test.js} +9 -12
  545. package/dist/tests/unit/validation/parameter-validation.test.js.map +1 -0
  546. package/dist/tests/unit/validation/policy-validation.test.d.ts +15 -0
  547. package/dist/tests/unit/validation/policy-validation.test.d.ts.map +1 -0
  548. package/dist/tests/unit/validation/policy-validation.test.js +343 -0
  549. package/dist/tests/unit/validation/policy-validation.test.js.map +1 -0
  550. package/dist/tests/utils/db-config.d.ts +21 -0
  551. package/dist/tests/utils/db-config.d.ts.map +1 -0
  552. package/dist/tests/utils/db-config.js +59 -0
  553. package/dist/tests/utils/db-config.js.map +1 -0
  554. package/dist/tests/utils/db-import.d.ts +11 -0
  555. package/dist/tests/utils/db-import.d.ts.map +1 -0
  556. package/dist/tests/utils/db-import.js +38 -0
  557. package/dist/tests/utils/db-import.js.map +1 -0
  558. package/dist/tests/utils/db-schema.d.ts +58 -0
  559. package/dist/tests/utils/db-schema.d.ts.map +1 -0
  560. package/dist/tests/utils/db-schema.js +218 -0
  561. package/dist/tests/utils/db-schema.js.map +1 -0
  562. package/dist/tests/utils/db-seeding.d.ts +18 -0
  563. package/dist/tests/utils/db-seeding.d.ts.map +1 -0
  564. package/dist/tests/utils/db-seeding.js +54 -0
  565. package/dist/tests/utils/db-seeding.js.map +1 -0
  566. package/dist/tests/utils/index.d.ts +20 -0
  567. package/dist/tests/utils/index.d.ts.map +1 -0
  568. package/dist/tests/utils/index.js +26 -0
  569. package/dist/tests/utils/index.js.map +1 -0
  570. package/dist/tests/utils/task-helpers.d.ts +67 -0
  571. package/dist/tests/utils/task-helpers.d.ts.map +1 -0
  572. package/dist/tests/utils/task-helpers.js +151 -0
  573. package/dist/tests/utils/task-helpers.js.map +1 -0
  574. package/dist/tests/utils/test-helpers.d.ts +93 -1
  575. package/dist/tests/utils/test-helpers.d.ts.map +1 -1
  576. package/dist/tests/utils/test-helpers.js +232 -64
  577. package/dist/tests/utils/test-helpers.js.map +1 -1
  578. package/dist/tests/utils/test-lifecycle.d.ts +52 -0
  579. package/dist/tests/utils/test-lifecycle.d.ts.map +1 -0
  580. package/dist/tests/utils/test-lifecycle.js +88 -0
  581. package/dist/tests/utils/test-lifecycle.js.map +1 -0
  582. package/dist/tools/context/actions/analytics.d.ts +88 -0
  583. package/dist/tools/context/actions/analytics.d.ts.map +1 -0
  584. package/dist/tools/context/actions/analytics.js +92 -0
  585. package/dist/tools/context/actions/analytics.js.map +1 -0
  586. package/dist/tools/context/actions/create-policy.d.ts +38 -0
  587. package/dist/tools/context/actions/create-policy.d.ts.map +1 -0
  588. package/dist/tools/context/actions/create-policy.js +87 -0
  589. package/dist/tools/context/actions/create-policy.js.map +1 -0
  590. package/dist/tools/context/actions/create-template.js +2 -2
  591. package/dist/tools/context/actions/create-template.js.map +1 -1
  592. package/dist/tools/context/actions/get.d.ts.map +1 -1
  593. package/dist/tools/context/actions/get.js +5 -4
  594. package/dist/tools/context/actions/get.js.map +1 -1
  595. package/dist/tools/context/actions/has-updates.d.ts.map +1 -1
  596. package/dist/tools/context/actions/has-updates.js +4 -19
  597. package/dist/tools/context/actions/has-updates.js.map +1 -1
  598. package/dist/tools/context/actions/list-policies.d.ts +31 -0
  599. package/dist/tools/context/actions/list-policies.d.ts.map +1 -0
  600. package/dist/tools/context/actions/list-policies.js +55 -0
  601. package/dist/tools/context/actions/list-policies.js.map +1 -0
  602. package/dist/tools/context/actions/list-templates.d.ts.map +1 -1
  603. package/dist/tools/context/actions/list-templates.js +2 -1
  604. package/dist/tools/context/actions/list-templates.js.map +1 -1
  605. package/dist/tools/context/actions/list.d.ts +1 -1
  606. package/dist/tools/context/actions/list.d.ts.map +1 -1
  607. package/dist/tools/context/actions/list.js +24 -18
  608. package/dist/tools/context/actions/list.js.map +1 -1
  609. package/dist/tools/context/actions/search-advanced.d.ts.map +1 -1
  610. package/dist/tools/context/actions/search-advanced.js +61 -42
  611. package/dist/tools/context/actions/search-advanced.js.map +1 -1
  612. package/dist/tools/context/actions/search-layer.d.ts.map +1 -1
  613. package/dist/tools/context/actions/search-layer.js +16 -7
  614. package/dist/tools/context/actions/search-layer.js.map +1 -1
  615. package/dist/tools/context/actions/search-tags.d.ts.map +1 -1
  616. package/dist/tools/context/actions/search-tags.js +22 -14
  617. package/dist/tools/context/actions/search-tags.js.map +1 -1
  618. package/dist/tools/context/actions/set-from-policy.d.ts +28 -0
  619. package/dist/tools/context/actions/set-from-policy.d.ts.map +1 -0
  620. package/dist/tools/context/actions/set-from-policy.js +54 -0
  621. package/dist/tools/context/actions/set-from-policy.js.map +1 -0
  622. package/dist/tools/context/actions/set-from-template.d.ts.map +1 -1
  623. package/dist/tools/context/actions/set-from-template.js +2 -1
  624. package/dist/tools/context/actions/set-from-template.js.map +1 -1
  625. package/dist/tools/context/index.d.ts +5 -0
  626. package/dist/tools/context/index.d.ts.map +1 -1
  627. package/dist/tools/context/index.js +5 -0
  628. package/dist/tools/context/index.js.map +1 -1
  629. package/dist/tools/context/internal/queries.d.ts.map +1 -1
  630. package/dist/tools/context/internal/queries.js +551 -31
  631. package/dist/tools/context/internal/queries.js.map +1 -1
  632. package/dist/tools/context/internal/validation.d.ts +4 -0
  633. package/dist/tools/context/internal/validation.d.ts.map +1 -1
  634. package/dist/tools/context/internal/validation.js +13 -0
  635. package/dist/tools/context/internal/validation.js.map +1 -1
  636. package/dist/tools/help/actions/query-action.js +1 -1
  637. package/dist/tools/help/actions/query-action.js.map +1 -1
  638. package/dist/tools/help/actions/query-params.js +1 -1
  639. package/dist/tools/help/actions/query-params.js.map +1 -1
  640. package/dist/tools/help/actions/query-tool.js +1 -1
  641. package/dist/tools/help/actions/query-tool.js.map +1 -1
  642. package/dist/tools/help-queries.d.ts +12 -12
  643. package/dist/tools/help-queries.d.ts.map +1 -1
  644. package/dist/tools/help-queries.js +121 -140
  645. package/dist/tools/help-queries.js.map +1 -1
  646. package/dist/tools/suggest/actions/by-context.d.ts +28 -0
  647. package/dist/tools/suggest/actions/by-context.d.ts.map +1 -0
  648. package/dist/tools/suggest/actions/by-context.js +68 -0
  649. package/dist/tools/suggest/actions/by-context.js.map +1 -0
  650. package/dist/tools/suggest/actions/by-key.d.ts +20 -0
  651. package/dist/tools/suggest/actions/by-key.d.ts.map +1 -0
  652. package/dist/tools/suggest/actions/by-key.js +55 -0
  653. package/dist/tools/suggest/actions/by-key.js.map +1 -0
  654. package/dist/tools/suggest/actions/by-tags.d.ts +23 -0
  655. package/dist/tools/suggest/actions/by-tags.d.ts.map +1 -0
  656. package/dist/tools/suggest/actions/by-tags.js +58 -0
  657. package/dist/tools/suggest/actions/by-tags.js.map +1 -0
  658. package/dist/tools/suggest/actions/check-duplicate.d.ts +20 -0
  659. package/dist/tools/suggest/actions/check-duplicate.d.ts.map +1 -0
  660. package/dist/tools/suggest/actions/check-duplicate.js +59 -0
  661. package/dist/tools/suggest/actions/check-duplicate.js.map +1 -0
  662. package/dist/tools/suggest/help/help.d.ts +5 -0
  663. package/dist/tools/suggest/help/help.d.ts.map +1 -0
  664. package/dist/tools/suggest/help/help.js +50 -0
  665. package/dist/tools/suggest/help/help.js.map +1 -0
  666. package/dist/tools/suggest/index.d.ts +18 -0
  667. package/dist/tools/suggest/index.d.ts.map +1 -0
  668. package/dist/tools/suggest/index.js +55 -0
  669. package/dist/tools/suggest/index.js.map +1 -0
  670. package/dist/tools/suggest/internal/queries.d.ts +60 -0
  671. package/dist/tools/suggest/internal/queries.d.ts.map +1 -0
  672. package/dist/tools/suggest/internal/queries.js +154 -0
  673. package/dist/tools/suggest/internal/queries.js.map +1 -0
  674. package/dist/tools/suggest/types.d.ts +70 -0
  675. package/dist/tools/suggest/types.d.ts.map +1 -0
  676. package/dist/tools/suggest/types.js +5 -0
  677. package/dist/tools/suggest/types.js.map +1 -0
  678. package/dist/tools/tasks/actions/link-pruned-file.d.ts +1 -0
  679. package/dist/tools/tasks/actions/link-pruned-file.d.ts.map +1 -1
  680. package/dist/tools/tasks/actions/link-pruned-file.js +7 -2
  681. package/dist/tools/tasks/actions/link-pruned-file.js.map +1 -1
  682. package/dist/tools/tasks/actions/link.d.ts.map +1 -1
  683. package/dist/tools/tasks/actions/link.js +4 -2
  684. package/dist/tools/tasks/actions/link.js.map +1 -1
  685. package/dist/tools/tasks/actions/list.d.ts.map +1 -1
  686. package/dist/tools/tasks/actions/list.js +37 -35
  687. package/dist/tools/tasks/actions/list.js.map +1 -1
  688. package/dist/tools/use_case/actions/search.d.ts +1 -1
  689. package/dist/tools/use_case/actions/search.d.ts.map +1 -1
  690. package/dist/tools/use_case/actions/search.js +31 -40
  691. package/dist/tools/use_case/actions/search.js.map +1 -1
  692. package/dist/types/actions.d.ts +10 -0
  693. package/dist/types/actions.d.ts.map +1 -1
  694. package/dist/types/decision/params.d.ts +7 -0
  695. package/dist/types/decision/params.d.ts.map +1 -1
  696. package/dist/types/decision/responses.d.ts +38 -0
  697. package/dist/types/decision/responses.d.ts.map +1 -1
  698. package/dist/types/view-entities.d.ts +1 -0
  699. package/dist/types/view-entities.d.ts.map +1 -1
  700. package/dist/types.d.ts +154 -1
  701. package/dist/types.d.ts.map +1 -1
  702. package/dist/utils/action-specs/decision-specs.js +3 -3
  703. package/dist/utils/action-specs/decision-specs.js.map +1 -1
  704. package/dist/utils/activity-logging.d.ts.map +1 -1
  705. package/dist/utils/activity-logging.js +7 -0
  706. package/dist/utils/activity-logging.js.map +1 -1
  707. package/dist/utils/db-aggregations.d.ts +88 -0
  708. package/dist/utils/db-aggregations.d.ts.map +1 -0
  709. package/dist/utils/db-aggregations.js +158 -0
  710. package/dist/utils/db-aggregations.js.map +1 -0
  711. package/dist/utils/file-pruning.d.ts +37 -13
  712. package/dist/utils/file-pruning.d.ts.map +1 -1
  713. package/dist/utils/file-pruning.js +93 -84
  714. package/dist/utils/file-pruning.js.map +1 -1
  715. package/dist/utils/policy-validator.d.ts +37 -0
  716. package/dist/utils/policy-validator.d.ts.map +1 -0
  717. package/dist/utils/policy-validator.js +240 -0
  718. package/dist/utils/policy-validator.js.map +1 -0
  719. package/dist/utils/quality-checks.d.ts +7 -7
  720. package/dist/utils/quality-checks.d.ts.map +1 -1
  721. package/dist/utils/quality-checks.js +18 -21
  722. package/dist/utils/quality-checks.js.map +1 -1
  723. package/dist/utils/semver.d.ts +50 -0
  724. package/dist/utils/semver.d.ts.map +1 -0
  725. package/dist/utils/semver.js +78 -0
  726. package/dist/utils/semver.js.map +1 -0
  727. package/dist/utils/sql-dump/schema/tables.d.ts.map +1 -1
  728. package/dist/utils/sql-dump/schema/tables.js +125 -7
  729. package/dist/utils/sql-dump/schema/tables.js.map +1 -1
  730. package/dist/utils/sql-dump/schema/views.d.ts.map +1 -1
  731. package/dist/utils/sql-dump/schema/views.js +6 -0
  732. package/dist/utils/sql-dump/schema/views.js.map +1 -1
  733. package/dist/utils/suggestion-scorer.d.ts +62 -0
  734. package/dist/utils/suggestion-scorer.d.ts.map +1 -0
  735. package/dist/utils/suggestion-scorer.js +169 -0
  736. package/dist/utils/suggestion-scorer.js.map +1 -0
  737. package/dist/utils/tag-parser.d.ts +52 -0
  738. package/dist/utils/tag-parser.d.ts.map +1 -0
  739. package/dist/utils/tag-parser.js +65 -0
  740. package/dist/utils/tag-parser.js.map +1 -0
  741. package/dist/utils/task-stale-detection.d.ts.map +1 -1
  742. package/dist/utils/task-stale-detection.js +40 -4
  743. package/dist/utils/task-stale-detection.js.map +1 -1
  744. package/dist/utils/token-logging.d.ts +9 -9
  745. package/dist/utils/token-logging.d.ts.map +1 -1
  746. package/dist/utils/token-logging.js +36 -38
  747. package/dist/utils/token-logging.js.map +1 -1
  748. package/dist/utils/universal-knex.d.ts +169 -0
  749. package/dist/utils/universal-knex.d.ts.map +1 -0
  750. package/dist/utils/universal-knex.js +318 -0
  751. package/dist/utils/universal-knex.js.map +1 -0
  752. package/dist/utils/validators.d.ts +2 -2
  753. package/dist/utils/validators.d.ts.map +1 -1
  754. package/dist/utils/validators.js +3 -2
  755. package/dist/utils/validators.js.map +1 -1
  756. package/dist/utils/vcs-adapter.d.ts.map +1 -1
  757. package/dist/utils/vcs-adapter.js +21 -14
  758. package/dist/utils/vcs-adapter.js.map +1 -1
  759. package/dist/utils/view-queries.d.ts +11 -3
  760. package/dist/utils/view-queries.d.ts.map +1 -1
  761. package/dist/utils/view-queries.js +122 -87
  762. package/dist/utils/view-queries.js.map +1 -1
  763. package/dist/watcher/file-watcher.d.ts.map +1 -1
  764. package/dist/watcher/file-watcher.js +99 -84
  765. package/dist/watcher/file-watcher.js.map +1 -1
  766. package/docs/BEST_PRACTICES.md +10 -0
  767. package/docs/DECISION_CONTEXT.md +190 -1
  768. package/docs/DECISION_INTELLIGENCE.md +594 -0
  769. package/docs/MIGRATION_GUIDE_V3.9.0.md +371 -0
  770. package/docs/SLASH_COMMANDS.md +652 -0
  771. package/docs/TOOL_REFERENCE.md +164 -22
  772. package/docs/TOOL_SELECTION.md +16 -2
  773. package/docs/WORKFLOWS.md +163 -0
  774. package/docs/changelogs/CHANGELOG_ARCHIVE_v3.4_and_older.md +296 -0
  775. package/package.json +37 -12
  776. package/scripts/check-cross-db-patterns.sh +105 -0
  777. package/scripts/filter-test-output.js +74 -0
  778. package/scripts/verify-migrations.sh +129 -0
  779. package/dist/tests/all-features.test.d.ts.map +0 -1
  780. package/dist/tests/all-features.test.js.map +0 -1
  781. package/dist/tests/batch-validation-comprehensive.test.d.ts.map +0 -1
  782. package/dist/tests/batch-validation-comprehensive.test.js.map +0 -1
  783. package/dist/tests/batch-validation-integration.test.d.ts.map +0 -1
  784. package/dist/tests/batch-validation-integration.test.js.map +0 -1
  785. package/dist/tests/batch-validation.test.d.ts.map +0 -1
  786. package/dist/tests/batch-validation.test.js.map +0 -1
  787. package/dist/tests/config-loader.test.d.ts.map +0 -1
  788. package/dist/tests/config-loader.test.js.map +0 -1
  789. package/dist/tests/connection-manager-integration.test.d.ts.map +0 -1
  790. package/dist/tests/connection-manager-integration.test.js.map +0 -1
  791. package/dist/tests/connection-manager.test.d.ts.map +0 -1
  792. package/dist/tests/connection-manager.test.js.map +0 -1
  793. package/dist/tests/context-modular.test.d.ts.map +0 -1
  794. package/dist/tests/context-modular.test.js.map +0 -1
  795. package/dist/tests/decision-batch-validation.test.d.ts.map +0 -1
  796. package/dist/tests/decision-batch-validation.test.js.map +0 -1
  797. package/dist/tests/dump-import.test.d.ts.map +0 -1
  798. package/dist/tests/dump-import.test.js.map +0 -1
  799. package/dist/tests/git-aware-completion.test.d.ts.map +0 -1
  800. package/dist/tests/git-aware-completion.test.js.map +0 -1
  801. package/dist/tests/help-system.test.d.ts.map +0 -1
  802. package/dist/tests/help-system.test.js.map +0 -1
  803. package/dist/tests/migration-idempotency.test.d.ts +0 -2
  804. package/dist/tests/migration-idempotency.test.d.ts.map +0 -1
  805. package/dist/tests/migration-idempotency.test.js.map +0 -1
  806. package/dist/tests/migration-upgrade-paths.test.d.ts +0 -2
  807. package/dist/tests/migration-upgrade-paths.test.d.ts.map +0 -1
  808. package/dist/tests/migration-upgrade-paths.test.js.map +0 -1
  809. package/dist/tests/multi-project-migration.test.d.ts.map +0 -1
  810. package/dist/tests/multi-project-migration.test.js.map +0 -1
  811. package/dist/tests/multi-project.test.d.ts.map +0 -1
  812. package/dist/tests/multi-project.test.js.map +0 -1
  813. package/dist/tests/parameter-validation.test.d.ts.map +0 -1
  814. package/dist/tests/parameter-validation.test.js.map +0 -1
  815. package/dist/tests/project-detector.test.d.ts.map +0 -1
  816. package/dist/tests/project-detector.test.js.map +0 -1
  817. package/dist/tests/schema-migration.test.d.ts.map +0 -1
  818. package/dist/tests/schema-migration.test.js.map +0 -1
  819. package/dist/tests/sql-dump-converters.test.d.ts.map +0 -1
  820. package/dist/tests/sql-dump-converters.test.js.map +0 -1
  821. package/dist/tests/sql-dump-cross-database.test.d.ts.map +0 -1
  822. package/dist/tests/sql-dump-cross-database.test.js.map +0 -1
  823. package/dist/tests/sql-dump-default-conversions.test.d.ts.map +0 -1
  824. package/dist/tests/sql-dump-default-conversions.test.js.map +0 -1
  825. package/dist/tests/sql-dump-fk-constraints.test.d.ts.map +0 -1
  826. package/dist/tests/sql-dump-fk-constraints.test.js.map +0 -1
  827. package/dist/tests/sql-dump-indexes.test.d.ts.map +0 -1
  828. package/dist/tests/sql-dump-indexes.test.js.map +0 -1
  829. package/dist/tests/sql-dump-integration.test.d.ts.map +0 -1
  830. package/dist/tests/sql-dump-integration.test.js.map +0 -1
  831. package/dist/tests/sql-dump-table-ordering.test.d.ts +0 -8
  832. package/dist/tests/sql-dump-table-ordering.test.d.ts.map +0 -1
  833. package/dist/tests/sql-dump-table-ordering.test.js.map +0 -1
  834. package/dist/tests/tasks.auto-pruning-decision-link.test.d.ts.map +0 -1
  835. package/dist/tests/tasks.auto-pruning-decision-link.test.js.map +0 -1
  836. package/dist/tests/tasks.auto-pruning-partial.test.d.ts.map +0 -1
  837. package/dist/tests/tasks.auto-pruning-partial.test.js.map +0 -1
  838. package/dist/tests/tasks.auto-pruning-persistence.test.d.ts.map +0 -1
  839. package/dist/tests/tasks.auto-pruning-persistence.test.js.map +0 -1
  840. package/dist/tests/tasks.auto-pruning-safety.test.d.ts.map +0 -1
  841. package/dist/tests/tasks.auto-pruning-safety.test.js.map +0 -1
  842. package/dist/tests/tasks.dependencies.test.d.ts.map +0 -1
  843. package/dist/tests/tasks.dependencies.test.js.map +0 -1
  844. package/dist/tests/tasks.file-actions-integration.test.d.ts.map +0 -1
  845. package/dist/tests/tasks.file-actions-integration.test.js.map +0 -1
  846. package/dist/tests/tasks.file-actions-validation.test.d.ts.map +0 -1
  847. package/dist/tests/tasks.file-actions-validation.test.js.map +0 -1
  848. package/dist/tests/tasks.link-file-backward-compat.test.d.ts.map +0 -1
  849. package/dist/tests/tasks.link-file-backward-compat.test.js.map +0 -1
  850. package/dist/tests/tasks.watch-files-action.test.d.ts.map +0 -1
  851. package/dist/tests/tasks.watch-files-action.test.js.map +0 -1
  852. package/dist/tests/tasks.watch-files-parameter.test.d.ts.map +0 -1
  853. package/dist/tests/tasks.watch-files-parameter.test.js.map +0 -1
  854. package/dist/tests/two-step-git-completion.test.d.ts.map +0 -1
  855. package/dist/tests/two-step-git-completion.test.js.map +0 -1
  856. package/dist/tests/type-conversion.test.d.ts.map +0 -1
  857. package/dist/tests/type-conversion.test.js.map +0 -1
  858. package/dist/tests/vcs-staging.test.d.ts.map +0 -1
  859. package/dist/tests/vcs-staging.test.js.map +0 -1
  860. package/dist/utils/sql-dump.d.ts +0 -102
  861. package/dist/utils/sql-dump.d.ts.map +0 -1
  862. package/dist/utils/sql-dump.js +0 -1590
  863. package/dist/utils/sql-dump.js.map +0 -1
  864. /package/dist/tests/{connection-manager-integration.test.d.ts → database/connection/connection-manager-integration.test.d.ts} +0 -0
  865. /package/dist/tests/{connection-manager.test.d.ts → database/connection/connection-manager.test.d.ts} +0 -0
  866. /package/dist/tests/{multi-project.test.d.ts → database/multi-project/multi-project.test.d.ts} +0 -0
  867. /package/dist/tests/{type-conversion.test.d.ts → database/sql-dump/type-conversion.test.d.ts} +0 -0
  868. /package/dist/tests/{dump-import.test.d.ts → docker/dump-import.test.d.ts} +0 -0
  869. /package/dist/tests/{multi-project-migration.test.d.ts → docker/multi-project-migration.test.d.ts} +0 -0
  870. /package/dist/tests/{schema-migration.test.d.ts → docker/schema-migration.test.d.ts} +0 -0
  871. /package/dist/tests/{batch-validation-comprehensive.test.d.ts → feature/decision/batch-validation-comprehensive.test.d.ts} +0 -0
  872. /package/dist/tests/{batch-validation-integration.test.d.ts → feature/decision/batch-validation-integration.test.d.ts} +0 -0
  873. /package/dist/tests/{context-modular.test.d.ts → feature/decision/context-modular.test.d.ts} +0 -0
  874. /package/dist/tests/{help-system.test.d.ts → feature/help/help-system.test.d.ts} +0 -0
  875. /package/dist/tests/{git-aware-completion.test.d.ts → feature/vcs/git-aware-completion.test.d.ts} +0 -0
  876. /package/dist/tests/{two-step-git-completion.test.d.ts → feature/vcs/two-step-git-completion.test.d.ts} +0 -0
  877. /package/dist/tests/{vcs-staging.test.d.ts → feature/vcs/vcs-staging.test.d.ts} +0 -0
  878. /package/dist/tests/{config-loader.test.d.ts → unit/utils/config-loader.test.d.ts} +0 -0
  879. /package/dist/tests/{project-detector.test.d.ts → unit/utils/project-detector.test.d.ts} +0 -0
  880. /package/dist/tests/{batch-validation.test.d.ts → unit/validation/batch-validation.test.d.ts} +0 -0
  881. /package/dist/tests/{parameter-validation.test.d.ts → unit/validation/parameter-validation.test.d.ts} +0 -0
@@ -0,0 +1,836 @@
1
+ /**
2
+ * Task Operations - Native RDBMS Integration Tests
3
+ *
4
+ * Tests task table schema and operations (CRUD, dependencies, status transitions,
5
+ * FK constraints, cascade delete) on fresh MySQL, MariaDB, and PostgreSQL installations.
6
+ *
7
+ * Task #532: Refactor task-operations.test.ts to use direct Knex operations
8
+ *
9
+ * ARCHITECTURE: Native RDBMS tests focus on database layer validation.
10
+ * - NO MCP tool function imports
11
+ * - Direct Knex operations only
12
+ * - Tests database constraints, indexes, views, triggers
13
+ * - Cross-database compatibility validation
14
+ */
15
+ import { describe, it } from 'node:test';
16
+ import assert from 'node:assert';
17
+ import { createHash } from 'crypto';
18
+ import { runTestsOnAllDatabases, getLayerId, getAgentId, getTagId } from './test-harness.js';
19
+ // ============================================================================
20
+ // Hash Helper
21
+ // ============================================================================
22
+ /**
23
+ * Generate SHA256 hash for constraint text (used for UNIQUE constraint)
24
+ */
25
+ function hashConstraintText(text) {
26
+ return createHash('sha256').update(text).digest('hex');
27
+ }
28
+ // ============================================================================
29
+ // Test Helpers
30
+ // ============================================================================
31
+ /**
32
+ * Get task status ID by status name
33
+ */
34
+ async function getStatusId(db, statusName) {
35
+ const status = await db('m_task_statuses').where({ name: statusName }).first();
36
+ assert.ok(status, `Status "${statusName}" should exist`);
37
+ return status.id;
38
+ }
39
+ /**
40
+ * Insert a task with required fields (helper for test setup)
41
+ */
42
+ async function insertTask(db, data) {
43
+ const statusId = await getStatusId(db, data.status || 'todo');
44
+ const layerId = data.layer ? await getLayerId(db, data.layer) : await getLayerId(db, 'business');
45
+ const agentId = await getAgentId(db, data.assigned_agent || 'system');
46
+ const timestamp = Math.floor(Date.now() / 1000);
47
+ const insertData = {
48
+ title: data.title,
49
+ status_id: statusId,
50
+ priority: data.priority || 2,
51
+ layer_id: layerId,
52
+ assigned_agent_id: agentId,
53
+ created_by_agent_id: agentId,
54
+ project_id: 1,
55
+ created_ts: timestamp,
56
+ updated_ts: timestamp,
57
+ };
58
+ const result = await db('t_tasks').insert(insertData);
59
+ // Get the inserted ID (different return format across databases)
60
+ let taskId;
61
+ if (Array.isArray(result) && result.length > 0) {
62
+ taskId = result[0];
63
+ }
64
+ else if (typeof result === 'number') {
65
+ taskId = result;
66
+ }
67
+ else {
68
+ // Fallback: query the last inserted task
69
+ const task = await db('t_tasks')
70
+ .where({ title: data.title, project_id: 1 })
71
+ .orderBy('id', 'desc')
72
+ .first();
73
+ taskId = task.id;
74
+ }
75
+ // Insert task details if description provided
76
+ if (data.description) {
77
+ await db('t_task_details').insert({
78
+ task_id: taskId,
79
+ description: data.description,
80
+ });
81
+ }
82
+ return taskId;
83
+ }
84
+ /**
85
+ * Assert task has expected status
86
+ */
87
+ async function assertTaskHasStatus(db, taskId, expectedStatus) {
88
+ const task = await db('t_tasks')
89
+ .join('m_task_statuses', 't_tasks.status_id', 'm_task_statuses.id')
90
+ .where({ 't_tasks.id': taskId })
91
+ .select('m_task_statuses.name as status')
92
+ .first();
93
+ assert.ok(task, `Task ${taskId} should exist`);
94
+ assert.strictEqual(task.status, expectedStatus, `Task ${taskId} status should be ${expectedStatus}`);
95
+ }
96
+ // ============================================================================
97
+ // Test Suite
98
+ // ============================================================================
99
+ runTestsOnAllDatabases('Task Operations', (getDb, dbType) => {
100
+ // ============================================================================
101
+ // Basic CRUD Operations
102
+ // ============================================================================
103
+ describe('Task CRUD', () => {
104
+ it('should insert task with required fields', async () => {
105
+ const db = getDb();
106
+ const taskId = await insertTask(db, {
107
+ title: 'Implement authentication',
108
+ priority: 3,
109
+ layer: 'business',
110
+ });
111
+ assert.ok(taskId, 'Should return task ID');
112
+ // Verify task exists
113
+ const task = await db('t_tasks').where({ id: taskId, project_id: 1 }).first();
114
+ assert.strictEqual(task.title, 'Implement authentication');
115
+ assert.strictEqual(task.priority, 3);
116
+ await assertTaskHasStatus(db, taskId, 'todo');
117
+ });
118
+ it('should insert task with all optional fields', async () => {
119
+ const db = getDb();
120
+ const taskId = await insertTask(db, {
121
+ title: 'Complex task with all fields',
122
+ description: 'This is a detailed description',
123
+ priority: 4,
124
+ layer: 'infrastructure',
125
+ assigned_agent: 'backend-specialist',
126
+ });
127
+ // Verify core task data
128
+ const task = await db('t_tasks').where({ id: taskId, project_id: 1 }).first();
129
+ assert.strictEqual(task.title, 'Complex task with all fields');
130
+ assert.strictEqual(task.priority, 4);
131
+ const layerId = await getLayerId(db, 'infrastructure');
132
+ assert.strictEqual(task.layer_id, layerId);
133
+ // Verify task details
134
+ const details = await db('t_task_details').where({ task_id: taskId }).first();
135
+ assert.ok(details, 'Task details should exist');
136
+ assert.strictEqual(details.description, 'This is a detailed description');
137
+ });
138
+ it('should update task fields', async () => {
139
+ const db = getDb();
140
+ const taskId = await insertTask(db, {
141
+ title: 'Original title',
142
+ priority: 2,
143
+ });
144
+ // Update title and priority
145
+ await db('t_tasks')
146
+ .where({ id: taskId, project_id: 1 })
147
+ .update({
148
+ title: 'Updated title',
149
+ priority: 4,
150
+ updated_ts: Math.floor(Date.now() / 1000),
151
+ });
152
+ // Verify update
153
+ const task = await db('t_tasks').where({ id: taskId, project_id: 1 }).first();
154
+ assert.strictEqual(task.title, 'Updated title');
155
+ assert.strictEqual(task.priority, 4);
156
+ });
157
+ it('should delete task', async () => {
158
+ const db = getDb();
159
+ const taskId = await insertTask(db, {
160
+ title: 'Task to delete',
161
+ });
162
+ // Delete task
163
+ await db('t_tasks').where({ id: taskId, project_id: 1 }).delete();
164
+ // Verify deletion
165
+ const task = await db('t_tasks').where({ id: taskId, project_id: 1 }).first();
166
+ assert.strictEqual(task, undefined, 'Task should be deleted');
167
+ });
168
+ });
169
+ // ============================================================================
170
+ // Foreign Key Constraints
171
+ // ============================================================================
172
+ describe('Foreign Key Constraints', () => {
173
+ it('should enforce FK constraint on status_id', async () => {
174
+ const db = getDb();
175
+ const insertPromise = db('t_tasks').insert({
176
+ title: 'Invalid status task',
177
+ status_id: 99999, // Non-existent status
178
+ priority: 2,
179
+ project_id: 1,
180
+ layer_id: 1,
181
+ assigned_agent_id: 1,
182
+ created_by_agent_id: 1,
183
+ created_ts: Math.floor(Date.now() / 1000),
184
+ updated_ts: Math.floor(Date.now() / 1000),
185
+ });
186
+ await assert.rejects(insertPromise, {
187
+ message: /foreign key constraint|violates foreign key|Cannot add or update a child row/i,
188
+ });
189
+ });
190
+ it('should enforce FK constraint on layer_id', async () => {
191
+ const db = getDb();
192
+ const statusId = await getStatusId(db, 'todo');
193
+ const insertPromise = db('t_tasks').insert({
194
+ title: 'Invalid layer task',
195
+ status_id: statusId,
196
+ priority: 2,
197
+ project_id: 1,
198
+ layer_id: 99999, // Non-existent layer
199
+ assigned_agent_id: 1,
200
+ created_by_agent_id: 1,
201
+ created_ts: Math.floor(Date.now() / 1000),
202
+ updated_ts: Math.floor(Date.now() / 1000),
203
+ });
204
+ await assert.rejects(insertPromise, {
205
+ message: /foreign key constraint|violates foreign key|Cannot add or update a child row/i,
206
+ });
207
+ });
208
+ it('should enforce FK constraint on assigned_agent_id', async () => {
209
+ const db = getDb();
210
+ const statusId = await getStatusId(db, 'todo');
211
+ const layerId = await getLayerId(db, 'business');
212
+ const insertPromise = db('t_tasks').insert({
213
+ title: 'Invalid agent task',
214
+ status_id: statusId,
215
+ priority: 2,
216
+ project_id: 1,
217
+ layer_id: layerId,
218
+ assigned_agent_id: 99999, // Non-existent agent
219
+ created_by_agent_id: 1,
220
+ created_ts: Math.floor(Date.now() / 1000),
221
+ updated_ts: Math.floor(Date.now() / 1000),
222
+ });
223
+ await assert.rejects(insertPromise, {
224
+ message: /foreign key constraint|violates foreign key|Cannot add or update a child row/i,
225
+ });
226
+ });
227
+ });
228
+ // ============================================================================
229
+ // Task Status Transitions
230
+ // ============================================================================
231
+ describe('Task Status Transitions', () => {
232
+ it('should transition from todo to in_progress', async () => {
233
+ const db = getDb();
234
+ const taskId = await insertTask(db, { title: 'Move to in_progress' });
235
+ await assertTaskHasStatus(db, taskId, 'todo');
236
+ // Move to in_progress
237
+ const inProgressId = await getStatusId(db, 'in_progress');
238
+ await db('t_tasks')
239
+ .where({ id: taskId })
240
+ .update({
241
+ status_id: inProgressId,
242
+ updated_ts: Math.floor(Date.now() / 1000),
243
+ });
244
+ await assertTaskHasStatus(db, taskId, 'in_progress');
245
+ });
246
+ it('should transition from in_progress to done', async () => {
247
+ const db = getDb();
248
+ const taskId = await insertTask(db, { title: 'Complete task', status: 'in_progress' });
249
+ await assertTaskHasStatus(db, taskId, 'in_progress');
250
+ // Move to done
251
+ const doneId = await getStatusId(db, 'done');
252
+ const completedTs = Math.floor(Date.now() / 1000);
253
+ await db('t_tasks')
254
+ .where({ id: taskId })
255
+ .update({
256
+ status_id: doneId,
257
+ completed_ts: completedTs,
258
+ updated_ts: completedTs,
259
+ });
260
+ await assertTaskHasStatus(db, taskId, 'done');
261
+ // Verify completed_ts was set
262
+ const task = await db('t_tasks').where({ id: taskId }).first();
263
+ assert.ok(task.completed_ts, 'completed_ts should be set');
264
+ });
265
+ it('should transition to blocked status', async () => {
266
+ const db = getDb();
267
+ const taskId = await insertTask(db, { title: 'Blocked task' });
268
+ const blockedId = await getStatusId(db, 'blocked');
269
+ await db('t_tasks')
270
+ .where({ id: taskId })
271
+ .update({
272
+ status_id: blockedId,
273
+ updated_ts: Math.floor(Date.now() / 1000),
274
+ });
275
+ await assertTaskHasStatus(db, taskId, 'blocked');
276
+ });
277
+ it('should transition to archived status', async () => {
278
+ const db = getDb();
279
+ const taskId = await insertTask(db, { title: 'Archive task' });
280
+ const archivedId = await getStatusId(db, 'archived');
281
+ await db('t_tasks')
282
+ .where({ id: taskId })
283
+ .update({
284
+ status_id: archivedId,
285
+ updated_ts: Math.floor(Date.now() / 1000),
286
+ });
287
+ await assertTaskHasStatus(db, taskId, 'archived');
288
+ });
289
+ });
290
+ // ============================================================================
291
+ // Task File Links
292
+ // ============================================================================
293
+ describe('Task File Links', () => {
294
+ it('should insert file links for task', async () => {
295
+ const db = getDb();
296
+ const taskId = await insertTask(db, { title: 'Task with files' });
297
+ const timestamp = Math.floor(Date.now() / 1000);
298
+ // First, create file records in m_files
299
+ const file1Result = await db('m_files').insert({ project_id: 1, path: 'src/auth/login.ts' });
300
+ const file2Result = await db('m_files').insert({ project_id: 1, path: 'src/auth/types.ts' });
301
+ const file3Result = await db('m_files').insert({ project_id: 1, path: 'src/auth/old.ts' });
302
+ // Get file IDs
303
+ const file1 = await db('m_files').where({ path: 'src/auth/login.ts', project_id: 1 }).first();
304
+ const file2 = await db('m_files').where({ path: 'src/auth/types.ts', project_id: 1 }).first();
305
+ const file3 = await db('m_files').where({ path: 'src/auth/old.ts', project_id: 1 }).first();
306
+ // Insert file links
307
+ await db('t_task_file_links').insert([
308
+ { task_id: taskId, file_id: file1.id, project_id: 1, linked_ts: timestamp },
309
+ { task_id: taskId, file_id: file2.id, project_id: 1, linked_ts: timestamp },
310
+ { task_id: taskId, file_id: file3.id, project_id: 1, linked_ts: timestamp },
311
+ ]);
312
+ // Verify file links
313
+ const fileLinks = await db('t_task_file_links')
314
+ .join('m_files', 't_task_file_links.file_id', 'm_files.id')
315
+ .where({ 't_task_file_links.task_id': taskId })
316
+ .select('t_task_file_links.*', 'm_files.path')
317
+ .orderBy('m_files.path');
318
+ assert.strictEqual(fileLinks.length, 3);
319
+ assert.strictEqual(fileLinks[0].path, 'src/auth/login.ts');
320
+ assert.strictEqual(fileLinks[1].path, 'src/auth/old.ts');
321
+ assert.strictEqual(fileLinks[2].path, 'src/auth/types.ts');
322
+ });
323
+ it('should enforce unique constraint on task-file combination', async () => {
324
+ const db = getDb();
325
+ const taskId = await insertTask(db, { title: 'Unique file link test' });
326
+ const timestamp = Math.floor(Date.now() / 1000);
327
+ // Create a file record
328
+ await db('m_files').insert({ project_id: 1, path: 'src/unique-test.ts' });
329
+ const file = await db('m_files').where({ path: 'src/unique-test.ts', project_id: 1 }).first();
330
+ await db('t_task_file_links').insert({
331
+ task_id: taskId,
332
+ file_id: file.id,
333
+ project_id: 1,
334
+ linked_ts: timestamp,
335
+ });
336
+ // Try to insert duplicate
337
+ const duplicatePromise = db('t_task_file_links').insert({
338
+ task_id: taskId,
339
+ file_id: file.id,
340
+ project_id: 1,
341
+ linked_ts: timestamp,
342
+ });
343
+ await assert.rejects(duplicatePromise, {
344
+ message: /UNIQUE constraint|unique constraint|Duplicate entry/i,
345
+ });
346
+ });
347
+ it('should cascade delete file links when task deleted', async () => {
348
+ const db = getDb();
349
+ const taskId = await insertTask(db, { title: 'Cascade delete file links' });
350
+ const timestamp = Math.floor(Date.now() / 1000);
351
+ // Create a file record
352
+ await db('m_files').insert({ project_id: 1, path: 'src/cascade-test.ts' });
353
+ const file = await db('m_files').where({ path: 'src/cascade-test.ts', project_id: 1 }).first();
354
+ await db('t_task_file_links').insert({
355
+ task_id: taskId,
356
+ file_id: file.id,
357
+ project_id: 1,
358
+ linked_ts: timestamp,
359
+ });
360
+ // Delete task
361
+ await db('t_tasks').where({ id: taskId }).delete();
362
+ // Verify file links were cascade deleted
363
+ const fileLinks = await db('t_task_file_links').where({ task_id: taskId });
364
+ assert.strictEqual(fileLinks.length, 0, 'File links should be cascade deleted');
365
+ });
366
+ });
367
+ // ============================================================================
368
+ // Task Tags
369
+ // ============================================================================
370
+ describe('Task Tags', () => {
371
+ it('should associate tags with task', async () => {
372
+ const db = getDb();
373
+ const taskId = await insertTask(db, { title: 'Tagged task' });
374
+ // Get tag IDs
375
+ const apiTagId = await getTagId(db, 'api');
376
+ const securityTagId = await getTagId(db, 'security');
377
+ const perfTagId = await getTagId(db, 'performance');
378
+ // Insert tag associations (t_task_tags has no project_id)
379
+ await db('t_task_tags').insert([
380
+ { task_id: taskId, tag_id: apiTagId },
381
+ { task_id: taskId, tag_id: securityTagId },
382
+ { task_id: taskId, tag_id: perfTagId },
383
+ ]);
384
+ // Verify tags
385
+ const tags = await db('t_task_tags')
386
+ .join('m_tags', 't_task_tags.tag_id', 'm_tags.id')
387
+ .where({ 't_task_tags.task_id': taskId })
388
+ .select('m_tags.name as tag_name');
389
+ assert.strictEqual(tags.length, 3);
390
+ const tagNames = tags.map(t => t.tag_name);
391
+ assert.ok(tagNames.includes('api'));
392
+ assert.ok(tagNames.includes('security'));
393
+ assert.ok(tagNames.includes('performance'));
394
+ });
395
+ it('should cascade delete tags when task deleted', async () => {
396
+ const db = getDb();
397
+ const taskId = await insertTask(db, { title: 'Task with tags for cascade' });
398
+ const tagId = await getTagId(db, 'test');
399
+ await db('t_task_tags').insert({
400
+ task_id: taskId,
401
+ tag_id: tagId,
402
+ });
403
+ // Delete task
404
+ await db('t_tasks').where({ id: taskId }).delete();
405
+ // Verify tags were cascade deleted
406
+ const tags = await db('t_task_tags').where({ task_id: taskId });
407
+ assert.strictEqual(tags.length, 0, 'Tags should be cascade deleted');
408
+ });
409
+ });
410
+ // ============================================================================
411
+ // Task Dependencies
412
+ // ============================================================================
413
+ describe('Task Dependencies', () => {
414
+ it('should add dependency between tasks', async () => {
415
+ const db = getDb();
416
+ const blockerTaskId = await insertTask(db, { title: 'Blocker task' });
417
+ const blockedTaskId = await insertTask(db, { title: 'Blocked task' });
418
+ // Add dependency: blocker blocks blocked
419
+ await db('t_task_dependencies').insert({
420
+ blocker_task_id: blockerTaskId,
421
+ blocked_task_id: blockedTaskId,
422
+ created_ts: Math.floor(Date.now() / 1000),
423
+ });
424
+ // Verify dependency exists
425
+ const dependency = await db('t_task_dependencies')
426
+ .where({ blocker_task_id: blockerTaskId, blocked_task_id: blockedTaskId })
427
+ .first();
428
+ assert.ok(dependency, 'Dependency should exist');
429
+ });
430
+ it('should prevent self-dependency (circular dependency)', async () => {
431
+ const db = getDb();
432
+ const taskId = await insertTask(db, { title: 'Self-blocking task' });
433
+ // Try to create self-dependency
434
+ const selfDepPromise = db('t_task_dependencies').insert({
435
+ blocker_task_id: taskId,
436
+ blocked_task_id: taskId, // Same task
437
+ created_ts: Math.floor(Date.now() / 1000),
438
+ });
439
+ // Should fail (either via trigger or application-level check)
440
+ // Note: Some databases may allow this at schema level but fail at trigger level
441
+ // For now, we just test if it rejects
442
+ const shouldReject = async () => {
443
+ try {
444
+ await selfDepPromise;
445
+ // If insert succeeds, check if there's a trigger that prevents it
446
+ // This is database-specific behavior
447
+ const dep = await db('t_task_dependencies')
448
+ .where({ blocker_task_id: taskId, blocked_task_id: taskId })
449
+ .first();
450
+ // If dependency was inserted, we need to check if the application
451
+ // layer prevents this. For now, we'll fail the test if it was inserted.
452
+ if (dep) {
453
+ throw new Error('Self-dependency should not be allowed');
454
+ }
455
+ }
456
+ catch (error) {
457
+ // Expected: trigger or constraint prevents self-dependency
458
+ if (!error.message.includes('should not be allowed')) {
459
+ // This is expected database error
460
+ return;
461
+ }
462
+ throw error;
463
+ }
464
+ };
465
+ // For databases without trigger, this test will pass
466
+ // For databases with trigger, this will throw expected error
467
+ try {
468
+ await shouldReject();
469
+ }
470
+ catch (error) {
471
+ // Acceptable error messages
472
+ if (error.message.includes('circular') ||
473
+ error.message.includes('self') ||
474
+ error.message.includes('should not be allowed')) {
475
+ // Expected behavior
476
+ return;
477
+ }
478
+ throw error;
479
+ }
480
+ });
481
+ it('should detect transitive circular dependency (A→B→A)', async () => {
482
+ const db = getDb();
483
+ const taskA = await insertTask(db, { title: 'Task A' });
484
+ const taskB = await insertTask(db, { title: 'Task B' });
485
+ // Create A blocks B
486
+ await db('t_task_dependencies').insert({
487
+ blocker_task_id: taskA,
488
+ blocked_task_id: taskB,
489
+ created_ts: Math.floor(Date.now() / 1000),
490
+ });
491
+ // Try to create B blocks A (circular)
492
+ // Note: Detection of transitive circular dependencies requires
493
+ // application-level logic or recursive triggers.
494
+ // The schema may allow this at database level.
495
+ // This test documents expected behavior.
496
+ const circularPromise = db('t_task_dependencies').insert({
497
+ blocker_task_id: taskB,
498
+ blocked_task_id: taskA,
499
+ created_ts: Math.floor(Date.now() / 1000),
500
+ });
501
+ // For now, we expect application-level validation to prevent this
502
+ // If the database allows it, we'll just document it
503
+ try {
504
+ await circularPromise;
505
+ // If it succeeds, verify both dependencies exist
506
+ const deps = await db('t_task_dependencies')
507
+ .whereIn('blocker_task_id', [taskA, taskB])
508
+ .whereIn('blocked_task_id', [taskA, taskB]);
509
+ // Note: Schema allows this, but application should prevent it
510
+ // This documents the current behavior
511
+ if (deps.length === 2) {
512
+ console.log(` ⚠️ [${dbType}] Database allows circular dependencies A→B→A (application must validate)`);
513
+ }
514
+ }
515
+ catch (error) {
516
+ // If database prevents it, that's good
517
+ if (error.message.includes('circular') || error.message.includes('cycle')) {
518
+ console.log(` ✅ [${dbType}] Database prevents circular dependencies at schema level`);
519
+ }
520
+ else {
521
+ throw error;
522
+ }
523
+ }
524
+ });
525
+ it('should remove dependency', async () => {
526
+ const db = getDb();
527
+ const blockerTaskId = await insertTask(db, { title: 'Blocker for removal' });
528
+ const blockedTaskId = await insertTask(db, { title: 'Blocked for removal' });
529
+ await db('t_task_dependencies').insert({
530
+ blocker_task_id: blockerTaskId,
531
+ blocked_task_id: blockedTaskId,
532
+ created_ts: Math.floor(Date.now() / 1000),
533
+ });
534
+ // Remove dependency
535
+ await db('t_task_dependencies')
536
+ .where({ blocker_task_id: blockerTaskId, blocked_task_id: blockedTaskId })
537
+ .delete();
538
+ // Verify removal
539
+ const dependency = await db('t_task_dependencies')
540
+ .where({ blocker_task_id: blockerTaskId, blocked_task_id: blockedTaskId })
541
+ .first();
542
+ assert.strictEqual(dependency, undefined, 'Dependency should be removed');
543
+ });
544
+ it('should cascade delete dependencies when task deleted', async () => {
545
+ const db = getDb();
546
+ const blockerTaskId = await insertTask(db, { title: 'Blocker for cascade' });
547
+ const blockedTaskId = await insertTask(db, { title: 'Blocked for cascade' });
548
+ await db('t_task_dependencies').insert({
549
+ blocker_task_id: blockerTaskId,
550
+ blocked_task_id: blockedTaskId,
551
+ created_ts: Math.floor(Date.now() / 1000),
552
+ });
553
+ // Delete blocker task
554
+ await db('t_tasks').where({ id: blockerTaskId }).delete();
555
+ // Verify dependencies were cascade deleted
556
+ const dependencies = await db('t_task_dependencies')
557
+ .where({ blocker_task_id: blockerTaskId })
558
+ .orWhere({ blocked_task_id: blockerTaskId });
559
+ assert.strictEqual(dependencies.length, 0, 'Dependencies should be cascade deleted');
560
+ });
561
+ it('should get task blocking relationships', async () => {
562
+ const db = getDb();
563
+ const blockerTaskId = await insertTask(db, { title: 'Blocker' });
564
+ const blocked1Id = await insertTask(db, { title: 'Blocked 1' });
565
+ const blocked2Id = await insertTask(db, { title: 'Blocked 2' });
566
+ // Blocker blocks both blocked tasks
567
+ await db('t_task_dependencies').insert([
568
+ {
569
+ blocker_task_id: blockerTaskId,
570
+ blocked_task_id: blocked1Id,
571
+ created_ts: Math.floor(Date.now() / 1000),
572
+ },
573
+ {
574
+ blocker_task_id: blockerTaskId,
575
+ blocked_task_id: blocked2Id,
576
+ created_ts: Math.floor(Date.now() / 1000),
577
+ },
578
+ ]);
579
+ // Query what blocker is blocking
580
+ const blocking = await db('t_task_dependencies')
581
+ .where({ blocker_task_id: blockerTaskId })
582
+ .select('blocked_task_id');
583
+ assert.strictEqual(blocking.length, 2);
584
+ const blockedIds = blocking.map(b => b.blocked_task_id);
585
+ assert.ok(blockedIds.includes(blocked1Id));
586
+ assert.ok(blockedIds.includes(blocked2Id));
587
+ });
588
+ it('should get task blocker relationships', async () => {
589
+ const db = getDb();
590
+ const blockedTaskId = await insertTask(db, { title: 'Blocked' });
591
+ const blocker1Id = await insertTask(db, { title: 'Blocker 1' });
592
+ const blocker2Id = await insertTask(db, { title: 'Blocker 2' });
593
+ // Blocked is blocked by both blockers
594
+ await db('t_task_dependencies').insert([
595
+ {
596
+ blocker_task_id: blocker1Id,
597
+ blocked_task_id: blockedTaskId,
598
+ created_ts: Math.floor(Date.now() / 1000),
599
+ },
600
+ {
601
+ blocker_task_id: blocker2Id,
602
+ blocked_task_id: blockedTaskId,
603
+ created_ts: Math.floor(Date.now() / 1000),
604
+ },
605
+ ]);
606
+ // Query what is blocking this task
607
+ const blockers = await db('t_task_dependencies')
608
+ .where({ blocked_task_id: blockedTaskId })
609
+ .select('blocker_task_id');
610
+ assert.strictEqual(blockers.length, 2);
611
+ const blockerIds = blockers.map(b => b.blocker_task_id);
612
+ assert.ok(blockerIds.includes(blocker1Id));
613
+ assert.ok(blockerIds.includes(blocker2Id));
614
+ });
615
+ });
616
+ // ============================================================================
617
+ // Task-Decision Links
618
+ // ============================================================================
619
+ describe('Task-Decision Links', () => {
620
+ it('should link task to decision', async () => {
621
+ const db = getDb();
622
+ const taskId = await insertTask(db, { title: 'Task implementing decision' });
623
+ const timestamp = Math.floor(Date.now() / 1000);
624
+ // Create a decision
625
+ const agentId = await getAgentId(db);
626
+ const layerId = await getLayerId(db, 'business');
627
+ // m_context_keys has no project_id column
628
+ await db('m_context_keys').insert({
629
+ key: 'test/link-decision',
630
+ });
631
+ const contextKey = await db('m_context_keys')
632
+ .where({ key: 'test/link-decision' })
633
+ .first();
634
+ await db('t_decisions').insert({
635
+ key_id: contextKey.id,
636
+ project_id: 1,
637
+ value: 'test value',
638
+ version: '1.0.0',
639
+ ts: timestamp,
640
+ agent_id: agentId,
641
+ layer_id: layerId,
642
+ status: 1, // 1=active (integer enum, not string)
643
+ });
644
+ // Link task to decision (using decision_key_id, not decision_id)
645
+ await db('t_task_decision_links').insert({
646
+ task_id: taskId,
647
+ decision_key_id: contextKey.id,
648
+ project_id: 1,
649
+ link_type: 'implements',
650
+ linked_ts: timestamp,
651
+ });
652
+ // Verify link
653
+ const link = await db('t_task_decision_links')
654
+ .where({ task_id: taskId, decision_key_id: contextKey.id })
655
+ .first();
656
+ assert.ok(link, 'Link should exist');
657
+ assert.strictEqual(link.link_type, 'implements');
658
+ });
659
+ it('should cascade delete task-decision links when task deleted', async () => {
660
+ const db = getDb();
661
+ const taskId = await insertTask(db, { title: 'Task for cascade link delete' });
662
+ const timestamp = Math.floor(Date.now() / 1000);
663
+ // Create decision and link (simplified)
664
+ const agentId = await getAgentId(db);
665
+ const layerId = await getLayerId(db, 'business');
666
+ // m_context_keys has no project_id column
667
+ await db('m_context_keys').insert({ key: 'test/cascade-link' });
668
+ const contextKey = await db('m_context_keys')
669
+ .where({ key: 'test/cascade-link' })
670
+ .first();
671
+ await db('t_decisions').insert({
672
+ key_id: contextKey.id,
673
+ project_id: 1,
674
+ value: 'test',
675
+ version: '1.0.0',
676
+ ts: timestamp,
677
+ agent_id: agentId,
678
+ layer_id: layerId,
679
+ status: 1, // 1=active (integer enum)
680
+ });
681
+ await db('t_task_decision_links').insert({
682
+ task_id: taskId,
683
+ decision_key_id: contextKey.id,
684
+ project_id: 1,
685
+ link_type: 'implements',
686
+ linked_ts: timestamp,
687
+ });
688
+ // Delete task
689
+ await db('t_tasks').where({ id: taskId }).delete();
690
+ // Verify links were cascade deleted
691
+ const links = await db('t_task_decision_links').where({ task_id: taskId });
692
+ assert.strictEqual(links.length, 0, 'Task-decision links should be cascade deleted');
693
+ });
694
+ });
695
+ // ============================================================================
696
+ // Task-Constraint Links
697
+ // ============================================================================
698
+ describe('Task-Constraint Links', () => {
699
+ it('should link task to constraint', async () => {
700
+ const db = getDb();
701
+ const taskId = await insertTask(db, { title: 'Task with constraint' });
702
+ // Create a constraint
703
+ const agentId = await getAgentId(db);
704
+ const layerId = await getLayerId(db, 'business');
705
+ // Get constraint category
706
+ const category = await db('m_constraint_categories')
707
+ .where({ name: 'architecture' })
708
+ .first();
709
+ const constraintText = 'Test constraint for linking';
710
+ await db('t_constraints').insert({
711
+ constraint_text: constraintText,
712
+ constraint_text_hash: hashConstraintText(constraintText),
713
+ category_id: category.id,
714
+ priority: 2,
715
+ project_id: 1,
716
+ layer_id: layerId,
717
+ agent_id: agentId,
718
+ ts: Math.floor(Date.now() / 1000),
719
+ active: 1,
720
+ });
721
+ const constraint = await db('t_constraints')
722
+ .where({ constraint_text: constraintText, project_id: 1 })
723
+ .first();
724
+ // Link task to constraint
725
+ await db('t_task_constraint_links').insert({
726
+ task_id: taskId,
727
+ constraint_id: constraint.id,
728
+ });
729
+ // Verify link
730
+ const link = await db('t_task_constraint_links')
731
+ .where({ task_id: taskId, constraint_id: constraint.id })
732
+ .first();
733
+ assert.ok(link, 'Constraint link should exist');
734
+ });
735
+ it('should cascade delete task-constraint links when task deleted', async () => {
736
+ const db = getDb();
737
+ const taskId = await insertTask(db, { title: 'Task for constraint cascade' });
738
+ // Create constraint and link (simplified)
739
+ const agentId = await getAgentId(db);
740
+ const layerId = await getLayerId(db, 'business');
741
+ const category = await db('m_constraint_categories')
742
+ .where({ name: 'architecture' })
743
+ .first();
744
+ const constraintText = 'Cascade test constraint';
745
+ await db('t_constraints').insert({
746
+ constraint_text: constraintText,
747
+ constraint_text_hash: hashConstraintText(constraintText),
748
+ category_id: category.id,
749
+ priority: 2,
750
+ project_id: 1,
751
+ layer_id: layerId,
752
+ agent_id: agentId,
753
+ ts: Math.floor(Date.now() / 1000),
754
+ active: 1,
755
+ });
756
+ const constraint = await db('t_constraints')
757
+ .where({ constraint_text: constraintText, project_id: 1 })
758
+ .first();
759
+ await db('t_task_constraint_links').insert({
760
+ task_id: taskId,
761
+ constraint_id: constraint.id,
762
+ });
763
+ // Delete task
764
+ await db('t_tasks').where({ id: taskId }).delete();
765
+ // Verify links were cascade deleted
766
+ const links = await db('t_task_constraint_links').where({ task_id: taskId });
767
+ assert.strictEqual(links.length, 0, 'Task-constraint links should be cascade deleted');
768
+ });
769
+ });
770
+ // ============================================================================
771
+ // Cross-Database Compatibility Tests
772
+ // ============================================================================
773
+ describe(`Cross-database compatibility - ${dbType}`, () => {
774
+ it('should handle long task titles', async () => {
775
+ const db = getDb();
776
+ const longTitle = 'A'.repeat(200);
777
+ const taskId = await insertTask(db, {
778
+ title: longTitle,
779
+ priority: 2,
780
+ });
781
+ const task = await db('t_tasks').where({ id: taskId, project_id: 1 }).first();
782
+ assert.strictEqual(task.title, longTitle);
783
+ });
784
+ it('should handle special characters in descriptions', async () => {
785
+ const db = getDb();
786
+ const specialDesc = "Description with 'quotes', \"double quotes\", and \\backslashes";
787
+ const taskId = await insertTask(db, {
788
+ title: 'Special chars test',
789
+ description: specialDesc,
790
+ });
791
+ const details = await db('t_task_details').where({ task_id: taskId }).first();
792
+ assert.strictEqual(details.description, specialDesc);
793
+ });
794
+ it('should handle unicode in task fields', async () => {
795
+ const db = getDb();
796
+ const unicodeTitle = 'タスク 任务 작업 🚀';
797
+ const taskId = await insertTask(db, {
798
+ title: unicodeTitle,
799
+ });
800
+ const task = await db('t_tasks').where({ id: taskId, project_id: 1 }).first();
801
+ assert.strictEqual(task.title, unicodeTitle);
802
+ });
803
+ it('should handle NULL optional fields', async () => {
804
+ const db = getDb();
805
+ const statusId = await getStatusId(db, 'todo');
806
+ const layerId = await getLayerId(db, 'business');
807
+ const agentId = await getAgentId(db);
808
+ // Insert with NULL assigned_agent_id
809
+ const timestamp = Math.floor(Date.now() / 1000);
810
+ const result = await db('t_tasks').insert({
811
+ title: 'Task with NULL agent',
812
+ status_id: statusId,
813
+ priority: 2,
814
+ project_id: 1,
815
+ layer_id: layerId,
816
+ assigned_agent_id: null, // NULL is allowed
817
+ created_by_agent_id: agentId,
818
+ created_ts: timestamp,
819
+ updated_ts: timestamp,
820
+ });
821
+ let taskId;
822
+ if (Array.isArray(result) && result.length > 0) {
823
+ taskId = result[0];
824
+ }
825
+ else {
826
+ const task = await db('t_tasks')
827
+ .where({ title: 'Task with NULL agent', project_id: 1 })
828
+ .first();
829
+ taskId = task.id;
830
+ }
831
+ const task = await db('t_tasks').where({ id: taskId, project_id: 1 }).first();
832
+ assert.strictEqual(task.assigned_agent_id, null);
833
+ });
834
+ });
835
+ });
836
+ //# sourceMappingURL=task-operations.test.js.map