ledisdb/server/cmd_hash_test.go

312 lines
6.2 KiB
Go

package server
import (
"fmt"
"strconv"
"testing"
"github.com/siddontang/goredis"
)
func TestHash(t *testing.T) {
c := getTestConn()
defer c.Close()
key := []byte("a")
if n, err := goredis.Int(c.Do("hkeyexists", key)); err != nil {
t.Fatal(err)
} else if n != 0 {
t.Fatal(n)
}
if n, err := goredis.Int(c.Do("hset", key, 1, 0)); err != nil {
t.Fatal(err)
} else if n != 1 {
t.Fatal(n)
}
if n, err := goredis.Int(c.Do("hkeyexists", key)); err != nil {
t.Fatal(err)
} else if n != 1 {
t.Fatal(n)
}
if n, err := goredis.Int(c.Do("hexists", key, 1)); err != nil {
t.Fatal(err)
} else if n != 1 {
t.Fatal(n)
}
if n, err := goredis.Int(c.Do("hexists", key, -1)); err != nil {
t.Fatal(err)
} else if n != 0 {
t.Fatal(n)
}
if n, err := goredis.Int(c.Do("hget", key, 1)); err != nil {
t.Fatal(err)
} else if n != 0 {
t.Fatal(n)
}
if n, err := goredis.Int(c.Do("hset", key, 1, 1)); err != nil {
t.Fatal(err)
} else if n != 0 {
t.Fatal(n)
}
if n, err := goredis.Int(c.Do("hget", key, 1)); err != nil {
t.Fatal(err)
} else if n != 1 {
t.Fatal(n)
}
if n, err := goredis.Int(c.Do("hlen", key)); err != nil {
t.Fatal(err)
} else if n != 1 {
t.Fatal(n)
}
}
func testHashArray(ay []interface{}, checkValues ...int) error {
if len(ay) != len(checkValues) {
return fmt.Errorf("invalid return number %d != %d", len(ay), len(checkValues))
}
for i := 0; i < len(ay); i++ {
if ay[i] == nil && checkValues[i] != 0 {
return fmt.Errorf("must nil")
} else if ay[i] != nil {
v, ok := ay[i].([]byte)
if !ok {
return fmt.Errorf("invalid return data %d %v :%T", i, ay[i], ay[i])
}
d, _ := strconv.Atoi(string(v))
if d != checkValues[i] {
return fmt.Errorf("invalid data %d %s != %d", i, v, checkValues[i])
}
}
}
return nil
}
func TestHashM(t *testing.T) {
c := getTestConn()
defer c.Close()
key := []byte("b")
if ok, err := goredis.String(c.Do("hmset", key, 1, 1, 2, 2, 3, 3)); err != nil {
t.Fatal(err)
} else if ok != OK {
t.Fatal(ok)
}
if n, err := goredis.Int(c.Do("hlen", key)); err != nil {
t.Fatal(err)
} else if n != 3 {
t.Fatal(n)
}
if v, err := goredis.MultiBulk(c.Do("hmget", key, 1, 2, 3, 4)); err != nil {
t.Fatal(err)
} else {
if err := testHashArray(v, 1, 2, 3, 0); err != nil {
t.Fatal(err)
}
}
if n, err := goredis.Int(c.Do("hdel", key, 1, 2, 3, 4)); err != nil {
t.Fatal(err)
} else if n != 3 {
t.Fatal(n)
}
if n, err := goredis.Int(c.Do("hlen", key)); err != nil {
t.Fatal(err)
} else if n != 0 {
t.Fatal(n)
}
if v, err := goredis.MultiBulk(c.Do("hmget", key, 1, 2, 3, 4)); err != nil {
t.Fatal(err)
} else {
if err := testHashArray(v, 0, 0, 0, 0); err != nil {
t.Fatal(err)
}
}
if n, err := goredis.Int(c.Do("hlen", key)); err != nil {
t.Fatal(err)
} else if n != 0 {
t.Fatal(n)
}
}
func TestHashIncr(t *testing.T) {
c := getTestConn()
defer c.Close()
key := []byte("c")
if n, err := goredis.Int(c.Do("hincrby", key, 1, 1)); err != nil {
t.Fatal(err)
} else if n != 1 {
t.Fatal(err)
}
if n, err := goredis.Int(c.Do("hlen", key)); err != nil {
t.Fatal(err)
} else if n != 1 {
t.Fatal(n)
}
if n, err := goredis.Int(c.Do("hincrby", key, 1, 10)); err != nil {
t.Fatal(err)
} else if n != 11 {
t.Fatal(err)
}
if n, err := goredis.Int(c.Do("hlen", key)); err != nil {
t.Fatal(err)
} else if n != 1 {
t.Fatal(n)
}
if n, err := goredis.Int(c.Do("hincrby", key, 1, -11)); err != nil {
t.Fatal(err)
} else if n != 0 {
t.Fatal(err)
}
}
func TestHashGetAll(t *testing.T) {
c := getTestConn()
defer c.Close()
key := []byte("d")
if ok, err := goredis.String(c.Do("hmset", key, 1, 1, 2, 2, 3, 3)); err != nil {
t.Fatal(err)
} else if ok != OK {
t.Fatal(ok)
}
if v, err := goredis.MultiBulk(c.Do("hgetall", key)); err != nil {
t.Fatal(err)
} else {
if err := testHashArray(v, 1, 1, 2, 2, 3, 3); err != nil {
t.Fatal(err)
}
}
if v, err := goredis.MultiBulk(c.Do("hkeys", key)); err != nil {
t.Fatal(err)
} else {
if err := testHashArray(v, 1, 2, 3); err != nil {
t.Fatal(err)
}
}
if v, err := goredis.MultiBulk(c.Do("hvals", key)); err != nil {
t.Fatal(err)
} else {
if err := testHashArray(v, 1, 2, 3); err != nil {
t.Fatal(err)
}
}
if n, err := goredis.Int(c.Do("hclear", key)); err != nil {
t.Fatal(err)
} else if n != 3 {
t.Fatal(n)
}
if n, err := goredis.Int(c.Do("hlen", key)); err != nil {
t.Fatal(err)
} else if n != 0 {
t.Fatal(n)
}
}
func TestHashErrorParams(t *testing.T) {
c := getTestConn()
defer c.Close()
if _, err := c.Do("hset", "test_hset"); err == nil {
t.Fatalf("invalid err of %v", err)
}
if _, err := c.Do("hget", "test_hget"); err == nil {
t.Fatalf("invalid err of %v", err)
}
if _, err := c.Do("hexists", "test_hexists"); err == nil {
t.Fatalf("invalid err of %v", err)
}
if _, err := c.Do("hdel", "test_hdel"); err == nil {
t.Fatalf("invalid err of %v", err)
}
if _, err := c.Do("hlen", "test_hlen", "a"); err == nil {
t.Fatalf("invalid err of %v", err)
}
if _, err := c.Do("hincrby", "test_hincrby"); err == nil {
t.Fatalf("invalid err of %v", err)
}
if _, err := c.Do("hmset", "test_hmset"); err == nil {
t.Fatalf("invalid err of %v", err)
}
if _, err := c.Do("hmset", "test_hmset", "f1", "v1", "f2"); err == nil {
t.Fatalf("invalid err of %v", err)
}
if _, err := c.Do("hmget", "test_hget"); err == nil {
t.Fatalf("invalid err of %v", err)
}
if _, err := c.Do("hgetall"); err == nil {
t.Fatalf("invalid err of %v", err)
}
if _, err := c.Do("hkeys"); err == nil {
t.Fatalf("invalid err of %v", err)
}
if _, err := c.Do("hvals"); err == nil {
t.Fatalf("invalid err of %v", err)
}
if _, err := c.Do("hclear"); err == nil {
t.Fatalf("invalid err of %v", err)
}
if _, err := c.Do("hclear", "test_hclear", "a"); err == nil {
t.Fatalf("invalid err of %v", err)
}
if _, err := c.Do("hmclear"); err == nil {
t.Fatalf("invalid err of %v", err)
}
if _, err := c.Do("hexpire", "test_hexpire"); err == nil {
t.Fatalf("invalid err of %v", err)
}
if _, err := c.Do("hexpireat", "test_hexpireat"); err == nil {
t.Fatalf("invalid err of %v", err)
}
if _, err := c.Do("httl"); err == nil {
t.Fatalf("invalid err of %v", err)
}
if _, err := c.Do("hpersist"); err == nil {
t.Fatalf("invalid err of %v", err)
}
}