58 lines
1.6 KiB
Go
58 lines
1.6 KiB
Go
|
|
package db_test
|
||
|
|
|
||
|
|
import (
|
||
|
|
"testing"
|
||
|
|
"apigo.cc/go/db"
|
||
|
|
_ "modernc.org/sqlite"
|
||
|
|
)
|
||
|
|
|
||
|
|
func TestVersionControl(t *testing.T) {
|
||
|
|
dbInst := db.GetDB("sqlite://:memory:", nil)
|
||
|
|
|
||
|
|
// Create table with autoVersion
|
||
|
|
dbInst.Exec("CREATE TABLE users (id INTEGER PRIMARY KEY, name TEXT, autoVersion BIGINT UNSIGNED)")
|
||
|
|
|
||
|
|
t.Run("InsertAutoVersion", func(t *testing.T) {
|
||
|
|
data := map[string]any{"id": 1, "name": "Alice"}
|
||
|
|
res := dbInst.Insert("users", data)
|
||
|
|
if res.Error != nil {
|
||
|
|
t.Fatalf("Insert failed: %v", res.Error)
|
||
|
|
}
|
||
|
|
|
||
|
|
// Verify version was injected
|
||
|
|
var ver int64
|
||
|
|
qr := dbInst.Query("SELECT autoVersion FROM users WHERE id = 1")
|
||
|
|
ver, _ = db.ToValue[int64](qr)
|
||
|
|
if ver != 1 {
|
||
|
|
t.Errorf("Expected version 1, got %d", ver)
|
||
|
|
}
|
||
|
|
})
|
||
|
|
|
||
|
|
t.Run("UpdateOptimisticLock", func(t *testing.T) {
|
||
|
|
// First update
|
||
|
|
data := map[string]any{"name": "Alice Updated", "autoVersion": int64(1)}
|
||
|
|
res := dbInst.Update("users", data, "id = 1")
|
||
|
|
if res.Error != nil {
|
||
|
|
t.Fatalf("Update failed: %v", res.Error)
|
||
|
|
}
|
||
|
|
if res.Changes() != 1 {
|
||
|
|
t.Errorf("Expected 1 change, got %d", res.Changes())
|
||
|
|
}
|
||
|
|
|
||
|
|
// Verify version incremented
|
||
|
|
var ver int64
|
||
|
|
qr := dbInst.Query("SELECT autoVersion FROM users WHERE id = 1")
|
||
|
|
ver, _ = db.ToValue[int64](qr)
|
||
|
|
if ver != 2 {
|
||
|
|
t.Errorf("Expected version 2, got %d", ver)
|
||
|
|
}
|
||
|
|
|
||
|
|
// Try update with old version (should fail to update any rows)
|
||
|
|
dataConflict := map[string]any{"name": "Conflict", "autoVersion": int64(1)}
|
||
|
|
resConflict := dbInst.Update("users", dataConflict, "id = 1")
|
||
|
|
if resConflict.Changes() != 0 {
|
||
|
|
t.Errorf("Expected 0 changes due to optimistic lock, got %d", resConflict.Changes())
|
||
|
|
}
|
||
|
|
})
|
||
|
|
}
|