diff options
| author | Paul Buetow <paul@buetow.org> | 2026-04-14 10:40:44 +0300 |
|---|---|---|
| committer | Paul Buetow <paul@buetow.org> | 2026-04-14 10:40:44 +0300 |
| commit | d49376f71dd8defebf80f901ecb60ab99f0f4906 (patch) | |
| tree | 749322d2bf5c33d28ff95b77ebc674d69435c31c /internal/storage/db_test.go | |
| parent | ff749457e392288e29dbf553bf8e0e64cc8b6401 (diff) | |
n3: validate SQLite with PingContext after Open
Call db.PingContext in storage.Open and authkeys.OpenStore; close DB and
return wrapped errors on failure. Add tests for canceled context and
invalid directory path.
Made-with: Cursor
Diffstat (limited to 'internal/storage/db_test.go')
| -rw-r--r-- | internal/storage/db_test.go | 34 |
1 files changed, 34 insertions, 0 deletions
diff --git a/internal/storage/db_test.go b/internal/storage/db_test.go new file mode 100644 index 0000000..5415235 --- /dev/null +++ b/internal/storage/db_test.go @@ -0,0 +1,34 @@ +package storage + +import ( + "context" + "errors" + "os" + "path/filepath" + "testing" +) + +func TestOpen_ContextCanceled(t *testing.T) { + ctx, cancel := context.WithCancel(context.Background()) + cancel() + path := filepath.Join(t.TempDir(), "records.db") + _, err := Open(ctx, path) + if err == nil { + t.Fatal("expected error") + } + if !errors.Is(err, context.Canceled) { + t.Fatalf("expected context.Canceled, got %v", err) + } +} + +func TestOpen_PingFailsOnDirectoryPath(t *testing.T) { + ctx := context.Background() + dir := filepath.Join(t.TempDir(), "isdir") + if err := os.Mkdir(dir, 0o755); err != nil { + t.Fatal(err) + } + _, err := Open(ctx, dir) + if err == nil { + t.Fatal("expected error opening sqlite at directory path") + } +} |
