refactor: use esm-safe database migrations

Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
This commit is contained in:
MythEclipse
2026-05-14 23:17:57 +07:00
parent 954faf6c5a
commit e5aa398e5c
2 changed files with 45 additions and 10 deletions

View File

@@ -1,28 +1,43 @@
import "dotenv/config"; import "dotenv/config";
import Database from "better-sqlite3"; import Database from "better-sqlite3";
import { drizzle as drizzleSqlite } from "drizzle-orm/better-sqlite3";
import { migrate as migrateSqlite } from "drizzle-orm/better-sqlite3/migrator"; import { migrate as migrateSqlite } from "drizzle-orm/better-sqlite3/migrator";
import { migrate } from "drizzle-orm/node-postgres/migrator"; import { migrate as migratePostgres } from "drizzle-orm/node-postgres/migrator";
import { config } from "../config"; import { config } from "../config";
import { createChildLogger } from "../logger"; import { createChildLogger } from "../logger";
import { initializeDatabase } from "./drizzle"; import { closeDatabase, initializeDatabase } from "./drizzle";
const logger = createChildLogger("migrate"); const logger = createChildLogger("migrate");
export function initializeMigrationSqliteDatabase(path = ".muxer-queue.db") {
const sqlite = new Database(path);
sqlite.pragma("journal_mode = WAL");
return { sqlite, db: drizzleSqlite(sqlite) };
}
export async function runMigrations(): Promise<void> { export async function runMigrations(): Promise<void> {
try { try {
logger.info("Starting database migrations"); logger.info("Starting database migrations");
if (config.DATABASE_TYPE === "postgres") { if (config.DATABASE_TYPE === "postgres") {
logger.info("Running PostgreSQL migrations"); logger.info("Running PostgreSQL migrations");
const db = await initializeDatabase(); const db = (await initializeDatabase()) as Parameters<
await migrate(db as any, { migrationsFolder: "./drizzle/migrations" }); typeof migratePostgres
>[0];
try {
await migratePostgres(db, { migrationsFolder: "./drizzle/migrations" });
} finally {
await closeDatabase();
}
logger.info("PostgreSQL migrations completed successfully"); logger.info("PostgreSQL migrations completed successfully");
} else { } else {
logger.info("Running SQLite migrations"); logger.info("Running SQLite migrations");
const sqlite = new Database(".muxer-queue.db"); const { sqlite, db } = initializeMigrationSqliteDatabase();
sqlite.pragma("journal_mode = WAL"); try {
const db = require("drizzle-orm/better-sqlite3").drizzle(sqlite); migrateSqlite(db, { migrationsFolder: "./drizzle/migrations" });
migrateSqlite(db, { migrationsFolder: "./drizzle/migrations" }); } finally {
sqlite.close();
}
logger.info("SQLite migrations completed successfully"); logger.info("SQLite migrations completed successfully");
} }
} catch (error) { } catch (error) {
@@ -34,8 +49,7 @@ export async function runMigrations(): Promise<void> {
} }
} }
// Run migrations if called directly if (import.meta.url === `file://${process.argv[1]}`) {
if (require.main === module) {
runMigrations() runMigrations()
.then(() => { .then(() => {
logger.info("Migrations completed"); logger.info("Migrations completed");

View File

@@ -0,0 +1,21 @@
import { mkdtempSync, rmSync } from "node:fs";
import { tmpdir } from "node:os";
import { join } from "node:path";
import { describe, expect, it } from "vitest";
import { initializeMigrationSqliteDatabase } from "../../src/database/migrate";
describe("initializeMigrationSqliteDatabase", () => {
it("creates a SQLite DB with WAL journal mode", () => {
const dir = mkdtempSync(join(tmpdir(), "bete-migrate-"));
const dbPath = join(dir, "test.db");
const { sqlite, db } = initializeMigrationSqliteDatabase(dbPath);
try {
expect(db).toBeDefined();
expect(sqlite.pragma("journal_mode", { simple: true })).toBe("wal");
} finally {
sqlite.close();
rmSync(dir, { recursive: true, force: true });
}
});
});