sqlew 3.6.10 → 3.7.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 (370) hide show
  1. package/CHANGELOG.md +318 -0
  2. package/README.md +54 -39
  3. package/assets/config.example.toml +93 -0
  4. package/assets/kanban-visualizer.png +0 -0
  5. package/assets/sample-agents/sqlew-architect.md +32 -13
  6. package/assets/sample-agents/sqlew-researcher.md +70 -17
  7. package/assets/sample-agents/sqlew-scrum-master.md +60 -25
  8. package/assets/schema.sql +2 -2
  9. package/dist/adapters/auth/auth-factory.d.ts +86 -0
  10. package/dist/adapters/auth/auth-factory.d.ts.map +1 -0
  11. package/dist/adapters/auth/auth-factory.js +103 -0
  12. package/dist/adapters/auth/auth-factory.js.map +1 -0
  13. package/dist/adapters/auth/auth-types.d.ts +30 -0
  14. package/dist/adapters/auth/auth-types.d.ts.map +1 -0
  15. package/dist/adapters/auth/auth-types.js +30 -0
  16. package/dist/adapters/auth/auth-types.js.map +1 -0
  17. package/dist/adapters/auth/base-auth-provider.d.ts +327 -0
  18. package/dist/adapters/auth/base-auth-provider.d.ts.map +1 -0
  19. package/dist/adapters/auth/base-auth-provider.js +111 -0
  20. package/dist/adapters/auth/base-auth-provider.js.map +1 -0
  21. package/dist/adapters/auth/direct-auth-provider.d.ts +356 -0
  22. package/dist/adapters/auth/direct-auth-provider.d.ts.map +1 -0
  23. package/dist/adapters/auth/direct-auth-provider.js +406 -0
  24. package/dist/adapters/auth/direct-auth-provider.js.map +1 -0
  25. package/dist/adapters/base-adapter.d.ts +638 -0
  26. package/dist/adapters/base-adapter.d.ts.map +1 -0
  27. package/dist/adapters/base-adapter.js +557 -0
  28. package/dist/adapters/base-adapter.js.map +1 -0
  29. package/dist/adapters/index.d.ts +13 -2
  30. package/dist/adapters/index.d.ts.map +1 -1
  31. package/dist/adapters/index.js +27 -5
  32. package/dist/adapters/index.js.map +1 -1
  33. package/dist/adapters/mysql-adapter.d.ts +547 -6
  34. package/dist/adapters/mysql-adapter.d.ts.map +1 -1
  35. package/dist/adapters/mysql-adapter.js +651 -32
  36. package/dist/adapters/mysql-adapter.js.map +1 -1
  37. package/dist/adapters/postgresql-adapter.d.ts +15 -4
  38. package/dist/adapters/postgresql-adapter.d.ts.map +1 -1
  39. package/dist/adapters/postgresql-adapter.js +19 -2
  40. package/dist/adapters/postgresql-adapter.js.map +1 -1
  41. package/dist/adapters/sqlite-adapter.d.ts +35 -5
  42. package/dist/adapters/sqlite-adapter.d.ts.map +1 -1
  43. package/dist/adapters/sqlite-adapter.js +57 -18
  44. package/dist/adapters/sqlite-adapter.js.map +1 -1
  45. package/dist/cli/db-dump.d.ts +32 -0
  46. package/dist/cli/db-dump.d.ts.map +1 -0
  47. package/dist/cli/db-dump.js +409 -0
  48. package/dist/cli/db-dump.js.map +1 -0
  49. package/dist/cli.js +24 -14
  50. package/dist/cli.js.map +1 -1
  51. package/dist/config/knex/bootstrap/20251025020452_create_master_tables.d.ts.map +1 -0
  52. package/dist/{migrations → config}/knex/bootstrap/20251025020452_create_master_tables.js +7 -2
  53. package/dist/config/knex/bootstrap/20251025020452_create_master_tables.js.map +1 -0
  54. package/dist/config/knex/bootstrap/20251025021152_create_transaction_tables.d.ts.map +1 -0
  55. package/dist/{migrations → config}/knex/bootstrap/20251025021152_create_transaction_tables.js +49 -50
  56. package/dist/config/knex/bootstrap/20251025021152_create_transaction_tables.js.map +1 -0
  57. package/dist/config/knex/bootstrap/20251025021351_create_indexes.d.ts.map +1 -0
  58. package/dist/config/knex/bootstrap/20251025021351_create_indexes.js.map +1 -0
  59. package/dist/config/knex/bootstrap/20251025021416_seed_master_data.d.ts.map +1 -0
  60. package/dist/{migrations → config}/knex/bootstrap/20251025021416_seed_master_data.js +11 -6
  61. package/dist/config/knex/bootstrap/20251025021416_seed_master_data.js.map +1 -0
  62. package/dist/config/knex/bootstrap/20251025070349_create_views.d.ts.map +1 -0
  63. package/dist/{migrations → config}/knex/bootstrap/20251025070349_create_views.js +66 -14
  64. package/dist/config/knex/bootstrap/20251025070349_create_views.js.map +1 -0
  65. package/dist/config/knex/enhancements/20251025081221_add_link_type_to_task_decision_links.d.ts.map +1 -0
  66. package/dist/config/knex/enhancements/20251025081221_add_link_type_to_task_decision_links.js +22 -0
  67. package/dist/config/knex/enhancements/20251025081221_add_link_type_to_task_decision_links.js.map +1 -0
  68. package/dist/config/knex/enhancements/20251025082220_fix_task_dependencies_columns.d.ts.map +1 -0
  69. package/dist/config/knex/enhancements/20251025082220_fix_task_dependencies_columns.js.map +1 -0
  70. package/dist/config/knex/enhancements/20251025090000_create_help_system_tables.d.ts.map +1 -0
  71. package/dist/{migrations → config}/knex/enhancements/20251025090000_create_help_system_tables.js +6 -0
  72. package/dist/config/knex/enhancements/20251025090000_create_help_system_tables.js.map +1 -0
  73. package/dist/config/knex/enhancements/20251025090100_seed_help_categories_and_use_cases.d.ts.map +1 -0
  74. package/dist/{migrations → config}/knex/enhancements/20251025090100_seed_help_categories_and_use_cases.js +6 -0
  75. package/dist/config/knex/enhancements/20251025090100_seed_help_categories_and_use_cases.js.map +1 -0
  76. package/dist/config/knex/enhancements/20251025100000_seed_help_metadata.d.ts.map +1 -0
  77. package/dist/{migrations → config}/knex/enhancements/20251025100000_seed_help_metadata.js +6 -0
  78. package/dist/config/knex/enhancements/20251025100000_seed_help_metadata.js.map +1 -0
  79. package/dist/config/knex/enhancements/20251025100100_seed_remaining_use_cases.d.ts.map +1 -0
  80. package/dist/config/knex/enhancements/20251025100100_seed_remaining_use_cases.js.map +1 -0
  81. package/dist/config/knex/enhancements/20251025120000_add_cascade_to_task_dependencies.d.ts.map +1 -0
  82. package/dist/{migrations → config}/knex/enhancements/20251025120000_add_cascade_to_task_dependencies.js +7 -0
  83. package/dist/config/knex/enhancements/20251025120000_add_cascade_to_task_dependencies.js.map +1 -0
  84. package/dist/config/knex/enhancements/20251027000000_add_agent_reuse_system.d.ts.map +1 -0
  85. package/dist/config/knex/enhancements/20251027000000_add_agent_reuse_system.js +62 -0
  86. package/dist/config/knex/enhancements/20251027000000_add_agent_reuse_system.js.map +1 -0
  87. package/dist/config/knex/enhancements/20251027010000_add_task_constraint_to_decision_context.d.ts.map +1 -0
  88. package/dist/config/knex/enhancements/20251027010000_add_task_constraint_to_decision_context.js.map +1 -0
  89. package/dist/config/knex/enhancements/20251027020000_update_agent_reusability.d.ts.map +1 -0
  90. package/dist/{migrations → config}/knex/enhancements/20251027020000_update_agent_reusability.js +6 -0
  91. package/dist/config/knex/enhancements/20251027020000_update_agent_reusability.js.map +1 -0
  92. package/dist/config/knex/enhancements/20251028000000_simplify_agent_system.d.ts.map +1 -0
  93. package/dist/{migrations → config}/knex/enhancements/20251028000000_simplify_agent_system.js +6 -0
  94. package/dist/config/knex/enhancements/20251028000000_simplify_agent_system.js.map +1 -0
  95. package/dist/config/knex/enhancements/20251031000000_drop_orphaned_message_view.d.ts +13 -0
  96. package/dist/config/knex/enhancements/20251031000000_drop_orphaned_message_view.d.ts.map +1 -0
  97. package/dist/config/knex/enhancements/20251031000000_drop_orphaned_message_view.js +48 -0
  98. package/dist/config/knex/enhancements/20251031000000_drop_orphaned_message_view.js.map +1 -0
  99. package/dist/config/knex/enhancements/20251104000003_rename_constraints_created_by_to_agent_id.d.ts +24 -0
  100. package/dist/config/knex/enhancements/20251104000003_rename_constraints_created_by_to_agent_id.d.ts.map +1 -0
  101. package/dist/config/knex/enhancements/20251104000003_rename_constraints_created_by_to_agent_id.js +189 -0
  102. package/dist/config/knex/enhancements/20251104000003_rename_constraints_created_by_to_agent_id.js.map +1 -0
  103. package/dist/config/knex/enhancements/20251105000000_add_token_usage_table.d.ts +16 -0
  104. package/dist/config/knex/enhancements/20251105000000_add_token_usage_table.d.ts.map +1 -0
  105. package/dist/config/knex/enhancements/20251105000000_add_token_usage_table.js +65 -0
  106. package/dist/config/knex/enhancements/20251105000000_add_token_usage_table.js.map +1 -0
  107. package/dist/config/knex/enhancements/20251105000001_rename_decision_context_decided_by_to_agent_id.d.ts +23 -0
  108. package/dist/config/knex/enhancements/20251105000001_rename_decision_context_decided_by_to_agent_id.d.ts.map +1 -0
  109. package/dist/config/knex/enhancements/20251105000001_rename_decision_context_decided_by_to_agent_id.js +118 -0
  110. package/dist/config/knex/enhancements/20251105000001_rename_decision_context_decided_by_to_agent_id.js.map +1 -0
  111. package/dist/config/knex/upgrades/20251024010000_upgrade_v1_0_to_v1_1.d.ts.map +1 -0
  112. package/dist/config/knex/upgrades/20251024010000_upgrade_v1_0_to_v1_1.js.map +1 -0
  113. package/dist/config/knex/upgrades/20251024020000_upgrade_v2_0_to_v2_1.d.ts.map +1 -0
  114. package/dist/config/knex/upgrades/20251024020000_upgrade_v2_0_to_v2_1.js.map +1 -0
  115. package/dist/config/knex/upgrades/20251024030000_upgrade_v2_1_to_v3_0.d.ts.map +1 -0
  116. package/dist/config/knex/upgrades/20251024030000_upgrade_v2_1_to_v3_0.js.map +1 -0
  117. package/dist/config/knex/upgrades/20251024040000_upgrade_v3_0_to_v3_2.d.ts.map +1 -0
  118. package/dist/config/knex/upgrades/20251024040000_upgrade_v3_0_to_v3_2.js.map +1 -0
  119. package/dist/config/knex/upgrades/20251024050000_upgrade_v3_2_0_to_v3_2_2.d.ts.map +1 -0
  120. package/dist/config/knex/upgrades/20251024050000_upgrade_v3_2_0_to_v3_2_2.js.map +1 -0
  121. package/dist/config/knex/upgrades/20251024060000_upgrade_v3_4_to_v3_5.d.ts.map +1 -0
  122. package/dist/config/knex/upgrades/20251024060000_upgrade_v3_4_to_v3_5.js.map +1 -0
  123. package/dist/config/knex/upgrades/20251024070000_upgrade_v3_5_to_v3_6.d.ts.map +1 -0
  124. package/dist/config/knex/upgrades/20251024070000_upgrade_v3_5_to_v3_6.js.map +1 -0
  125. package/dist/config/knex/upgrades/20251104000000_add_multi_project_v3_7_0.d.ts +49 -0
  126. package/dist/config/knex/upgrades/20251104000000_add_multi_project_v3_7_0.d.ts.map +1 -0
  127. package/dist/config/knex/upgrades/20251104000000_add_multi_project_v3_7_0.js +864 -0
  128. package/dist/config/knex/upgrades/20251104000000_add_multi_project_v3_7_0.js.map +1 -0
  129. package/dist/config/loader.d.ts +19 -1
  130. package/dist/config/loader.d.ts.map +1 -1
  131. package/dist/config/loader.js +149 -4
  132. package/dist/config/loader.js.map +1 -1
  133. package/dist/config/types.d.ts +261 -2
  134. package/dist/config/types.d.ts.map +1 -1
  135. package/dist/config/types.js.map +1 -1
  136. package/dist/config/writer.d.ts +65 -0
  137. package/dist/config/writer.d.ts.map +1 -0
  138. package/dist/config/writer.js +139 -0
  139. package/dist/config/writer.js.map +1 -0
  140. package/dist/database.d.ts +11 -2
  141. package/dist/database.d.ts.map +1 -1
  142. package/dist/database.js +62 -6
  143. package/dist/database.js.map +1 -1
  144. package/dist/index.js +165 -35
  145. package/dist/index.js.map +1 -1
  146. package/dist/knexfile.d.ts.map +1 -1
  147. package/dist/knexfile.js +88 -12
  148. package/dist/knexfile.js.map +1 -1
  149. package/dist/tests/all-features.test.js +15 -3
  150. package/dist/tests/all-features.test.js.map +1 -1
  151. package/dist/tests/config-loader.test.d.ts +6 -0
  152. package/dist/tests/config-loader.test.d.ts.map +1 -0
  153. package/dist/tests/config-loader.test.js +201 -0
  154. package/dist/tests/config-loader.test.js.map +1 -0
  155. package/dist/tests/connection-manager-integration.test.d.ts +2 -0
  156. package/dist/tests/connection-manager-integration.test.d.ts.map +1 -0
  157. package/dist/tests/connection-manager-integration.test.js +431 -0
  158. package/dist/tests/connection-manager-integration.test.js.map +1 -0
  159. package/dist/tests/connection-manager.test.d.ts +2 -0
  160. package/dist/tests/connection-manager.test.d.ts.map +1 -0
  161. package/dist/tests/connection-manager.test.js +361 -0
  162. package/dist/tests/connection-manager.test.js.map +1 -0
  163. package/dist/tests/dump-import.test.d.ts +15 -0
  164. package/dist/tests/dump-import.test.d.ts.map +1 -0
  165. package/dist/tests/dump-import.test.js +430 -0
  166. package/dist/tests/dump-import.test.js.map +1 -0
  167. package/dist/tests/migration-idempotency.test.d.ts +2 -0
  168. package/dist/tests/migration-idempotency.test.d.ts.map +1 -0
  169. package/dist/tests/migration-idempotency.test.js +330 -0
  170. package/dist/tests/migration-idempotency.test.js.map +1 -0
  171. package/dist/tests/migration-upgrade-paths.test.d.ts +2 -0
  172. package/dist/tests/migration-upgrade-paths.test.d.ts.map +1 -0
  173. package/dist/tests/migration-upgrade-paths.test.js +248 -0
  174. package/dist/tests/migration-upgrade-paths.test.js.map +1 -0
  175. package/dist/tests/multi-project-migration.test.d.ts +17 -0
  176. package/dist/tests/multi-project-migration.test.d.ts.map +1 -0
  177. package/dist/tests/multi-project-migration.test.js +399 -0
  178. package/dist/tests/multi-project-migration.test.js.map +1 -0
  179. package/dist/tests/multi-project.test.d.ts +5 -0
  180. package/dist/tests/multi-project.test.d.ts.map +1 -0
  181. package/dist/tests/multi-project.test.js +238 -0
  182. package/dist/tests/multi-project.test.js.map +1 -0
  183. package/dist/tests/schema-migration.test.d.ts +8 -0
  184. package/dist/tests/schema-migration.test.d.ts.map +1 -0
  185. package/dist/tests/schema-migration.test.js +108 -0
  186. package/dist/tests/schema-migration.test.js.map +1 -0
  187. package/dist/tests/sql-dump-converters.test.d.ts +7 -0
  188. package/dist/tests/sql-dump-converters.test.d.ts.map +1 -0
  189. package/dist/tests/sql-dump-converters.test.js +314 -0
  190. package/dist/tests/sql-dump-converters.test.js.map +1 -0
  191. package/dist/tests/sql-dump-cross-database.test.d.ts +21 -0
  192. package/dist/tests/sql-dump-cross-database.test.d.ts.map +1 -0
  193. package/dist/tests/sql-dump-cross-database.test.js +314 -0
  194. package/dist/tests/sql-dump-cross-database.test.js.map +1 -0
  195. package/dist/tests/sql-dump-default-conversions.test.d.ts +8 -0
  196. package/dist/tests/sql-dump-default-conversions.test.d.ts.map +1 -0
  197. package/dist/tests/sql-dump-default-conversions.test.js +141 -0
  198. package/dist/tests/sql-dump-default-conversions.test.js.map +1 -0
  199. package/dist/tests/sql-dump-fk-constraints.test.d.ts +13 -0
  200. package/dist/tests/sql-dump-fk-constraints.test.d.ts.map +1 -0
  201. package/dist/tests/sql-dump-fk-constraints.test.js +381 -0
  202. package/dist/tests/sql-dump-fk-constraints.test.js.map +1 -0
  203. package/dist/tests/sql-dump-indexes.test.d.ts +12 -0
  204. package/dist/tests/sql-dump-indexes.test.d.ts.map +1 -0
  205. package/dist/tests/sql-dump-indexes.test.js +269 -0
  206. package/dist/tests/sql-dump-indexes.test.js.map +1 -0
  207. package/dist/tests/sql-dump-integration.test.d.ts +16 -0
  208. package/dist/tests/sql-dump-integration.test.d.ts.map +1 -0
  209. package/dist/tests/sql-dump-integration.test.js +342 -0
  210. package/dist/tests/sql-dump-integration.test.js.map +1 -0
  211. package/dist/tests/sql-dump-table-ordering.test.d.ts +8 -0
  212. package/dist/tests/sql-dump-table-ordering.test.d.ts.map +1 -0
  213. package/dist/tests/sql-dump-table-ordering.test.js +253 -0
  214. package/dist/tests/sql-dump-table-ordering.test.js.map +1 -0
  215. package/dist/tests/tasks.link-file-backward-compat.test.js +11 -1
  216. package/dist/tests/tasks.link-file-backward-compat.test.js.map +1 -1
  217. package/dist/tests/tasks.watch-files-action.test.js +11 -1
  218. package/dist/tests/tasks.watch-files-action.test.js.map +1 -1
  219. package/dist/tests/type-conversion.test.d.ts +8 -0
  220. package/dist/tests/type-conversion.test.d.ts.map +1 -0
  221. package/dist/tests/type-conversion.test.js +312 -0
  222. package/dist/tests/type-conversion.test.js.map +1 -0
  223. package/dist/tests/utils/test-helpers.d.ts +93 -0
  224. package/dist/tests/utils/test-helpers.d.ts.map +1 -0
  225. package/dist/tests/utils/test-helpers.js +407 -0
  226. package/dist/tests/utils/test-helpers.js.map +1 -0
  227. package/dist/tools/config.d.ts +58 -0
  228. package/dist/tools/config.d.ts.map +1 -0
  229. package/dist/tools/config.js +281 -0
  230. package/dist/tools/config.js.map +1 -0
  231. package/dist/tools/constraints.d.ts.map +1 -1
  232. package/dist/tools/constraints.js +138 -122
  233. package/dist/tools/constraints.js.map +1 -1
  234. package/dist/tools/context.d.ts.map +1 -1
  235. package/dist/tools/context.js +216 -109
  236. package/dist/tools/context.js.map +1 -1
  237. package/dist/tools/files.d.ts.map +1 -1
  238. package/dist/tools/files.js +123 -102
  239. package/dist/tools/files.js.map +1 -1
  240. package/dist/tools/tasks.d.ts.map +1 -1
  241. package/dist/tools/tasks.js +581 -518
  242. package/dist/tools/tasks.js.map +1 -1
  243. package/dist/tools/utils.d.ts +5 -0
  244. package/dist/tools/utils.d.ts.map +1 -1
  245. package/dist/tools/utils.js +176 -122
  246. package/dist/tools/utils.js.map +1 -1
  247. package/dist/types.d.ts +9 -26
  248. package/dist/types.d.ts.map +1 -1
  249. package/dist/utils/cleanup.d.ts +3 -0
  250. package/dist/utils/cleanup.d.ts.map +1 -1
  251. package/dist/utils/cleanup.js +14 -2
  252. package/dist/utils/cleanup.js.map +1 -1
  253. package/dist/utils/connection-manager.d.ts +59 -0
  254. package/dist/utils/connection-manager.d.ts.map +1 -0
  255. package/dist/utils/connection-manager.js +178 -0
  256. package/dist/utils/connection-manager.js.map +1 -0
  257. package/dist/utils/debug-logger.d.ts +8 -4
  258. package/dist/utils/debug-logger.d.ts.map +1 -1
  259. package/dist/utils/debug-logger.js +27 -7
  260. package/dist/utils/debug-logger.js.map +1 -1
  261. package/dist/utils/error-handler.d.ts +2 -2
  262. package/dist/utils/error-handler.d.ts.map +1 -1
  263. package/dist/utils/error-handler.js +10 -7
  264. package/dist/utils/error-handler.js.map +1 -1
  265. package/dist/utils/parameter-validator.d.ts.map +1 -1
  266. package/dist/utils/parameter-validator.js +36 -15
  267. package/dist/utils/parameter-validator.js.map +1 -1
  268. package/dist/utils/project-context.d.ts +111 -0
  269. package/dist/utils/project-context.d.ts.map +1 -0
  270. package/dist/utils/project-context.js +187 -0
  271. package/dist/utils/project-context.js.map +1 -0
  272. package/dist/utils/sql-dump-converters.d.ts +188 -0
  273. package/dist/utils/sql-dump-converters.d.ts.map +1 -0
  274. package/dist/utils/sql-dump-converters.js +311 -0
  275. package/dist/utils/sql-dump-converters.js.map +1 -0
  276. package/dist/utils/sql-dump.d.ts +102 -0
  277. package/dist/utils/sql-dump.d.ts.map +1 -0
  278. package/dist/utils/sql-dump.js +1550 -0
  279. package/dist/utils/sql-dump.js.map +1 -0
  280. package/dist/utils/vcs-adapter.d.ts +42 -0
  281. package/dist/utils/vcs-adapter.d.ts.map +1 -1
  282. package/dist/utils/vcs-adapter.js +154 -0
  283. package/dist/utils/vcs-adapter.js.map +1 -1
  284. package/docs/BASEADAPTER_IMPLEMENTATION.md +399 -0
  285. package/docs/DATABASE_AUTH.md +445 -0
  286. package/docs/DATABASE_MIGRATION.md +247 -0
  287. package/docs/MULTI_PROJECT_ARCHITECTURE.md +497 -0
  288. package/package.json +12 -4
  289. package/dist/migrations/knex/bootstrap/20251025020452_create_master_tables.d.ts.map +0 -1
  290. package/dist/migrations/knex/bootstrap/20251025020452_create_master_tables.js.map +0 -1
  291. package/dist/migrations/knex/bootstrap/20251025021152_create_transaction_tables.d.ts.map +0 -1
  292. package/dist/migrations/knex/bootstrap/20251025021152_create_transaction_tables.js.map +0 -1
  293. package/dist/migrations/knex/bootstrap/20251025021351_create_indexes.d.ts.map +0 -1
  294. package/dist/migrations/knex/bootstrap/20251025021351_create_indexes.js.map +0 -1
  295. package/dist/migrations/knex/bootstrap/20251025021416_seed_master_data.d.ts.map +0 -1
  296. package/dist/migrations/knex/bootstrap/20251025021416_seed_master_data.js.map +0 -1
  297. package/dist/migrations/knex/bootstrap/20251025070349_create_views.d.ts.map +0 -1
  298. package/dist/migrations/knex/bootstrap/20251025070349_create_views.js.map +0 -1
  299. package/dist/migrations/knex/enhancements/20251025081221_add_link_type_to_task_decision_links.d.ts.map +0 -1
  300. package/dist/migrations/knex/enhancements/20251025081221_add_link_type_to_task_decision_links.js +0 -15
  301. package/dist/migrations/knex/enhancements/20251025081221_add_link_type_to_task_decision_links.js.map +0 -1
  302. package/dist/migrations/knex/enhancements/20251025082220_fix_task_dependencies_columns.d.ts.map +0 -1
  303. package/dist/migrations/knex/enhancements/20251025082220_fix_task_dependencies_columns.js.map +0 -1
  304. package/dist/migrations/knex/enhancements/20251025090000_create_help_system_tables.d.ts.map +0 -1
  305. package/dist/migrations/knex/enhancements/20251025090000_create_help_system_tables.js.map +0 -1
  306. package/dist/migrations/knex/enhancements/20251025090100_seed_help_categories_and_use_cases.d.ts.map +0 -1
  307. package/dist/migrations/knex/enhancements/20251025090100_seed_help_categories_and_use_cases.js.map +0 -1
  308. package/dist/migrations/knex/enhancements/20251025100000_seed_help_metadata.d.ts.map +0 -1
  309. package/dist/migrations/knex/enhancements/20251025100000_seed_help_metadata.js.map +0 -1
  310. package/dist/migrations/knex/enhancements/20251025100100_seed_remaining_use_cases.d.ts.map +0 -1
  311. package/dist/migrations/knex/enhancements/20251025100100_seed_remaining_use_cases.js.map +0 -1
  312. package/dist/migrations/knex/enhancements/20251025120000_add_cascade_to_task_dependencies.d.ts.map +0 -1
  313. package/dist/migrations/knex/enhancements/20251025120000_add_cascade_to_task_dependencies.js.map +0 -1
  314. package/dist/migrations/knex/enhancements/20251027000000_add_agent_reuse_system.d.ts.map +0 -1
  315. package/dist/migrations/knex/enhancements/20251027000000_add_agent_reuse_system.js +0 -34
  316. package/dist/migrations/knex/enhancements/20251027000000_add_agent_reuse_system.js.map +0 -1
  317. package/dist/migrations/knex/enhancements/20251027010000_add_task_constraint_to_decision_context.d.ts.map +0 -1
  318. package/dist/migrations/knex/enhancements/20251027010000_add_task_constraint_to_decision_context.js.map +0 -1
  319. package/dist/migrations/knex/enhancements/20251027020000_update_agent_reusability.d.ts.map +0 -1
  320. package/dist/migrations/knex/enhancements/20251027020000_update_agent_reusability.js.map +0 -1
  321. package/dist/migrations/knex/enhancements/20251028000000_simplify_agent_system.d.ts.map +0 -1
  322. package/dist/migrations/knex/enhancements/20251028000000_simplify_agent_system.js.map +0 -1
  323. package/dist/migrations/knex/upgrades/20251024010000_upgrade_v1_0_to_v1_1.d.ts.map +0 -1
  324. package/dist/migrations/knex/upgrades/20251024010000_upgrade_v1_0_to_v1_1.js.map +0 -1
  325. package/dist/migrations/knex/upgrades/20251024020000_upgrade_v2_0_to_v2_1.d.ts.map +0 -1
  326. package/dist/migrations/knex/upgrades/20251024020000_upgrade_v2_0_to_v2_1.js.map +0 -1
  327. package/dist/migrations/knex/upgrades/20251024030000_upgrade_v2_1_to_v3_0.d.ts.map +0 -1
  328. package/dist/migrations/knex/upgrades/20251024030000_upgrade_v2_1_to_v3_0.js.map +0 -1
  329. package/dist/migrations/knex/upgrades/20251024040000_upgrade_v3_0_to_v3_2.d.ts.map +0 -1
  330. package/dist/migrations/knex/upgrades/20251024040000_upgrade_v3_0_to_v3_2.js.map +0 -1
  331. package/dist/migrations/knex/upgrades/20251024050000_upgrade_v3_2_0_to_v3_2_2.d.ts.map +0 -1
  332. package/dist/migrations/knex/upgrades/20251024050000_upgrade_v3_2_0_to_v3_2_2.js.map +0 -1
  333. package/dist/migrations/knex/upgrades/20251024060000_upgrade_v3_4_to_v3_5.d.ts.map +0 -1
  334. package/dist/migrations/knex/upgrades/20251024060000_upgrade_v3_4_to_v3_5.js.map +0 -1
  335. package/dist/migrations/knex/upgrades/20251024070000_upgrade_v3_5_to_v3_6.d.ts.map +0 -1
  336. package/dist/migrations/knex/upgrades/20251024070000_upgrade_v3_5_to_v3_6.js.map +0 -1
  337. /package/dist/{migrations → config}/knex/bootstrap/20251025020452_create_master_tables.d.ts +0 -0
  338. /package/dist/{migrations → config}/knex/bootstrap/20251025021152_create_transaction_tables.d.ts +0 -0
  339. /package/dist/{migrations → config}/knex/bootstrap/20251025021351_create_indexes.d.ts +0 -0
  340. /package/dist/{migrations → config}/knex/bootstrap/20251025021351_create_indexes.js +0 -0
  341. /package/dist/{migrations → config}/knex/bootstrap/20251025021416_seed_master_data.d.ts +0 -0
  342. /package/dist/{migrations → config}/knex/bootstrap/20251025070349_create_views.d.ts +0 -0
  343. /package/dist/{migrations → config}/knex/enhancements/20251025081221_add_link_type_to_task_decision_links.d.ts +0 -0
  344. /package/dist/{migrations → config}/knex/enhancements/20251025082220_fix_task_dependencies_columns.d.ts +0 -0
  345. /package/dist/{migrations → config}/knex/enhancements/20251025082220_fix_task_dependencies_columns.js +0 -0
  346. /package/dist/{migrations → config}/knex/enhancements/20251025090000_create_help_system_tables.d.ts +0 -0
  347. /package/dist/{migrations → config}/knex/enhancements/20251025090100_seed_help_categories_and_use_cases.d.ts +0 -0
  348. /package/dist/{migrations → config}/knex/enhancements/20251025100000_seed_help_metadata.d.ts +0 -0
  349. /package/dist/{migrations → config}/knex/enhancements/20251025100100_seed_remaining_use_cases.d.ts +0 -0
  350. /package/dist/{migrations → config}/knex/enhancements/20251025100100_seed_remaining_use_cases.js +0 -0
  351. /package/dist/{migrations → config}/knex/enhancements/20251025120000_add_cascade_to_task_dependencies.d.ts +0 -0
  352. /package/dist/{migrations → config}/knex/enhancements/20251027000000_add_agent_reuse_system.d.ts +0 -0
  353. /package/dist/{migrations → config}/knex/enhancements/20251027010000_add_task_constraint_to_decision_context.d.ts +0 -0
  354. /package/dist/{migrations → config}/knex/enhancements/20251027010000_add_task_constraint_to_decision_context.js +0 -0
  355. /package/dist/{migrations → config}/knex/enhancements/20251027020000_update_agent_reusability.d.ts +0 -0
  356. /package/dist/{migrations → config}/knex/enhancements/20251028000000_simplify_agent_system.d.ts +0 -0
  357. /package/dist/{migrations → config}/knex/upgrades/20251024010000_upgrade_v1_0_to_v1_1.d.ts +0 -0
  358. /package/dist/{migrations → config}/knex/upgrades/20251024010000_upgrade_v1_0_to_v1_1.js +0 -0
  359. /package/dist/{migrations → config}/knex/upgrades/20251024020000_upgrade_v2_0_to_v2_1.d.ts +0 -0
  360. /package/dist/{migrations → config}/knex/upgrades/20251024020000_upgrade_v2_0_to_v2_1.js +0 -0
  361. /package/dist/{migrations → config}/knex/upgrades/20251024030000_upgrade_v2_1_to_v3_0.d.ts +0 -0
  362. /package/dist/{migrations → config}/knex/upgrades/20251024030000_upgrade_v2_1_to_v3_0.js +0 -0
  363. /package/dist/{migrations → config}/knex/upgrades/20251024040000_upgrade_v3_0_to_v3_2.d.ts +0 -0
  364. /package/dist/{migrations → config}/knex/upgrades/20251024040000_upgrade_v3_0_to_v3_2.js +0 -0
  365. /package/dist/{migrations → config}/knex/upgrades/20251024050000_upgrade_v3_2_0_to_v3_2_2.d.ts +0 -0
  366. /package/dist/{migrations → config}/knex/upgrades/20251024050000_upgrade_v3_2_0_to_v3_2_2.js +0 -0
  367. /package/dist/{migrations → config}/knex/upgrades/20251024060000_upgrade_v3_4_to_v3_5.d.ts +0 -0
  368. /package/dist/{migrations → config}/knex/upgrades/20251024060000_upgrade_v3_4_to_v3_5.js +0 -0
  369. /package/dist/{migrations → config}/knex/upgrades/20251024070000_upgrade_v3_5_to_v3_6.d.ts +0 -0
  370. /package/dist/{migrations → config}/knex/upgrades/20251024070000_upgrade_v3_5_to_v3_6.js +0 -0
