func TestXSelect(t *testing.T) { c1 := getTestConn() defer c1.Close() c2 := getTestConn() defer c2.Close() _, err := c1.Do("XSELECT", "1", "THEN", "SET", "tmp_select_key", "1") if err != nil { t.Fatal(err) } _, err = goredis.Int(c2.Do("GET", "tmp_select_key")) if err != goredis.ErrNil { t.Fatal(err) } n, _ := goredis.Int(c2.Do("XSELECT", "1", "THEN", "GET", "tmp_select_key")) if n != 1 { t.Fatal(n) } n, _ = goredis.Int(c2.Do("GET", "tmp_select_key")) if n != 1 { t.Fatal(n) } c1.Do("SELECT", 0) c2.Do("SELECT", 0) }
func TestListMPush(t *testing.T) { c := getTestConn() defer c.Close() key := []byte("b") if n, err := goredis.Int(c.Do("rpush", key, 1, 2, 3)); err != nil { t.Fatal(err) } else if n != 3 { t.Fatal(n) } if err := testListRange(key, 0, 3, 1, 2, 3); err != nil { t.Fatal(err) } if n, err := goredis.Int(c.Do("lpush", key, 1, 2, 3)); err != nil { t.Fatal(err) } else if n != 6 { t.Fatal(n) } if err := testListRange(key, 0, 6, 3, 2, 1, 1, 2, 3); err != nil { t.Fatal(err) } }
func TestZSetRank(t *testing.T) { c := getTestConn() defer c.Close() key := []byte("myzset") if _, err := goredis.Int(c.Do("zadd", key, 1, "a", 2, "b", 3, "c", 4, "d")); err != nil { t.Fatal(err) } if n, err := goredis.Int(c.Do("zrank", key, "c")); err != nil { t.Fatal(err) } else if n != 2 { t.Fatal(n) } if _, err := goredis.Int(c.Do("zrank", key, "e")); err != goredis.ErrNil { t.Fatal(err) } if n, err := goredis.Int(c.Do("zrevrank", key, "c")); err != nil { t.Fatal(err) } else if n != 1 { t.Fatal(n) } if _, err := goredis.Int(c.Do("zrevrank", key, "e")); err != goredis.ErrNil { t.Fatal(err) } }
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 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 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 testListIndex(key []byte, index int64, v int) error { c := getTestConn() defer c.Close() n, err := goredis.Int(c.Do("lindex", key, index)) if err == goredis.ErrNil && v != 0 { return fmt.Errorf("must nil") } else if err != nil && err != goredis.ErrNil { return err } else if n != v { return fmt.Errorf("index err number %d != %d", n, v) } return nil }
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 TestPop(t *testing.T) { c := getTestConn() defer c.Close() key := []byte("c") if n, err := goredis.Int(c.Do("rpush", key, 1, 2, 3, 4, 5, 6)); err != nil { t.Fatal(err) } else if n != 6 { t.Fatal(n) } if v, err := goredis.Int(c.Do("lpop", key)); err != nil { t.Fatal(err) } else if v != 1 { t.Fatal(v) } if v, err := goredis.Int(c.Do("rpop", key)); err != nil { t.Fatal(err) } else if v != 6 { t.Fatal(v) } if n, err := goredis.Int(c.Do("lpush", key, 1)); err != nil { t.Fatal(err) } else if n != 5 { t.Fatal(n) } if err := testListRange(key, 0, 5, 1, 2, 3, 4, 5); err != nil { t.Fatal(err) } for i := 1; i <= 5; i++ { if v, err := goredis.Int(c.Do("lpop", key)); err != nil { t.Fatal(err) } else if v != i { t.Fatal(v) } } if n, err := goredis.Int(c.Do("llen", key)); err != nil { t.Fatal(err) } else if n != 0 { t.Fatal(n) } c.Do("rpush", key, 1, 2, 3, 4, 5) if n, err := goredis.Int(c.Do("lclear", key)); err != nil { t.Fatal(err) } else if n != 5 { t.Fatal(n) } if n, err := goredis.Int(c.Do("llen", key)); err != nil { t.Fatal(err) } else if n != 0 { t.Fatal(n) } }
func TestZSetRange(t *testing.T) { c := getTestConn() defer c.Close() key := []byte("myzset_range_rank") if _, err := goredis.Int(c.Do("zadd", key, 1, "a", 2, "b", 3, "c", 4, "d")); err != nil { t.Fatal(err) } if v, err := goredis.MultiBulk(c.Do("zrange", key, 0, 3, "withscores")); err != nil { t.Fatal(err) } else { if err := testZSetRange(v, "a", 1, "b", 2, "c", 3, "d", 4); err != nil { t.Fatal(err) } } if v, err := goredis.MultiBulk(c.Do("zrange", key, 1, 4, "withscores")); err != nil { t.Fatal(err) } else { if err := testZSetRange(v, "b", 2, "c", 3, "d", 4); err != nil { t.Fatal(err) } } if v, err := goredis.MultiBulk(c.Do("zrange", key, -2, -1, "withscores")); err != nil { t.Fatal(err) } else { if err := testZSetRange(v, "c", 3, "d", 4); err != nil { t.Fatal(err) } } if v, err := goredis.MultiBulk(c.Do("zrange", key, 0, -1, "withscores")); err != nil { t.Fatal(err) } else { if err := testZSetRange(v, "a", 1, "b", 2, "c", 3, "d", 4); err != nil { t.Fatal(err) } } if v, err := goredis.MultiBulk(c.Do("zrange", key, -1, -2, "withscores")); err != nil { t.Fatal(err) } else if len(v) != 0 { t.Fatal(len(v)) } if v, err := goredis.MultiBulk(c.Do("zrevrange", key, 0, 4, "withscores")); err != nil { t.Fatal(err) } else { if err := testZSetRange(v, "d", 4, "c", 3, "b", 2, "a", 1); err != nil { t.Fatal(err) } } if v, err := goredis.MultiBulk(c.Do("zrevrange", key, 0, -1, "withscores")); err != nil { t.Fatal(err) } else { if err := testZSetRange(v, "d", 4, "c", 3, "b", 2, "a", 1); err != nil { t.Fatal(err) } } if v, err := goredis.MultiBulk(c.Do("zrevrange", key, 2, 3, "withscores")); err != nil { t.Fatal(err) } else { if err := testZSetRange(v, "b", 2, "a", 1); err != nil { t.Fatal(err) } } if v, err := goredis.MultiBulk(c.Do("zrevrange", key, -2, -1, "withscores")); err != nil { t.Fatal(err) } else { if err := testZSetRange(v, "b", 2, "a", 1); err != nil { t.Fatal(err) } } if n, err := goredis.Int(c.Do("zremrangebyrank", key, 2, 3)); err != nil { t.Fatal(err) } else if n != 2 { t.Fatal(n) } if n, err := goredis.Int(c.Do("zcard", key)); err != nil { t.Fatal(err) } else if n != 2 { t.Fatal(n) } if v, err := goredis.MultiBulk(c.Do("zrange", key, 0, 4)); err != nil { t.Fatal(err) } else { if err := testZSetRange(v, "a", "b"); err != nil { t.Fatal(err) } } if n, err := goredis.Int(c.Do("zclear", key)); err != nil { t.Fatal(err) } else if n != 2 { t.Fatal(n) } if n, err := goredis.Int(c.Do("zcard", key)); err != nil { t.Fatal(err) } else if n != 0 { t.Fatal(n) } }
func TestZSetRangeScore(t *testing.T) { c := getTestConn() defer c.Close() key := []byte("myzset_range") if _, err := goredis.Int(c.Do("zadd", key, 1, "a", 2, "b", 3, "c", 4, "d")); err != nil { t.Fatal(err) } if v, err := goredis.MultiBulk(c.Do("zrangebyscore", key, 1, 4, "withscores")); err != nil { t.Fatal(err) } else { if err := testZSetRange(v, "a", 1, "b", 2, "c", 3, "d", 4); err != nil { t.Fatal(err) } } if v, err := goredis.MultiBulk(c.Do("zrangebyscore", key, 1, 4, "withscores", "limit", 1, 2)); err != nil { t.Fatal(err) } else { if err := testZSetRange(v, "b", 2, "c", 3); err != nil { t.Fatal(err) } } if v, err := goredis.MultiBulk(c.Do("zrangebyscore", key, "-inf", "+inf", "withscores")); err != nil { t.Fatal(err) } else { if err := testZSetRange(v, "a", 1, "b", 2, "c", 3, "d", 4); err != nil { t.Fatal(err) } } if v, err := goredis.MultiBulk(c.Do("zrangebyscore", key, "(1", "(4")); err != nil { t.Fatal(err) } else { if err := testZSetRange(v, "b", "c"); err != nil { t.Fatal(err) } } if v, err := goredis.MultiBulk(c.Do("zrevrangebyscore", key, 4, 1, "withscores")); err != nil { t.Fatal(err) } else { if err := testZSetRange(v, "d", 4, "c", 3, "b", 2, "a", 1); err != nil { t.Fatal(err) } } if v, err := goredis.MultiBulk(c.Do("zrevrangebyscore", key, 4, 1, "withscores", "limit", 1, 2)); err != nil { t.Fatal(err) } else { if err := testZSetRange(v, "c", 3, "b", 2); err != nil { t.Fatal(err) } } if v, err := goredis.MultiBulk(c.Do("zrevrangebyscore", key, "+inf", "-inf", "withscores")); err != nil { t.Fatal(err) } else { if err := testZSetRange(v, "d", 4, "c", 3, "b", 2, "a", 1); err != nil { t.Fatal(err) } } if v, err := goredis.MultiBulk(c.Do("zrevrangebyscore", key, "(4", "(1")); err != nil { t.Fatal(err) } else { if err := testZSetRange(v, "c", "b"); err != nil { t.Fatal(err) } } if n, err := goredis.Int(c.Do("zremrangebyscore", key, 2, 3)); err != nil { t.Fatal(err) } else if n != 2 { t.Fatal(n) } if n, err := goredis.Int(c.Do("zcard", key)); err != nil { t.Fatal(err) } else if n != 2 { t.Fatal(n) } if v, err := goredis.MultiBulk(c.Do("zrangebyscore", key, 1, 4)); err != nil { t.Fatal(err) } else { if err := testZSetRange(v, "a", "d"); err != nil { t.Fatal(err) } } }
func TestSort(t *testing.T) { c := getTestConn() defer c.Close() key := "my_sort_key" storeKey := "my_sort_store_key" if _, err := c.Do("LPUSH", key, 3, 2, 1); err != nil { t.Fatal(err) } if _, err := c.Do("MSET", "weight_1", 3, "weight_2", 2, "weight_3", 1); err != nil { t.Fatal(err) } if _, err := c.Do("MSET", "object_1", 10, "object_2", 20, "object_3", 30); err != nil { t.Fatal(err) } if ay, err := c.Do("XLSORT", key); err != nil { t.Fatal(err) } else if err = checkTestSortRes(ay, []string{"1", "2", "3"}); err != nil { t.Fatal(err) } if ay, err := c.Do("XLSORT", key, "DESC"); err != nil { t.Fatal(err) } else if err = checkTestSortRes(ay, []string{"3", "2", "1"}); err != nil { t.Fatal(err) } if ay, err := c.Do("XLSORT", key, "LIMIT", 0, 1); err != nil { t.Fatal(err) } else if err = checkTestSortRes(ay, []string{"1"}); err != nil { t.Fatal(err) } if ay, err := c.Do("XLSORT", key, "BY", "weight_*"); err != nil { t.Fatal(err) } else if err = checkTestSortRes(ay, []string{"3", "2", "1"}); err != nil { t.Fatal(err) } if ay, err := c.Do("XLSORT", key, "GET", "object_*"); err != nil { t.Fatal(err) } else if err = checkTestSortRes(ay, []string{"10", "20", "30"}); err != nil { t.Fatal(err) } if ay, err := c.Do("XLSORT", key, "GET", "object_*", "GET", "#"); err != nil { t.Fatal(err) } else if err = checkTestSortRes(ay, []string{"10", "1", "20", "2", "30", "3"}); err != nil { t.Fatal(err) } if n, err := goredis.Int(c.Do("XLSORT", key, "STORE", storeKey)); err != nil { t.Fatal(err) } else if n != 3 { t.Fatalf("invalid return store sort number, %d != 3", n) } else if ay, err := c.Do("LRANGE", storeKey, 0, -1); err != nil { t.Fatal(err) } else if err = checkTestSortRes(ay, []string{"1", "2", "3"}); err != nil { t.Fatal(err) } }
func TestZSet(t *testing.T) { c := getTestConn() defer c.Close() key := []byte("myzset") if n, err := goredis.Int(c.Do("zkeyexists", key)); err != nil { t.Fatal(err) } else if n != 0 { t.Fatal(n) } if n, err := goredis.Int(c.Do("zadd", key, 3, "a", 4, "b")); err != nil { t.Fatal(err) } else if n != 2 { t.Fatal(n) } if n, err := goredis.Int(c.Do("zkeyexists", key)); err != nil { t.Fatal(err) } else if n != 1 { t.Fatal(n) } if n, err := goredis.Int(c.Do("zcard", key)); err != nil { t.Fatal(n) } else if n != 2 { t.Fatal(n) } if n, err := goredis.Int(c.Do("zadd", key, 1, "a", 2, "b")); err != nil { t.Fatal(err) } else if n != 0 { t.Fatal(n) } if n, err := goredis.Int(c.Do("zcard", key)); err != nil { t.Fatal(n) } else if n != 2 { t.Fatal(n) } if n, err := goredis.Int(c.Do("zadd", key, 3, "c", 4, "d")); err != nil { t.Fatal(err) } else if n != 2 { t.Fatal(n) } if n, err := goredis.Int(c.Do("zcard", key)); err != nil { t.Fatal(err) } else if n != 4 { t.Fatal(n) } if s, err := goredis.Int(c.Do("zscore", key, "c")); err != nil { t.Fatal(err) } else if s != 3 { t.Fatal(s) } if n, err := goredis.Int(c.Do("zrem", key, "d", "e")); err != nil { t.Fatal(err) } else if n != 1 { t.Fatal(n) } if n, err := goredis.Int(c.Do("zcard", key)); err != nil { t.Fatal(err) } else if n != 3 { t.Fatal(n) } if n, err := goredis.Int(c.Do("zincrby", key, 4, "c")); err != nil { t.Fatal(err) } else if n != 7 { t.Fatal(n) } if n, err := goredis.Int(c.Do("zincrby", key, -4, "c")); err != nil { t.Fatal(err) } else if n != 3 { t.Fatal(n) } if n, err := goredis.Int(c.Do("zincrby", key, 4, "d")); err != nil { t.Fatal(err) } else if n != 4 { t.Fatal(n) } if n, err := goredis.Int(c.Do("zcard", key)); err != nil { t.Fatal(err) } else if n != 4 { t.Fatal(n) } if n, err := goredis.Int(c.Do("zrem", key, "a", "b", "c", "d")); err != nil { t.Fatal(err) } else if n != 4 { t.Fatal(n) } if n, err := goredis.Int(c.Do("zcard", key)); err != nil { t.Fatal(err) } else if n != 0 { t.Fatal(n) } }
func TestExpire(t *testing.T) { // test for kv, list, hash, set, zset, bitmap in all ttlType := []string{"k", "l", "h", "s", "z"} var ( expire string expireat string ttl string persist string key string ) c := getTestConn() defer c.Close() idx := 1 for _, tt := range ttlType { if tt == "k" { expire = "expire" expireat = "expireat" ttl = "ttl" persist = "persist" } else { expire = fmt.Sprintf("%sexpire", tt) expireat = fmt.Sprintf("%sexpireat", tt) ttl = fmt.Sprintf("%sttl", tt) persist = fmt.Sprintf("%spersist", tt) } switch tt { case "k": key = "kv_ttl" c.Do("set", key, "123") case "l": key = "list_ttl" c.Do("rpush", key, "123") case "h": key = "hash_ttl" c.Do("hset", key, "a", "123") case "s": key = "set_ttl" c.Do("sadd", key, "123") case "z": key = "zset_ttl" c.Do("zadd", key, 123, "a") case "b": key = "bitmap_ttl" c.Do("bsetbit", key, 0, 1) } // expire + ttl exp := int64(10) if n, err := goredis.Int(c.Do(expire, key, exp)); err != nil { t.Fatal(err) } else if n != 1 { t.Fatal(n) } if ttl, err := goredis.Int64(c.Do(ttl, key)); err != nil { t.Fatal(err) } else if ttl == -1 { t.Fatal("no ttl") } // expireat + ttl tm := now() + 3 if n, err := goredis.Int(c.Do(expireat, key, tm)); err != nil { t.Fatal(err) } else if n != 1 { t.Fatal(n) } if ttl, err := goredis.Int64(c.Do(ttl, key)); err != nil { t.Fatal(err) } else if ttl == -1 { t.Fatal("no ttl") } kErr := "not_exist_ttl" // err - expire, expireat if n, err := goredis.Int(c.Do(expire, kErr, tm)); err != nil || n != 0 { t.Fatal(false) } if n, err := goredis.Int(c.Do(expireat, kErr, tm)); err != nil || n != 0 { t.Fatal(false) } if n, err := goredis.Int(c.Do(ttl, kErr)); err != nil || n != -1 { t.Fatal(false) } if n, err := goredis.Int(c.Do(persist, key)); err != nil { t.Fatal(err) } else if n != 1 { t.Fatal(n) } if n, err := goredis.Int(c.Do(expire, key, 10)); err != nil { t.Fatal(err) } else if n != 1 { t.Fatal(n) } if n, err := goredis.Int(c.Do(persist, key)); err != nil { t.Fatal(err) } else if n != 1 { t.Fatal(n) } idx++ } }
func TestKV(t *testing.T) { c := getTestConn() defer c.Close() if ok, err := goredis.String(c.Do("set", "a", "1234")); err != nil { t.Fatal(err) } else if ok != OK { t.Fatal(ok) } if n, err := goredis.Int(c.Do("setnx", "a", "123")); err != nil { t.Fatal(err) } else if n != 0 { t.Fatal(n) } if n, err := goredis.Int(c.Do("setnx", "b", "123")); err != nil { t.Fatal(err) } else if n != 1 { t.Fatal(n) } if ok, err := goredis.String(c.Do("setex", "xx", 10, "hello world")); err != nil { t.Fatal(err) } else if ok != OK { t.Fatal(ok) } if v, err := goredis.String(c.Do("get", "a")); err != nil { t.Fatal(err) } else if v != "1234" { t.Fatal(v) } if v, err := goredis.String(c.Do("getset", "a", "123")); err != nil { t.Fatal(err) } else if v != "1234" { t.Fatal(v) } if v, err := goredis.String(c.Do("get", "a")); err != nil { t.Fatal(err) } else if v != "123" { t.Fatal(v) } if n, err := goredis.Int(c.Do("exists", "a")); err != nil { t.Fatal(err) } else if n != 1 { t.Fatal(n) } if n, err := goredis.Int(c.Do("exists", "empty_key_test")); err != nil { t.Fatal(err) } else if n != 0 { t.Fatal(n) } if _, err := goredis.Int(c.Do("del", "a", "b")); err != nil { t.Fatal(err) } if n, err := goredis.Int(c.Do("exists", "a")); err != nil { t.Fatal(err) } else if n != 0 { t.Fatal(n) } if n, err := goredis.Int(c.Do("exists", "b")); err != nil { t.Fatal(err) } else if n != 0 { t.Fatal(n) } rangeKey := "range_key" if n, err := goredis.Int(c.Do("append", rangeKey, "Hello ")); err != nil { t.Fatal(err) } else if n != 6 { t.Fatal(n) } if n, err := goredis.Int(c.Do("setrange", rangeKey, 6, "Redis")); err != nil { t.Fatal(err) } else if n != 11 { t.Fatal(n) } if n, err := goredis.Int(c.Do("strlen", rangeKey)); err != nil { t.Fatal(err) } else if n != 11 { t.Fatal(n) } if v, err := goredis.String(c.Do("getrange", rangeKey, 0, -1)); err != nil { t.Fatal(err) } else if v != "Hello Redis" { t.Fatal(v) } bitKey := "bit_key" if n, err := goredis.Int(c.Do("setbit", bitKey, 7, 1)); err != nil { t.Fatal(err) } else if n != 0 { t.Fatal(n) } if n, err := goredis.Int(c.Do("getbit", bitKey, 7)); err != nil { t.Fatal(err) } else if n != 1 { t.Fatal(n) } if n, err := goredis.Int(c.Do("bitcount", bitKey)); err != nil { t.Fatal(err) } else if n != 1 { t.Fatal(n) } if n, err := goredis.Int(c.Do("bitpos", bitKey, 1)); err != nil { t.Fatal(err) } else if n != 7 { t.Fatal(n) } c.Do("set", "key1", "foobar") c.Do("set", "key2", "abcdef") if n, err := goredis.Int(c.Do("bitop", "and", "bit_dest_key", "key1", "key2")); err != nil { t.Fatal(err) } else if n != 6 { t.Fatal(n) } if v, err := goredis.String(c.Do("get", "bit_dest_key")); err != nil { t.Fatal(err) } else if v != "`bc`ab" { t.Fatal(v) } }
func TestTrim(t *testing.T) { c := getTestConn() defer c.Close() key := []byte("d") if n, err := goredis.Int(c.Do("rpush", key, 1, 2, 3, 4, 5, 6)); err != nil { t.Fatal(err) } else if n != 6 { t.Fatal(n) } if n, err := goredis.Int(c.Do("ltrim_front", key, 2)); err != nil { t.Fatal(err) } else if n != 2 { t.Fatal(n) } if n, err := goredis.Int(c.Do("llen", key)); err != nil { t.Fatal(err) } else if n != 4 { t.Fatal(n) } if n, err := goredis.Int(c.Do("ltrim_back", key, 2)); err != nil { t.Fatal(err) } else if n != 2 { t.Fatal(n) } if n, err := goredis.Int(c.Do("llen", key)); err != nil { t.Fatal(err) } else if n != 2 { t.Fatal(n) } if n, err := goredis.Int(c.Do("ltrim_front", key, 5)); err != nil { t.Fatal(err) } else if n != 2 { t.Fatal(n) } if n, err := goredis.Int(c.Do("llen", key)); err != nil { t.Fatal(err) } else if n != 0 { t.Fatal(n) } if n, err := goredis.Int(c.Do("rpush", key, 1, 2)); err != nil { t.Fatal(err) } else if n != 2 { t.Fatal(n) } if n, err := goredis.Int(c.Do("ltrim_front", key, 2)); err != nil { t.Fatal(err) } else if n != 2 { t.Fatal(n) } if n, err := goredis.Int(c.Do("llen", key)); err != nil { t.Fatal(err) } else if n != 0 { t.Fatal(n) } }
func TestList(t *testing.T) { c := getTestConn() defer c.Close() key := []byte("a") if n, err := goredis.Int(c.Do("lkeyexists", key)); err != nil { t.Fatal(err) } else if n != 0 { t.Fatal(n) } if n, err := goredis.Int(c.Do("lpush", key, 1)); err != nil { t.Fatal(err) } else if n != 1 { t.Fatal(n) } if n, err := goredis.Int(c.Do("lkeyexists", key)); err != nil { t.Fatal(err) } else if n != 1 { t.Fatal(1) } if n, err := goredis.Int(c.Do("rpush", key, 2)); err != nil { t.Fatal(err) } else if n != 2 { t.Fatal(n) } if n, err := goredis.Int(c.Do("rpush", key, 3)); err != nil { t.Fatal(err) } else if n != 3 { t.Fatal(n) } if n, err := goredis.Int(c.Do("llen", key)); err != nil { t.Fatal(err) } else if n != 3 { t.Fatal(n) } //for ledis-cli a 1 2 3 // 127.0.0.1:6379> lrange a 0 0 // 1) "1" if err := testListRange(key, 0, 0, 1); err != nil { t.Fatal(err) } // 127.0.0.1:6379> lrange a 0 1 // 1) "1" // 2) "2" if err := testListRange(key, 0, 1, 1, 2); err != nil { t.Fatal(err) } // 127.0.0.1:6379> lrange a 0 5 // 1) "1" // 2) "2" // 3) "3" if err := testListRange(key, 0, 5, 1, 2, 3); err != nil { t.Fatal(err) } // 127.0.0.1:6379> lrange a -1 5 // 1) "3" if err := testListRange(key, -1, 5, 3); err != nil { t.Fatal(err) } // 127.0.0.1:6379> lrange a -5 -1 // 1) "1" // 2) "2" // 3) "3" if err := testListRange(key, -5, -1, 1, 2, 3); err != nil { t.Fatal(err) } // 127.0.0.1:6379> lrange a -2 -1 // 1) "2" // 2) "3" if err := testListRange(key, -2, -1, 2, 3); err != nil { t.Fatal(err) } // 127.0.0.1:6379> lrange a -1 -2 // (empty list or set) if err := testListRange(key, -1, -2); err != nil { t.Fatal(err) } // 127.0.0.1:6379> lrange a -1 2 // 1) "3" if err := testListRange(key, -1, 2, 3); err != nil { t.Fatal(err) } // 127.0.0.1:6379> lrange a -5 5 // 1) "1" // 2) "2" // 3) "3" if err := testListRange(key, -5, 5, 1, 2, 3); err != nil { t.Fatal(err) } // 127.0.0.1:6379> lrange a -1 0 // (empty list or set) if err := testListRange(key, -1, 0); err != nil { t.Fatal(err) } if err := testListRange([]byte("empty list"), 0, 100); err != nil { t.Fatal(err) } // 127.0.0.1:6379> lrange a -1 -1 // 1) "3" if err := testListRange(key, -1, -1, 3); err != nil { t.Fatal(err) } if err := testListIndex(key, -1, 3); err != nil { t.Fatal(err) } if err := testListIndex(key, 0, 1); err != nil { t.Fatal(err) } if err := testListIndex(key, 1, 2); err != nil { t.Fatal(err) } if err := testListIndex(key, 2, 3); err != nil { t.Fatal(err) } if err := testListIndex(key, 5, 0); err != nil { t.Fatal(err) } if err := testListIndex(key, -1, 3); err != nil { t.Fatal(err) } if err := testListIndex(key, -2, 2); err != nil { t.Fatal(err) } if err := testListIndex(key, -3, 1); err != nil { t.Fatal(err) } }
func TestZSetCount(t *testing.T) { c := getTestConn() defer c.Close() key := []byte("myzset") if _, err := goredis.Int(c.Do("zadd", key, 1, "a", 2, "b", 3, "c", 4, "d")); err != nil { t.Fatal(err) } if n, err := goredis.Int(c.Do("zcount", key, 2, 4)); err != nil { t.Fatal(err) } else if n != 3 { t.Fatal(n) } if n, err := goredis.Int(c.Do("zcount", key, 4, 4)); err != nil { t.Fatal(err) } else if n != 1 { t.Fatal(n) } if n, err := goredis.Int(c.Do("zcount", key, 4, 3)); err != nil { t.Fatal(err) } else if n != 0 { t.Fatal(n) } if n, err := goredis.Int(c.Do("zcount", key, "(2", 4)); err != nil { t.Fatal(err) } else if n != 2 { t.Fatal(n) } if n, err := goredis.Int(c.Do("zcount", key, "2", "(4")); err != nil { t.Fatal(err) } else if n != 2 { t.Fatal(n) } if n, err := goredis.Int(c.Do("zcount", key, "(2", "(4")); err != nil { t.Fatal(err) } else if n != 1 { t.Fatal(n) } if n, err := goredis.Int(c.Do("zcount", key, "-inf", "+inf")); err != nil { t.Fatal(err) } else if n != 4 { t.Fatal(n) } c.Do("zadd", key, 3, "e") if n, err := goredis.Int(c.Do("zcount", key, "(2", "(4")); err != nil { t.Fatal(err) } else if n != 2 { t.Fatal(n) } c.Do("zrem", key, "a", "b", "c", "d", "e") }
func TestMigrate(t *testing.T) { data_dir := "/tmp/test_migrate" os.RemoveAll(data_dir) s1Cfg := config.NewConfigDefault() s1Cfg.DataDir = fmt.Sprintf("%s/s1", data_dir) s1Cfg.Addr = "127.0.0.1:11185" s2Cfg := config.NewConfigDefault() s2Cfg.DataDir = fmt.Sprintf("%s/s2", data_dir) s2Cfg.Addr = "127.0.0.1:11186" s1, err := NewApp(s1Cfg) if err != nil { t.Fatal(err) } defer s1.Close() s2, err := NewApp(s2Cfg) if err != nil { t.Fatal(err) } defer s2.Close() go s1.Run() go s2.Run() time.Sleep(1 * time.Second) c1, _ := goredis.Connect(s1Cfg.Addr) defer c1.Close() c2, _ := goredis.Connect(s2Cfg.Addr) defer c2.Close() if _, err = c1.Do("set", "a", "1"); err != nil { t.Fatal(err) } timeout := 30000 if _, err = c1.Do("xmigrate", "127.0.0.1", 11186, "KV", "a", 0, timeout); err != nil { t.Fatal(err) } if s, err := goredis.String(c2.Do("get", "a")); err != nil { t.Fatal(err) } else if s != "1" { t.Fatal(s, "must 1") } if s, err := goredis.String(c1.Do("get", "a")); err != nil && err != goredis.ErrNil { t.Fatal(err) } else if s != "" { t.Fatal(s, "must empty") } if num, err := goredis.Int(c2.Do("xmigratedb", "127.0.0.1", 11185, "KV", 10, 0, timeout)); err != nil { t.Fatal(err) } else if num != 1 { t.Fatal(num, "must number 1") } if s, err := goredis.String(c1.Do("get", "a")); err != nil { t.Fatal(err) } else if s != "1" { t.Fatal(s, "must 1") } if s, err := goredis.String(c2.Do("get", "a")); err != nil && err != goredis.ErrNil { t.Fatal(err) } else if s != "" { t.Fatal(s, "must empty") } if _, err = c1.Do("xmigrate", "127.0.0.1", 11186, "ALL", "a", 0, timeout); err != nil { t.Fatal(err) } if s, err := goredis.String(c2.Do("get", "a")); err != nil { t.Fatal(err) } else if s != "1" { t.Fatal(s, "must 1") } if s, err := goredis.String(c1.Do("get", "a")); err != nil && err != goredis.ErrNil { t.Fatal(err) } else if s != "" { t.Fatal(s, "must empty") } }
func TestSet(t *testing.T) { c := getTestConn() defer c.Close() key1 := "testdb_cmd_set_1" key2 := "testdb_cmd_set_2" if n, err := goredis.Int(c.Do("skeyexists", key1)); err != nil { t.Fatal(err) } else if n != 0 { t.Fatal(n) } if n, err := goredis.Int(c.Do("sadd", key1, 0, 1)); err != nil { t.Fatal(err) } else if n != 2 { t.Fatal(n) } if n, err := goredis.Int(c.Do("skeyexists", key1)); err != nil { t.Fatal(err) } else if n != 1 { t.Fatal(n) } if n, err := goredis.Int(c.Do("sadd", key2, 0, 1, 2, 3)); err != nil { t.Fatal(err) } else if n != 4 { t.Fatal(n) } if n, err := goredis.Int(c.Do("scard", key1)); err != nil { t.Fatal(err) } else if n != 2 { t.Fatal(n) } if n, err := goredis.MultiBulk(c.Do("sdiff", key2, key1)); err != nil { t.Fatal(err) } else if len(n) != 2 { t.Fatal(n) } if n, err := goredis.Int(c.Do("sdiffstore", []byte("cmd_set_em1"), key2, key1)); err != nil { t.Fatal(err) } else if n != 2 { t.Fatal(n) } if n, err := goredis.MultiBulk(c.Do("sunion", key1, key2)); err != nil { t.Fatal(err) } else if len(n) != 4 { t.Fatal(n) } if n, err := goredis.Int(c.Do("sunionstore", []byte("cmd_set_em2"), key1, key2)); err != nil { t.Fatal(err) } else if n != 4 { t.Fatal(n) } if n, err := goredis.MultiBulk(c.Do("sinter", key1, key2)); err != nil { t.Fatal(err) } else if len(n) != 2 { t.Fatal(n) } if n, err := goredis.Int(c.Do("sinterstore", []byte("cmd_set_em3"), key1, key2)); err != nil { t.Fatal(err) } else if n != 2 { t.Fatal(n) } if n, err := goredis.Int(c.Do("srem", key1, 0, 1)); err != nil { t.Fatal(err) } else if n != 2 { t.Fatal(n) } if n, err := goredis.Int(c.Do("sismember", key2, 0)); err != nil { t.Fatal(err) } else if n != 1 { t.Fatal(n) } if n, err := goredis.MultiBulk(c.Do("smembers", key2)); err != nil { t.Fatal(err) } else if len(n) != 4 { t.Fatal(n) } if n, err := goredis.Int(c.Do("sclear", key2)); err != nil { t.Fatal(err) } else if n != 4 { t.Fatal(n) } c.Do("sadd", key1, 0) c.Do("sadd", key2, 1) if n, err := goredis.Int(c.Do("smclear", key1, key2)); err != nil { t.Fatal(err) } else if n != 2 { t.Fatal(n) } }