()
| 293 | }; |
| 294 | |
| 295 | const migrate = async () => { |
| 296 | const client = await pool.connect(); |
| 297 | |
| 298 | try { |
| 299 | logger.info('🚀 Starting database migration...'); |
| 300 | |
| 301 | await createTables(client); |
| 302 | await createIndexes(client); |
| 303 | await createTriggers(client); |
| 304 | await recordSchemaVersion(client); |
| 305 | |
| 306 | logger.info('✨ Migration completed successfully!'); |
| 307 | logger.info(`📌 Schema version recorded: v${EXPECTED_SCHEMA_VERSION} (${EXPECTED_SCHEMA_LABEL})`); |
| 308 | logger.info('📚 Your database is now ready for TitanBot.'); |
| 309 | } catch (error) { |
| 310 | logger.error('❌ Migration failed:', error); |
| 311 | process.exit(1); |
| 312 | } finally { |
| 313 | client.release(); |
| 314 | await pool.end(); |
| 315 | } |
| 316 | }; |
| 317 | |
| 318 | const checkMigrationVersion = async () => { |
| 319 | const client = await pool.connect(); |
no test coverage detected