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.
- package/CHANGELOG.md +318 -0
- package/README.md +54 -39
- package/assets/config.example.toml +93 -0
- package/assets/kanban-visualizer.png +0 -0
- package/assets/sample-agents/sqlew-architect.md +32 -13
- package/assets/sample-agents/sqlew-researcher.md +70 -17
- package/assets/sample-agents/sqlew-scrum-master.md +60 -25
- package/assets/schema.sql +2 -2
- package/dist/adapters/auth/auth-factory.d.ts +86 -0
- package/dist/adapters/auth/auth-factory.d.ts.map +1 -0
- package/dist/adapters/auth/auth-factory.js +103 -0
- package/dist/adapters/auth/auth-factory.js.map +1 -0
- package/dist/adapters/auth/auth-types.d.ts +30 -0
- package/dist/adapters/auth/auth-types.d.ts.map +1 -0
- package/dist/adapters/auth/auth-types.js +30 -0
- package/dist/adapters/auth/auth-types.js.map +1 -0
- package/dist/adapters/auth/base-auth-provider.d.ts +327 -0
- package/dist/adapters/auth/base-auth-provider.d.ts.map +1 -0
- package/dist/adapters/auth/base-auth-provider.js +111 -0
- package/dist/adapters/auth/base-auth-provider.js.map +1 -0
- package/dist/adapters/auth/direct-auth-provider.d.ts +356 -0
- package/dist/adapters/auth/direct-auth-provider.d.ts.map +1 -0
- package/dist/adapters/auth/direct-auth-provider.js +406 -0
- package/dist/adapters/auth/direct-auth-provider.js.map +1 -0
- package/dist/adapters/base-adapter.d.ts +638 -0
- package/dist/adapters/base-adapter.d.ts.map +1 -0
- package/dist/adapters/base-adapter.js +557 -0
- package/dist/adapters/base-adapter.js.map +1 -0
- package/dist/adapters/index.d.ts +13 -2
- package/dist/adapters/index.d.ts.map +1 -1
- package/dist/adapters/index.js +27 -5
- package/dist/adapters/index.js.map +1 -1
- package/dist/adapters/mysql-adapter.d.ts +547 -6
- package/dist/adapters/mysql-adapter.d.ts.map +1 -1
- package/dist/adapters/mysql-adapter.js +651 -32
- package/dist/adapters/mysql-adapter.js.map +1 -1
- package/dist/adapters/postgresql-adapter.d.ts +15 -4
- package/dist/adapters/postgresql-adapter.d.ts.map +1 -1
- package/dist/adapters/postgresql-adapter.js +19 -2
- package/dist/adapters/postgresql-adapter.js.map +1 -1
- package/dist/adapters/sqlite-adapter.d.ts +35 -5
- package/dist/adapters/sqlite-adapter.d.ts.map +1 -1
- package/dist/adapters/sqlite-adapter.js +57 -18
- package/dist/adapters/sqlite-adapter.js.map +1 -1
- package/dist/cli/db-dump.d.ts +32 -0
- package/dist/cli/db-dump.d.ts.map +1 -0
- package/dist/cli/db-dump.js +409 -0
- package/dist/cli/db-dump.js.map +1 -0
- package/dist/cli.js +24 -14
- package/dist/cli.js.map +1 -1
- package/dist/config/knex/bootstrap/20251025020452_create_master_tables.d.ts.map +1 -0
- package/dist/{migrations → config}/knex/bootstrap/20251025020452_create_master_tables.js +7 -2
- package/dist/config/knex/bootstrap/20251025020452_create_master_tables.js.map +1 -0
- package/dist/config/knex/bootstrap/20251025021152_create_transaction_tables.d.ts.map +1 -0
- package/dist/{migrations → config}/knex/bootstrap/20251025021152_create_transaction_tables.js +49 -50
- package/dist/config/knex/bootstrap/20251025021152_create_transaction_tables.js.map +1 -0
- package/dist/config/knex/bootstrap/20251025021351_create_indexes.d.ts.map +1 -0
- package/dist/config/knex/bootstrap/20251025021351_create_indexes.js.map +1 -0
- package/dist/config/knex/bootstrap/20251025021416_seed_master_data.d.ts.map +1 -0
- package/dist/{migrations → config}/knex/bootstrap/20251025021416_seed_master_data.js +11 -6
- package/dist/config/knex/bootstrap/20251025021416_seed_master_data.js.map +1 -0
- package/dist/config/knex/bootstrap/20251025070349_create_views.d.ts.map +1 -0
- package/dist/{migrations → config}/knex/bootstrap/20251025070349_create_views.js +66 -14
- package/dist/config/knex/bootstrap/20251025070349_create_views.js.map +1 -0
- package/dist/config/knex/enhancements/20251025081221_add_link_type_to_task_decision_links.d.ts.map +1 -0
- package/dist/config/knex/enhancements/20251025081221_add_link_type_to_task_decision_links.js +22 -0
- package/dist/config/knex/enhancements/20251025081221_add_link_type_to_task_decision_links.js.map +1 -0
- package/dist/config/knex/enhancements/20251025082220_fix_task_dependencies_columns.d.ts.map +1 -0
- package/dist/config/knex/enhancements/20251025082220_fix_task_dependencies_columns.js.map +1 -0
- package/dist/config/knex/enhancements/20251025090000_create_help_system_tables.d.ts.map +1 -0
- package/dist/{migrations → config}/knex/enhancements/20251025090000_create_help_system_tables.js +6 -0
- package/dist/config/knex/enhancements/20251025090000_create_help_system_tables.js.map +1 -0
- package/dist/config/knex/enhancements/20251025090100_seed_help_categories_and_use_cases.d.ts.map +1 -0
- package/dist/{migrations → config}/knex/enhancements/20251025090100_seed_help_categories_and_use_cases.js +6 -0
- package/dist/config/knex/enhancements/20251025090100_seed_help_categories_and_use_cases.js.map +1 -0
- package/dist/config/knex/enhancements/20251025100000_seed_help_metadata.d.ts.map +1 -0
- package/dist/{migrations → config}/knex/enhancements/20251025100000_seed_help_metadata.js +6 -0
- package/dist/config/knex/enhancements/20251025100000_seed_help_metadata.js.map +1 -0
- package/dist/config/knex/enhancements/20251025100100_seed_remaining_use_cases.d.ts.map +1 -0
- package/dist/config/knex/enhancements/20251025100100_seed_remaining_use_cases.js.map +1 -0
- package/dist/config/knex/enhancements/20251025120000_add_cascade_to_task_dependencies.d.ts.map +1 -0
- package/dist/{migrations → config}/knex/enhancements/20251025120000_add_cascade_to_task_dependencies.js +7 -0
- package/dist/config/knex/enhancements/20251025120000_add_cascade_to_task_dependencies.js.map +1 -0
- package/dist/config/knex/enhancements/20251027000000_add_agent_reuse_system.d.ts.map +1 -0
- package/dist/config/knex/enhancements/20251027000000_add_agent_reuse_system.js +62 -0
- package/dist/config/knex/enhancements/20251027000000_add_agent_reuse_system.js.map +1 -0
- package/dist/config/knex/enhancements/20251027010000_add_task_constraint_to_decision_context.d.ts.map +1 -0
- package/dist/config/knex/enhancements/20251027010000_add_task_constraint_to_decision_context.js.map +1 -0
- package/dist/config/knex/enhancements/20251027020000_update_agent_reusability.d.ts.map +1 -0
- package/dist/{migrations → config}/knex/enhancements/20251027020000_update_agent_reusability.js +6 -0
- package/dist/config/knex/enhancements/20251027020000_update_agent_reusability.js.map +1 -0
- package/dist/config/knex/enhancements/20251028000000_simplify_agent_system.d.ts.map +1 -0
- package/dist/{migrations → config}/knex/enhancements/20251028000000_simplify_agent_system.js +6 -0
- package/dist/config/knex/enhancements/20251028000000_simplify_agent_system.js.map +1 -0
- package/dist/config/knex/enhancements/20251031000000_drop_orphaned_message_view.d.ts +13 -0
- package/dist/config/knex/enhancements/20251031000000_drop_orphaned_message_view.d.ts.map +1 -0
- package/dist/config/knex/enhancements/20251031000000_drop_orphaned_message_view.js +48 -0
- package/dist/config/knex/enhancements/20251031000000_drop_orphaned_message_view.js.map +1 -0
- package/dist/config/knex/enhancements/20251104000003_rename_constraints_created_by_to_agent_id.d.ts +24 -0
- package/dist/config/knex/enhancements/20251104000003_rename_constraints_created_by_to_agent_id.d.ts.map +1 -0
- package/dist/config/knex/enhancements/20251104000003_rename_constraints_created_by_to_agent_id.js +189 -0
- package/dist/config/knex/enhancements/20251104000003_rename_constraints_created_by_to_agent_id.js.map +1 -0
- package/dist/config/knex/enhancements/20251105000000_add_token_usage_table.d.ts +16 -0
- package/dist/config/knex/enhancements/20251105000000_add_token_usage_table.d.ts.map +1 -0
- package/dist/config/knex/enhancements/20251105000000_add_token_usage_table.js +65 -0
- package/dist/config/knex/enhancements/20251105000000_add_token_usage_table.js.map +1 -0
- package/dist/config/knex/enhancements/20251105000001_rename_decision_context_decided_by_to_agent_id.d.ts +23 -0
- package/dist/config/knex/enhancements/20251105000001_rename_decision_context_decided_by_to_agent_id.d.ts.map +1 -0
- package/dist/config/knex/enhancements/20251105000001_rename_decision_context_decided_by_to_agent_id.js +118 -0
- package/dist/config/knex/enhancements/20251105000001_rename_decision_context_decided_by_to_agent_id.js.map +1 -0
- package/dist/config/knex/upgrades/20251024010000_upgrade_v1_0_to_v1_1.d.ts.map +1 -0
- package/dist/config/knex/upgrades/20251024010000_upgrade_v1_0_to_v1_1.js.map +1 -0
- package/dist/config/knex/upgrades/20251024020000_upgrade_v2_0_to_v2_1.d.ts.map +1 -0
- package/dist/config/knex/upgrades/20251024020000_upgrade_v2_0_to_v2_1.js.map +1 -0
- package/dist/config/knex/upgrades/20251024030000_upgrade_v2_1_to_v3_0.d.ts.map +1 -0
- package/dist/config/knex/upgrades/20251024030000_upgrade_v2_1_to_v3_0.js.map +1 -0
- package/dist/config/knex/upgrades/20251024040000_upgrade_v3_0_to_v3_2.d.ts.map +1 -0
- package/dist/config/knex/upgrades/20251024040000_upgrade_v3_0_to_v3_2.js.map +1 -0
- package/dist/config/knex/upgrades/20251024050000_upgrade_v3_2_0_to_v3_2_2.d.ts.map +1 -0
- package/dist/config/knex/upgrades/20251024050000_upgrade_v3_2_0_to_v3_2_2.js.map +1 -0
- package/dist/config/knex/upgrades/20251024060000_upgrade_v3_4_to_v3_5.d.ts.map +1 -0
- package/dist/config/knex/upgrades/20251024060000_upgrade_v3_4_to_v3_5.js.map +1 -0
- package/dist/config/knex/upgrades/20251024070000_upgrade_v3_5_to_v3_6.d.ts.map +1 -0
- package/dist/config/knex/upgrades/20251024070000_upgrade_v3_5_to_v3_6.js.map +1 -0
- package/dist/config/knex/upgrades/20251104000000_add_multi_project_v3_7_0.d.ts +49 -0
- package/dist/config/knex/upgrades/20251104000000_add_multi_project_v3_7_0.d.ts.map +1 -0
- package/dist/config/knex/upgrades/20251104000000_add_multi_project_v3_7_0.js +864 -0
- package/dist/config/knex/upgrades/20251104000000_add_multi_project_v3_7_0.js.map +1 -0
- package/dist/config/loader.d.ts +19 -1
- package/dist/config/loader.d.ts.map +1 -1
- package/dist/config/loader.js +149 -4
- package/dist/config/loader.js.map +1 -1
- package/dist/config/types.d.ts +261 -2
- package/dist/config/types.d.ts.map +1 -1
- package/dist/config/types.js.map +1 -1
- package/dist/config/writer.d.ts +65 -0
- package/dist/config/writer.d.ts.map +1 -0
- package/dist/config/writer.js +139 -0
- package/dist/config/writer.js.map +1 -0
- package/dist/database.d.ts +11 -2
- package/dist/database.d.ts.map +1 -1
- package/dist/database.js +62 -6
- package/dist/database.js.map +1 -1
- package/dist/index.js +165 -35
- package/dist/index.js.map +1 -1
- package/dist/knexfile.d.ts.map +1 -1
- package/dist/knexfile.js +88 -12
- package/dist/knexfile.js.map +1 -1
- package/dist/tests/all-features.test.js +15 -3
- package/dist/tests/all-features.test.js.map +1 -1
- package/dist/tests/config-loader.test.d.ts +6 -0
- package/dist/tests/config-loader.test.d.ts.map +1 -0
- package/dist/tests/config-loader.test.js +201 -0
- package/dist/tests/config-loader.test.js.map +1 -0
- package/dist/tests/connection-manager-integration.test.d.ts +2 -0
- package/dist/tests/connection-manager-integration.test.d.ts.map +1 -0
- package/dist/tests/connection-manager-integration.test.js +431 -0
- package/dist/tests/connection-manager-integration.test.js.map +1 -0
- package/dist/tests/connection-manager.test.d.ts +2 -0
- package/dist/tests/connection-manager.test.d.ts.map +1 -0
- package/dist/tests/connection-manager.test.js +361 -0
- package/dist/tests/connection-manager.test.js.map +1 -0
- package/dist/tests/dump-import.test.d.ts +15 -0
- package/dist/tests/dump-import.test.d.ts.map +1 -0
- package/dist/tests/dump-import.test.js +430 -0
- package/dist/tests/dump-import.test.js.map +1 -0
- package/dist/tests/migration-idempotency.test.d.ts +2 -0
- package/dist/tests/migration-idempotency.test.d.ts.map +1 -0
- package/dist/tests/migration-idempotency.test.js +330 -0
- package/dist/tests/migration-idempotency.test.js.map +1 -0
- package/dist/tests/migration-upgrade-paths.test.d.ts +2 -0
- package/dist/tests/migration-upgrade-paths.test.d.ts.map +1 -0
- package/dist/tests/migration-upgrade-paths.test.js +248 -0
- package/dist/tests/migration-upgrade-paths.test.js.map +1 -0
- package/dist/tests/multi-project-migration.test.d.ts +17 -0
- package/dist/tests/multi-project-migration.test.d.ts.map +1 -0
- package/dist/tests/multi-project-migration.test.js +399 -0
- package/dist/tests/multi-project-migration.test.js.map +1 -0
- package/dist/tests/multi-project.test.d.ts +5 -0
- package/dist/tests/multi-project.test.d.ts.map +1 -0
- package/dist/tests/multi-project.test.js +238 -0
- package/dist/tests/multi-project.test.js.map +1 -0
- package/dist/tests/schema-migration.test.d.ts +8 -0
- package/dist/tests/schema-migration.test.d.ts.map +1 -0
- package/dist/tests/schema-migration.test.js +108 -0
- package/dist/tests/schema-migration.test.js.map +1 -0
- package/dist/tests/sql-dump-converters.test.d.ts +7 -0
- package/dist/tests/sql-dump-converters.test.d.ts.map +1 -0
- package/dist/tests/sql-dump-converters.test.js +314 -0
- package/dist/tests/sql-dump-converters.test.js.map +1 -0
- package/dist/tests/sql-dump-cross-database.test.d.ts +21 -0
- package/dist/tests/sql-dump-cross-database.test.d.ts.map +1 -0
- package/dist/tests/sql-dump-cross-database.test.js +314 -0
- package/dist/tests/sql-dump-cross-database.test.js.map +1 -0
- package/dist/tests/sql-dump-default-conversions.test.d.ts +8 -0
- package/dist/tests/sql-dump-default-conversions.test.d.ts.map +1 -0
- package/dist/tests/sql-dump-default-conversions.test.js +141 -0
- package/dist/tests/sql-dump-default-conversions.test.js.map +1 -0
- package/dist/tests/sql-dump-fk-constraints.test.d.ts +13 -0
- package/dist/tests/sql-dump-fk-constraints.test.d.ts.map +1 -0
- package/dist/tests/sql-dump-fk-constraints.test.js +381 -0
- package/dist/tests/sql-dump-fk-constraints.test.js.map +1 -0
- package/dist/tests/sql-dump-indexes.test.d.ts +12 -0
- package/dist/tests/sql-dump-indexes.test.d.ts.map +1 -0
- package/dist/tests/sql-dump-indexes.test.js +269 -0
- package/dist/tests/sql-dump-indexes.test.js.map +1 -0
- package/dist/tests/sql-dump-integration.test.d.ts +16 -0
- package/dist/tests/sql-dump-integration.test.d.ts.map +1 -0
- package/dist/tests/sql-dump-integration.test.js +342 -0
- package/dist/tests/sql-dump-integration.test.js.map +1 -0
- package/dist/tests/sql-dump-table-ordering.test.d.ts +8 -0
- package/dist/tests/sql-dump-table-ordering.test.d.ts.map +1 -0
- package/dist/tests/sql-dump-table-ordering.test.js +253 -0
- package/dist/tests/sql-dump-table-ordering.test.js.map +1 -0
- package/dist/tests/tasks.link-file-backward-compat.test.js +11 -1
- package/dist/tests/tasks.link-file-backward-compat.test.js.map +1 -1
- package/dist/tests/tasks.watch-files-action.test.js +11 -1
- package/dist/tests/tasks.watch-files-action.test.js.map +1 -1
- package/dist/tests/type-conversion.test.d.ts +8 -0
- package/dist/tests/type-conversion.test.d.ts.map +1 -0
- package/dist/tests/type-conversion.test.js +312 -0
- package/dist/tests/type-conversion.test.js.map +1 -0
- package/dist/tests/utils/test-helpers.d.ts +93 -0
- package/dist/tests/utils/test-helpers.d.ts.map +1 -0
- package/dist/tests/utils/test-helpers.js +407 -0
- package/dist/tests/utils/test-helpers.js.map +1 -0
- package/dist/tools/config.d.ts +58 -0
- package/dist/tools/config.d.ts.map +1 -0
- package/dist/tools/config.js +281 -0
- package/dist/tools/config.js.map +1 -0
- package/dist/tools/constraints.d.ts.map +1 -1
- package/dist/tools/constraints.js +138 -122
- package/dist/tools/constraints.js.map +1 -1
- package/dist/tools/context.d.ts.map +1 -1
- package/dist/tools/context.js +216 -109
- package/dist/tools/context.js.map +1 -1
- package/dist/tools/files.d.ts.map +1 -1
- package/dist/tools/files.js +123 -102
- package/dist/tools/files.js.map +1 -1
- package/dist/tools/tasks.d.ts.map +1 -1
- package/dist/tools/tasks.js +581 -518
- package/dist/tools/tasks.js.map +1 -1
- package/dist/tools/utils.d.ts +5 -0
- package/dist/tools/utils.d.ts.map +1 -1
- package/dist/tools/utils.js +176 -122
- package/dist/tools/utils.js.map +1 -1
- package/dist/types.d.ts +9 -26
- package/dist/types.d.ts.map +1 -1
- package/dist/utils/cleanup.d.ts +3 -0
- package/dist/utils/cleanup.d.ts.map +1 -1
- package/dist/utils/cleanup.js +14 -2
- package/dist/utils/cleanup.js.map +1 -1
- package/dist/utils/connection-manager.d.ts +59 -0
- package/dist/utils/connection-manager.d.ts.map +1 -0
- package/dist/utils/connection-manager.js +178 -0
- package/dist/utils/connection-manager.js.map +1 -0
- package/dist/utils/debug-logger.d.ts +8 -4
- package/dist/utils/debug-logger.d.ts.map +1 -1
- package/dist/utils/debug-logger.js +27 -7
- package/dist/utils/debug-logger.js.map +1 -1
- package/dist/utils/error-handler.d.ts +2 -2
- package/dist/utils/error-handler.d.ts.map +1 -1
- package/dist/utils/error-handler.js +10 -7
- package/dist/utils/error-handler.js.map +1 -1
- package/dist/utils/parameter-validator.d.ts.map +1 -1
- package/dist/utils/parameter-validator.js +36 -15
- package/dist/utils/parameter-validator.js.map +1 -1
- package/dist/utils/project-context.d.ts +111 -0
- package/dist/utils/project-context.d.ts.map +1 -0
- package/dist/utils/project-context.js +187 -0
- package/dist/utils/project-context.js.map +1 -0
- package/dist/utils/sql-dump-converters.d.ts +188 -0
- package/dist/utils/sql-dump-converters.d.ts.map +1 -0
- package/dist/utils/sql-dump-converters.js +311 -0
- package/dist/utils/sql-dump-converters.js.map +1 -0
- package/dist/utils/sql-dump.d.ts +102 -0
- package/dist/utils/sql-dump.d.ts.map +1 -0
- package/dist/utils/sql-dump.js +1550 -0
- package/dist/utils/sql-dump.js.map +1 -0
- package/dist/utils/vcs-adapter.d.ts +42 -0
- package/dist/utils/vcs-adapter.d.ts.map +1 -1
- package/dist/utils/vcs-adapter.js +154 -0
- package/dist/utils/vcs-adapter.js.map +1 -1
- package/docs/BASEADAPTER_IMPLEMENTATION.md +399 -0
- package/docs/DATABASE_AUTH.md +445 -0
- package/docs/DATABASE_MIGRATION.md +247 -0
- package/docs/MULTI_PROJECT_ARCHITECTURE.md +497 -0
- package/package.json +12 -4
- package/dist/migrations/knex/bootstrap/20251025020452_create_master_tables.d.ts.map +0 -1
- package/dist/migrations/knex/bootstrap/20251025020452_create_master_tables.js.map +0 -1
- package/dist/migrations/knex/bootstrap/20251025021152_create_transaction_tables.d.ts.map +0 -1
- package/dist/migrations/knex/bootstrap/20251025021152_create_transaction_tables.js.map +0 -1
- package/dist/migrations/knex/bootstrap/20251025021351_create_indexes.d.ts.map +0 -1
- package/dist/migrations/knex/bootstrap/20251025021351_create_indexes.js.map +0 -1
- package/dist/migrations/knex/bootstrap/20251025021416_seed_master_data.d.ts.map +0 -1
- package/dist/migrations/knex/bootstrap/20251025021416_seed_master_data.js.map +0 -1
- package/dist/migrations/knex/bootstrap/20251025070349_create_views.d.ts.map +0 -1
- package/dist/migrations/knex/bootstrap/20251025070349_create_views.js.map +0 -1
- package/dist/migrations/knex/enhancements/20251025081221_add_link_type_to_task_decision_links.d.ts.map +0 -1
- package/dist/migrations/knex/enhancements/20251025081221_add_link_type_to_task_decision_links.js +0 -15
- package/dist/migrations/knex/enhancements/20251025081221_add_link_type_to_task_decision_links.js.map +0 -1
- package/dist/migrations/knex/enhancements/20251025082220_fix_task_dependencies_columns.d.ts.map +0 -1
- package/dist/migrations/knex/enhancements/20251025082220_fix_task_dependencies_columns.js.map +0 -1
- package/dist/migrations/knex/enhancements/20251025090000_create_help_system_tables.d.ts.map +0 -1
- package/dist/migrations/knex/enhancements/20251025090000_create_help_system_tables.js.map +0 -1
- package/dist/migrations/knex/enhancements/20251025090100_seed_help_categories_and_use_cases.d.ts.map +0 -1
- package/dist/migrations/knex/enhancements/20251025090100_seed_help_categories_and_use_cases.js.map +0 -1
- package/dist/migrations/knex/enhancements/20251025100000_seed_help_metadata.d.ts.map +0 -1
- package/dist/migrations/knex/enhancements/20251025100000_seed_help_metadata.js.map +0 -1
- package/dist/migrations/knex/enhancements/20251025100100_seed_remaining_use_cases.d.ts.map +0 -1
- package/dist/migrations/knex/enhancements/20251025100100_seed_remaining_use_cases.js.map +0 -1
- package/dist/migrations/knex/enhancements/20251025120000_add_cascade_to_task_dependencies.d.ts.map +0 -1
- package/dist/migrations/knex/enhancements/20251025120000_add_cascade_to_task_dependencies.js.map +0 -1
- package/dist/migrations/knex/enhancements/20251027000000_add_agent_reuse_system.d.ts.map +0 -1
- package/dist/migrations/knex/enhancements/20251027000000_add_agent_reuse_system.js +0 -34
- package/dist/migrations/knex/enhancements/20251027000000_add_agent_reuse_system.js.map +0 -1
- package/dist/migrations/knex/enhancements/20251027010000_add_task_constraint_to_decision_context.d.ts.map +0 -1
- package/dist/migrations/knex/enhancements/20251027010000_add_task_constraint_to_decision_context.js.map +0 -1
- package/dist/migrations/knex/enhancements/20251027020000_update_agent_reusability.d.ts.map +0 -1
- package/dist/migrations/knex/enhancements/20251027020000_update_agent_reusability.js.map +0 -1
- package/dist/migrations/knex/enhancements/20251028000000_simplify_agent_system.d.ts.map +0 -1
- package/dist/migrations/knex/enhancements/20251028000000_simplify_agent_system.js.map +0 -1
- package/dist/migrations/knex/upgrades/20251024010000_upgrade_v1_0_to_v1_1.d.ts.map +0 -1
- package/dist/migrations/knex/upgrades/20251024010000_upgrade_v1_0_to_v1_1.js.map +0 -1
- package/dist/migrations/knex/upgrades/20251024020000_upgrade_v2_0_to_v2_1.d.ts.map +0 -1
- package/dist/migrations/knex/upgrades/20251024020000_upgrade_v2_0_to_v2_1.js.map +0 -1
- package/dist/migrations/knex/upgrades/20251024030000_upgrade_v2_1_to_v3_0.d.ts.map +0 -1
- package/dist/migrations/knex/upgrades/20251024030000_upgrade_v2_1_to_v3_0.js.map +0 -1
- package/dist/migrations/knex/upgrades/20251024040000_upgrade_v3_0_to_v3_2.d.ts.map +0 -1
- package/dist/migrations/knex/upgrades/20251024040000_upgrade_v3_0_to_v3_2.js.map +0 -1
- package/dist/migrations/knex/upgrades/20251024050000_upgrade_v3_2_0_to_v3_2_2.d.ts.map +0 -1
- package/dist/migrations/knex/upgrades/20251024050000_upgrade_v3_2_0_to_v3_2_2.js.map +0 -1
- package/dist/migrations/knex/upgrades/20251024060000_upgrade_v3_4_to_v3_5.d.ts.map +0 -1
- package/dist/migrations/knex/upgrades/20251024060000_upgrade_v3_4_to_v3_5.js.map +0 -1
- package/dist/migrations/knex/upgrades/20251024070000_upgrade_v3_5_to_v3_6.d.ts.map +0 -1
- package/dist/migrations/knex/upgrades/20251024070000_upgrade_v3_5_to_v3_6.js.map +0 -1
- /package/dist/{migrations → config}/knex/bootstrap/20251025020452_create_master_tables.d.ts +0 -0
- /package/dist/{migrations → config}/knex/bootstrap/20251025021152_create_transaction_tables.d.ts +0 -0
- /package/dist/{migrations → config}/knex/bootstrap/20251025021351_create_indexes.d.ts +0 -0
- /package/dist/{migrations → config}/knex/bootstrap/20251025021351_create_indexes.js +0 -0
- /package/dist/{migrations → config}/knex/bootstrap/20251025021416_seed_master_data.d.ts +0 -0
- /package/dist/{migrations → config}/knex/bootstrap/20251025070349_create_views.d.ts +0 -0
- /package/dist/{migrations → config}/knex/enhancements/20251025081221_add_link_type_to_task_decision_links.d.ts +0 -0
- /package/dist/{migrations → config}/knex/enhancements/20251025082220_fix_task_dependencies_columns.d.ts +0 -0
- /package/dist/{migrations → config}/knex/enhancements/20251025082220_fix_task_dependencies_columns.js +0 -0
- /package/dist/{migrations → config}/knex/enhancements/20251025090000_create_help_system_tables.d.ts +0 -0
- /package/dist/{migrations → config}/knex/enhancements/20251025090100_seed_help_categories_and_use_cases.d.ts +0 -0
- /package/dist/{migrations → config}/knex/enhancements/20251025100000_seed_help_metadata.d.ts +0 -0
- /package/dist/{migrations → config}/knex/enhancements/20251025100100_seed_remaining_use_cases.d.ts +0 -0
- /package/dist/{migrations → config}/knex/enhancements/20251025100100_seed_remaining_use_cases.js +0 -0
- /package/dist/{migrations → config}/knex/enhancements/20251025120000_add_cascade_to_task_dependencies.d.ts +0 -0
- /package/dist/{migrations → config}/knex/enhancements/20251027000000_add_agent_reuse_system.d.ts +0 -0
- /package/dist/{migrations → config}/knex/enhancements/20251027010000_add_task_constraint_to_decision_context.d.ts +0 -0
- /package/dist/{migrations → config}/knex/enhancements/20251027010000_add_task_constraint_to_decision_context.js +0 -0
- /package/dist/{migrations → config}/knex/enhancements/20251027020000_update_agent_reusability.d.ts +0 -0
- /package/dist/{migrations → config}/knex/enhancements/20251028000000_simplify_agent_system.d.ts +0 -0
- /package/dist/{migrations → config}/knex/upgrades/20251024010000_upgrade_v1_0_to_v1_1.d.ts +0 -0
- /package/dist/{migrations → config}/knex/upgrades/20251024010000_upgrade_v1_0_to_v1_1.js +0 -0
- /package/dist/{migrations → config}/knex/upgrades/20251024020000_upgrade_v2_0_to_v2_1.d.ts +0 -0
- /package/dist/{migrations → config}/knex/upgrades/20251024020000_upgrade_v2_0_to_v2_1.js +0 -0
- /package/dist/{migrations → config}/knex/upgrades/20251024030000_upgrade_v2_1_to_v3_0.d.ts +0 -0
- /package/dist/{migrations → config}/knex/upgrades/20251024030000_upgrade_v2_1_to_v3_0.js +0 -0
- /package/dist/{migrations → config}/knex/upgrades/20251024040000_upgrade_v3_0_to_v3_2.d.ts +0 -0
- /package/dist/{migrations → config}/knex/upgrades/20251024040000_upgrade_v3_0_to_v3_2.js +0 -0
- /package/dist/{migrations → config}/knex/upgrades/20251024050000_upgrade_v3_2_0_to_v3_2_2.d.ts +0 -0
- /package/dist/{migrations → config}/knex/upgrades/20251024050000_upgrade_v3_2_0_to_v3_2_2.js +0 -0
- /package/dist/{migrations → config}/knex/upgrades/20251024060000_upgrade_v3_4_to_v3_5.d.ts +0 -0
- /package/dist/{migrations → config}/knex/upgrades/20251024060000_upgrade_v3_4_to_v3_5.js +0 -0
- /package/dist/{migrations → config}/knex/upgrades/20251024070000_upgrade_v3_5_to_v3_6.d.ts +0 -0
- /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 @@
|
|
|
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 @@
|
|
|
1
|
+
{"version":3,"file":"sql-dump-converters.test.d.ts","sourceRoot":"","sources":["../../src/tests/sql-dump-converters.test.ts"],"names":[],"mappings":"AAAA;;;;GAIG"}
|