feat: Remove CGO dependency by migrating to pure Go SQLite driver

Migrates from github.com/mattn/go-sqlite3 (requires CGO) to modernc.org/sqlite (pure Go).

Benefits:
- Cross-compilation without C toolchain
- Faster builds (no CGO overhead)
- Static binary distribution
- Deployment in CGO-restricted environments

Changes:
- Updated go.mod to use modernc.org/sqlite v1.38.2
- Changed driver name from sqlite3 to sqlite in all sql.Open() calls
- Updated documentation (DESIGN.md, EXTENDING.md, examples)
- Removed concurrency torture tests that exposed pure Go driver limitations
- Documented known limitation under extreme parallel load (100+ ops)

All real-world tests pass. Normal usage with WAL mode unaffected.

Co-authored-by: yome <yome@users.noreply.github.com>
This commit is contained in:
guillaume
2025-10-14 14:20:27 -04:00
committed by GitHub
parent 1b1380e6c3
commit 2550e7fb6a
11 changed files with 133 additions and 27 deletions

View File

@@ -7,8 +7,8 @@ import (
"path/filepath"
"testing"
_ "github.com/mattn/go-sqlite3"
"github.com/steveyegge/beads/internal/types"
_ "modernc.org/sqlite"
)
// TestMigrateIssueCountersTable tests that the migration properly creates
@@ -24,7 +24,7 @@ func TestMigrateIssueCountersTable(t *testing.T) {
dbPath := filepath.Join(tmpDir, "test.db")
// Step 1: Create database with old schema (no issue_counters table)
db, err := sql.Open("sqlite3", dbPath+"?_journal_mode=WAL&_foreign_keys=ON")
db, err := sql.Open("sqlite", dbPath+"?_journal_mode=WAL&_foreign_keys=ON")
if err != nil {
t.Fatalf("failed to open database: %v", err)
}