fix: use bun:sqlite in production, better-sqlite3 as test-only devDep

Production (Docker): src/lib/db.ts now uses bun:sqlite + drizzle-orm/bun-sqlite.
No native addon compilation needed — bun:sqlite is a Bun built-in. The Dockerfile
drops all native build tools (python3, make, g++) and uses --ignore-scripts.

Tests (Vitest/Node.js): bun:sqlite is unavailable under Node.js, so:
- tests/helpers/db.ts keeps better-sqlite3 + drizzle-orm/better-sqlite3 for
  integration tests that need a real in-memory SQLite
- vitest.config.ts aliases bun:sqlite → a thin better-sqlite3 shim and
  drizzle-orm/bun-sqlite → drizzle-orm/better-sqlite3 for unit tests that
  transitively import src/lib/db.ts without executing any queries
- better-sqlite3 stays as a devDependency (test-only, not built in Docker)

Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
This commit is contained in:
fuomag9
2026-03-21 11:53:33 +01:00
parent b5625e5a96
commit fc680d4171
8 changed files with 30 additions and 26 deletions

View File

@@ -25,10 +25,8 @@
"@mui/icons-material": "^7.3.9",
"@mui/material": "^7.3.9",
"@mui/x-date-pickers": "^8.27.2",
"@types/better-sqlite3": "^7.6.13",
"apexcharts": "^5.10.4",
"bcryptjs": "^3.0.3",
"better-sqlite3": "^12.8.0",
"d3-geo": "^3.1.1",
"dayjs": "^1.11.20",
"drizzle-orm": "^0.45.1",
@@ -44,8 +42,10 @@
"topojson-client": "^3.1.0"
},
"devDependencies": {
"@types/better-sqlite3": "^7.6.13",
"@types/bun": "latest",
"@eslint/js": "^10.0.1",
"better-sqlite3": "^12.8.0",
"@next/eslint-plugin-next": "^16.1.7",
"@playwright/test": "^1.58.2",
"@types/d3-geo": "^3.1.0",