ledisdb/ledis/ledis_test.go

108 lines
2.1 KiB
Go

package ledis
import (
"sync"
"testing"
)
var testLedis *Ledis
var testLedisOnce sync.Once
func getTestDB() *DB {
f := func() {
var d = []byte(`
{
"data_db" : {
"path" : "/tmp/testdb",
"compression":true,
"block_size" : 32768,
"write_buffer_size" : 2097152,
"cache_size" : 20971520
},
"binlog" : {
"path" : "/tmp/testdb_binlog",
"max_file_size" : 1073741824,
"max_file_num" : 3
}
}
`)
var err error
testLedis, err = Open(d)
if err != nil {
println(err.Error())
panic(err)
}
testLedis.ldb.Clear()
}
testLedisOnce.Do(f)
db, _ := testLedis.Select(0)
return db
}
func TestDB(t *testing.T) {
getTestDB()
}
func TestSelect(t *testing.T) {
db0, _ := testLedis.Select(0)
db1, _ := testLedis.Select(1)
key0 := []byte("db0_test_key")
key1 := []byte("db1_test_key")
db0.Set(key0, []byte("0"))
db1.Set(key1, []byte("1"))
if v, err := db0.Get(key0); err != nil {
t.Fatal(err)
} else if string(v) != "0" {
t.Fatal(string(v))
}
if v, err := db1.Get(key1); err != nil {
t.Fatal(err)
} else if string(v) != "1" {
t.Fatal(string(v))
}
}
func TestFlush(t *testing.T) {
db0, _ := testLedis.Select(0)
db1, _ := testLedis.Select(1)
db0.Set([]byte("a"), []byte("1"))
db0.ZAdd([]byte("zset_0"), ScorePair{int64(1), []byte("ma")})
db0.ZAdd([]byte("zset_0"), ScorePair{int64(2), []byte("mb")})
db1.Set([]byte("b"), []byte("2"))
db1.LPush([]byte("lst"), []byte("a1"), []byte("b2"))
db1.ZAdd([]byte("zset_0"), ScorePair{int64(3), []byte("mc")})
db1.Flush()
// 0 - existing
if exists, _ := db0.Exists([]byte("a")); exists <= 0 {
t.Fatal(false)
}
if zcnt, _ := db0.ZCard([]byte("zset_0")); zcnt != 2 {
t.Fatal(zcnt)
}
// 1 - deleted
if exists, _ := db1.Exists([]byte("b")); exists > 0 {
t.Fatal(false)
}
if llen, _ := db1.LLen([]byte("lst")); llen > 0 {
t.Fatal(llen)
}
if zcnt, _ := db1.ZCard([]byte("zset_1")); zcnt > 0 {
t.Fatal(zcnt)
}
}