@@ -0,0 +1,238 @@
1
+ /**
2
+ * Phase 7 Integration Tests - Multi-Project Support v3.7.0
3
+ */
4
+ import { describe, it, beforeEach, afterEach } from 'node:test';
5
+ import assert from 'node:assert/strict';
6
+ import { initializeDatabase, closeDatabase } from '../database.js';
7
+ import { ProjectContext } from '../utils/project-context.js';
8
+ import { setDecision, getContext, searchByLayer } from '../tools/context.js';
9
+ import { createTask, listTasks } from '../tools/tasks.js';
10
+ import { recordFileChange } from '../tools/files.js';
11
+ import fs from 'fs';
12
+ import path from 'path';
13
+ import os from 'os';
14
+ let testDb;
15
+ let tempDir;
16
+ let tempDbPath;
17
+ beforeEach(async () => {
18
+ tempDir = fs.mkdtempSync(path.join(os.tmpdir(), 'sqlew-test-'));
19
+ tempDbPath = path.join(tempDir, 'test.db');
20
+ testDb = await initializeDatabase({ connection: { filename: tempDbPath } });
21
+ });
22
+ afterEach(async () => {
23
+ ProjectContext.reset();
24
+ await closeDatabase();
25
+ if (tempDir && fs.existsSync(tempDir)) {
26
+ fs.rmSync(tempDir, { recursive: true, force: true });
27
+ }
28
+ });
29
+ describe('Multi-Project Data Isolation', () => {
30
+ it('should isolate decisions between projects', async () => {
31
+ const knex = testDb.getKnex();
32
+ // Setup Project A
33
+ const projectContextA = ProjectContext.getInstance();
34
+ await projectContextA.ensureProject(knex, 'project-a', 'config');
35
+ await setDecision({
36
+ key: 'auth-method',
37
+ value: 'OAuth2',
38
+ layer: 'infrastructure',
39
+ status: 'active'
40
+ }, testDb);
41
+ const decisionsA = await getContext({}, testDb);
42
+ assert.strictEqual(decisionsA.decisions.length, 1);
43
+ assert.strictEqual(decisionsA.decisions[0].value, 'OAuth2');
44
+ // Reset and switch to Project B
45
+ ProjectContext.reset();
46
+ const projectContextB = ProjectContext.getInstance();
47
+ await projectContextB.ensureProject(knex, 'project-b', 'config');
48
+ await setDecision({
49
+ key: 'auth-method',
50
+ value: 'JWT',
51
+ layer: 'infrastructure',
52
+ status: 'active'
53
+ }, testDb);
54
+ const decisionsB = await getContext({}, testDb);
55
+ assert.strictEqual(decisionsB.decisions.length, 1);
56
+ assert.strictEqual(decisionsB.decisions[0].value, 'JWT');
57
+ });
58
+ it('should isolate tasks between projects', async () => {
59
+ const knex = testDb.getKnex();
60
+ // Project A
61
+ const projectContextA = ProjectContext.getInstance();
62
+ await projectContextA.ensureProject(knex, 'frontend', 'config');
63
+ await createTask({
64
+ title: 'Build login component',
65
+ status: 'in_progress',
66
+ priority: 3
67
+ }, testDb);
68
+ const tasksA = await listTasks({}, testDb);
69
+ assert.strictEqual(tasksA.tasks.length, 1);
70
+ // Project B
71
+ ProjectContext.reset();
72
+ const projectContextB = ProjectContext.getInstance();
73
+ await projectContextB.ensureProject(knex, 'backend', 'config');
74
+ await createTask({
75
+ title: 'Design API schema',
76
+ status: 'todo',
77
+ priority: 4
78
+ }, testDb);
79
+ const tasksB = await listTasks({}, testDb);
80
+ assert.strictEqual(tasksB.tasks.length, 1);
81
+ assert.strictEqual(tasksB.tasks[0].title, 'Design API schema');
82
+ });
83
+ it('should isolate file changes between projects', async () => {
84
+ const knex = testDb.getKnex();
85
+ // Project A
86
+ const projectContextA = ProjectContext.getInstance();
87
+ await projectContextA.ensureProject(knex, 'web-app', 'config');
88
+ await recordFileChange({
89
+ file_path: 'src/index.ts',
90
+ agent_name: 'developer-1',
91
+ layer: 'infrastructure',
92
+ change_type: 'modified',
93
+ description: 'Updated imports'
94
+ }, testDb);
95
+ const changesA = await knex('t_file_changes')
96
+ .where({ project_id: projectContextA.getProjectId() })
97
+ .select('*');
98
+ assert.strictEqual(changesA.length, 1);
99
+ // Project B
100
+ ProjectContext.reset();
101
+ const projectContextB = ProjectContext.getInstance();
102
+ await projectContextB.ensureProject(knex, 'api-server', 'config');
103
+ await recordFileChange({
104
+ file_path: 'src/index.ts',
105
+ agent_name: 'developer-2',
106
+ layer: 'business',
107
+ change_type: 'created',
108
+ description: 'Added endpoint'
109
+ }, testDb);
110
+ const changesB = await knex('t_file_changes')
111
+ .where({ project_id: projectContextB.getProjectId() })
112
+ .select('*');
113
+ assert.strictEqual(changesB.length, 1);
114
+ });
115
+ });
116
+ describe('Cross-Project Queries', () => {
117
+ it('should query decisions from another project', async () => {
118
+ const knex = testDb.getKnex();
119
+ // Project A
120
+ const projectContextA = ProjectContext.getInstance();
121
+ await projectContextA.ensureProject(knex, 'legacy-app', 'config');
122
+ await setDecision({
123
+ key: 'database',
124
+ value: 'PostgreSQL',
125
+ layer: 'data',
126
+ status: 'active'
127
+ }, testDb);
128
+ // Project B
129
+ ProjectContext.reset();
130
+ const projectContextB = ProjectContext.getInstance();
131
+ await projectContextB.ensureProject(knex, 'new-app', 'config');
132
+ await setDecision({
133
+ key: 'database',
134
+ value: 'MySQL',
135
+ layer: 'data',
136
+ status: 'active'
137
+ }, testDb);
138
+ // Query current project
139
+ const currentDecisions = await getContext({}, testDb);
140
+ assert.strictEqual(currentDecisions.decisions[0].value, 'MySQL');
141
+ // Cross-project query
142
+ const crossProjectDecisions = await getContext({
143
+ _reference_project: 'legacy-app'
144
+ }, testDb);
145
+ assert.strictEqual(crossProjectDecisions.decisions.length, 1);
146
+ assert.strictEqual(crossProjectDecisions.decisions[0].value, 'PostgreSQL');
147
+ });
148
+ it('should query by layer from another project', async () => {
149
+ const knex = testDb.getKnex();
150
+ // Project A
151
+ const projectContextA = ProjectContext.getInstance();
152
+ await projectContextA.ensureProject(knex, 'backend-v1', 'config');
153
+ await setDecision({
154
+ key: 'rest-framework',
155
+ value: 'Express',
156
+ layer: 'business',
157
+ status: 'active'
158
+ }, testDb);
159
+ // Project B
160
+ ProjectContext.reset();
161
+ const projectContextB = ProjectContext.getInstance();
162
+ await projectContextB.ensureProject(knex, 'backend-v2', 'config');
163
+ await setDecision({
164
+ key: 'rest-framework',
165
+ value: 'Fastify',
166
+ layer: 'business',
167
+ status: 'active'
168
+ }, testDb);
169
+ // Current project query
170
+ const currentBiz = await searchByLayer({ layer: 'business' }, testDb);
171
+ assert.strictEqual(currentBiz.decisions[0].value, 'Fastify');
172
+ // Cross-project query
173
+ const crossBiz = await searchByLayer({
174
+ layer: 'business',
175
+ _reference_project: 'backend-v1'
176
+ }, testDb);
177
+ assert.strictEqual(crossBiz.decisions[0].value, 'Express');
178
+ });
179
+ it('should throw error for non-existent project', async () => {
180
+ const knex = testDb.getKnex();
181
+ const projectContext = ProjectContext.getInstance();
182
+ await projectContext.ensureProject(knex, 'my-app', 'config');
183
+ await assert.rejects(getContext({ _reference_project: 'non-existent' }, testDb), /Referenced project "non-existent" not found/);
184
+ });
185
+ });
186
+ describe('Project Detection', () => {
187
+ it('should create project with correct detection source', async () => {
188
+ const knex = testDb.getKnex();
189
+ const projectContext = ProjectContext.getInstance();
190
+ await projectContext.ensureProject(knex, 'test-project', 'cli');
191
+ const dbProject = await knex('m_projects')
192
+ .where({ name: 'test-project' })
193
+ .first();
194
+ assert.ok(dbProject);
195
+ assert.strictEqual(dbProject.detection_source, 'cli');
196
+ });
197
+ it('should reuse existing project', async () => {
198
+ const knex = testDb.getKnex();
199
+ const projectContext = ProjectContext.getInstance();
200
+ await projectContext.ensureProject(knex, 'reusable', 'config');
201
+ const id1 = projectContext.getProjectId();
202
+ // Second call should return same ID
203
+ const id2 = projectContext.getProjectId();
204
+ assert.strictEqual(id1, id2);
205
+ // Verify only one project in database
206
+ const projects = await knex('m_projects')
207
+ .where({ name: 'reusable' })
208
+ .select('*');
209
+ assert.strictEqual(projects.length, 1);
210
+ });
211
+ });
212
+ describe('Migration Verification', () => {
213
+ it('should have m_projects table with correct schema', async () => {
214
+ const knex = testDb.getKnex();
215
+ const hasTable = await knex.schema.hasTable('m_projects');
216
+ assert.ok(hasTable);
217
+ const hasId = await knex.schema.hasColumn('m_projects', 'id');
218
+ const hasName = await knex.schema.hasColumn('m_projects', 'name');
219
+ const hasDetectionSource = await knex.schema.hasColumn('m_projects', 'detection_source');
220
+ assert.ok(hasId);
221
+ assert.ok(hasName);
222
+ assert.ok(hasDetectionSource);
223
+ });
224
+ it('should have project_id in transaction tables', async () => {
225
+ const knex = testDb.getKnex();
226
+ const tables = [
227
+ 't_decisions',
228
+ 't_file_changes',
229
+ 't_constraints',
230
+ 't_tasks'
231
+ ];
232
+ for (const table of tables) {
233
+ const hasColumn = await knex.schema.hasColumn(table, 'project_id');
234
+ assert.ok(hasColumn, `${table} should have project_id column`);
235
+ }
236
+ });
237
+ });
238
+ //# sourceMappingURL=multi-project.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"multi-project.test.js","sourceRoot":"","sources":["../../src/tests/multi-project.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,8 @@
1
+ /**
2
+ * Schema-only migration tests (CREATE TABLE + CREATE VIEW)
3
+ *
4
+ * Tests that schema structures can be migrated across databases
5
+ * without data type conversion issues.
6
+ */
7
+ export {};
8
+ //# sourceMappingURL=schema-migration.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"schema-migration.test.d.ts","sourceRoot":"","sources":["../../src/tests/schema-migration.test.ts"],"names":[],"mappings":"AAAA;;;;;GAKG"}
@@ -0,0 +1,108 @@
1
+ /**
2
+ * Schema-only migration tests (CREATE TABLE + CREATE VIEW)
3
+ *
4
+ * Tests that schema structures can be migrated across databases
5
+ * without data type conversion issues.
6
+ */
7
+ import knex from 'knex';
8
+ import { generateSqlDump } from '../utils/sql-dump.js';
9
+ import { describe, it, before, after } from 'node:test';
10
+ import assert from 'node:assert';
11
+ import { writeFileSync, unlinkSync } from 'node:fs';
12
+ import { exec } from 'node:child_process';
13
+ import { promisify } from 'node:util';
14
+ const execAsync = promisify(exec);
15
+ // Test database configurations
16
+ const configs = {
17
+ sqlite: {
18
+ client: 'better-sqlite3',
19
+ connection: { filename: '.sqlew/sqlew.db' },
20
+ useNullAsDefault: true,
21
+ },
22
+ postgresql: {
23
+ client: 'pg',
24
+ connection: {
25
+ host: 'localhost',
26
+ port: 5433,
27
+ user: 'testuser',
28
+ password: 'testpass',
29
+ database: 'sqlew_test',
30
+ },
31
+ },
32
+ };
33
+ describe('Schema Migration Tests (No Data)', () => {
34
+ let sqliteDb;
35
+ let postgresDb;
36
+ before(async () => {
37
+ sqliteDb = knex(configs.sqlite);
38
+ postgresDb = knex(configs.postgresql);
39
+ console.log(' Verifying database connections...');
40
+ await postgresDb.raw('SELECT 1');
41
+ console.log(' ✅ Databases connected');
42
+ });
43
+ after(async () => {
44
+ await sqliteDb.destroy();
45
+ await postgresDb.destroy();
46
+ });
47
+ it('should generate schema-only dump (CREATE TABLE + CREATE VIEW)', async () => {
48
+ console.log(' Generating schema-only dump...');
49
+ const dump = await generateSqlDump(sqliteDb, 'postgresql', {
50
+ includeHeader: true,
51
+ includeSchema: true,
52
+ chunkSize: 0, // No data, schema only
53
+ });
54
+ // Verify schema elements present
55
+ assert.ok(dump.includes('CREATE TABLE'), 'Should contain CREATE TABLE statements');
56
+ assert.ok(dump.includes('CREATE VIEW'), 'Should contain CREATE VIEW statements');
57
+ assert.ok(!dump.includes('insert into'), 'Should NOT contain INSERT statements');
58
+ console.log(` ✅ Schema dump generated (${dump.length} chars)`);
59
+ });
60
+ it('should migrate schema to PostgreSQL successfully', async () => {
61
+ console.log(' Migrating schema to PostgreSQL...');
62
+ // Generate schema-only dump
63
+ const dump = await generateSqlDump(sqliteDb, 'postgresql', {
64
+ includeSchema: true,
65
+ chunkSize: 0, // Schema only, no data
66
+ });
67
+ // Drop and recreate schema
68
+ await postgresDb.raw('DROP SCHEMA public CASCADE');
69
+ await postgresDb.raw('CREATE SCHEMA public');
70
+ // Import via psql
71
+ const tempFile = '/tmp/sqlew-schema-test.sql';
72
+ writeFileSync(tempFile, dump);
73
+ try {
74
+ await execAsync(`docker cp ${tempFile} mcp-sqlew_postgres_1:/tmp/schema.sql`);
75
+ await execAsync(`docker exec mcp-sqlew_postgres_1 psql -U testuser -d sqlew_test -f /tmp/schema.sql -v ON_ERROR_STOP=1 -q`);
76
+ }
77
+ finally {
78
+ unlinkSync(tempFile);
79
+ }
80
+ // Verify tables created
81
+ const tables = await postgresDb.raw(`
82
+ SELECT tablename FROM pg_tables WHERE schemaname = 'public' AND tablename LIKE 'm_%' OR tablename LIKE 't_%'
83
+ `);
84
+ assert.ok(tables.rows.length > 10, 'Should create multiple tables');
85
+ console.log(` ✅ Schema migrated: ${tables.rows.length} tables created`);
86
+ // Verify views created
87
+ const views = await postgresDb.raw(`
88
+ SELECT viewname FROM pg_views WHERE schemaname = 'public'
89
+ `);
90
+ assert.ok(views.rows.length > 0, 'Should create views');
91
+ console.log(` ✅ Views created: ${views.rows.length} views`);
92
+ });
93
+ it('should verify view definitions are valid', async () => {
94
+ console.log(' Verifying view definitions...');
95
+ // Query each view to ensure it's valid SQL
96
+ const views = await postgresDb.raw(`
97
+ SELECT viewname FROM pg_views WHERE schemaname = 'public'
98
+ `);
99
+ for (const row of views.rows) {
100
+ const viewName = row.viewname;
101
+ // Query the view (should not throw)
102
+ await postgresDb.raw(`SELECT * FROM "${viewName}" LIMIT 0`);
103
+ console.log(` ✅ View "${viewName}" is valid`);
104
+ }
105
+ console.log(` ✅ All ${views.rows.length} views are valid`);
106
+ });
107
+ });
108
+ //# sourceMappingURL=schema-migration.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"schema-migration.test.js","sourceRoot":"","sources":["../../src/tests/schema-migration.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,7 @@
1
+ /**
2
+ * Unit tests for SQL dump converter functions
3
+ *
4
+ * Tests regex pattern conversions for cross-database SQL migration
5
+ */
6
+ export {};
7
+ //# sourceMappingURL=sql-dump-converters.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sql-dump-converters.test.d.ts","sourceRoot":"","sources":["../../src/tests/sql-dump-converters.test.ts"],"names":[],"mappings":"AAAA;;;;GAIG"}