refactor: use esm-safe database migrations
Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
This commit is contained in:
@@ -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");
|
||||||
|
|||||||
21
tests/database/migrate.test.ts
Normal file
21
tests/database/migrate.test.ts
Normal 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 });
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});
|
||||||
Reference in New Issue
Block a user