mirror of
https://github.com/nalgeon/redka.git
synced 2025-09-27 04:16:00 +08:00
168 lines
4.5 KiB
Go
168 lines
4.5 KiB
Go
package set
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/nalgeon/be"
|
|
"github.com/nalgeon/redka/internal/core"
|
|
"github.com/nalgeon/redka/internal/redis"
|
|
)
|
|
|
|
func TestSUnionStoreParse(t *testing.T) {
|
|
tests := []struct {
|
|
cmd string
|
|
want SUnionStore
|
|
err error
|
|
}{
|
|
{
|
|
cmd: "sunionstore",
|
|
want: SUnionStore{},
|
|
err: redis.ErrInvalidArgNum,
|
|
},
|
|
{
|
|
cmd: "sunionstore dest",
|
|
want: SUnionStore{},
|
|
err: redis.ErrInvalidArgNum,
|
|
},
|
|
{
|
|
cmd: "sunionstore dest key",
|
|
want: SUnionStore{dest: "dest", keys: []string{"key"}},
|
|
err: nil,
|
|
},
|
|
{
|
|
cmd: "sunionstore dest k1 k2",
|
|
want: SUnionStore{dest: "dest", keys: []string{"k1", "k2"}},
|
|
err: nil,
|
|
},
|
|
}
|
|
|
|
for _, test := range tests {
|
|
t.Run(test.cmd, func(t *testing.T) {
|
|
cmd, err := redis.Parse(ParseSUnionStore, test.cmd)
|
|
be.Equal(t, err, test.err)
|
|
if err == nil {
|
|
be.Equal(t, cmd.dest, test.want.dest)
|
|
be.Equal(t, cmd.keys, test.want.keys)
|
|
} else {
|
|
be.Equal(t, cmd, test.want)
|
|
}
|
|
})
|
|
}
|
|
}
|
|
|
|
func TestSUnionStoreExec(t *testing.T) {
|
|
t.Run("store", func(t *testing.T) {
|
|
red := getRedka(t)
|
|
_, _ = red.Set().Add("key1", "one", "two", "thr")
|
|
_, _ = red.Set().Add("key2", "two", "thr", "fou")
|
|
_, _ = red.Set().Add("key3", "one", "two", "thr", "fou")
|
|
|
|
cmd := redis.MustParse(ParseSUnionStore, "sunionstore dest key1 key2 key3")
|
|
conn := redis.NewFakeConn()
|
|
res, err := cmd.Run(conn, red)
|
|
be.Err(t, err, nil)
|
|
be.Equal(t, res, 4)
|
|
be.Equal(t, conn.Out(), "4")
|
|
|
|
items, _ := red.Set().Items("dest")
|
|
sortValues(items)
|
|
be.Equal(t, items, []core.Value{
|
|
core.Value("fou"), core.Value("one"), core.Value("thr"), core.Value("two"),
|
|
})
|
|
})
|
|
t.Run("rewrite dest", func(t *testing.T) {
|
|
red := getRedka(t)
|
|
_, _ = red.Set().Add("key1", "one")
|
|
_, _ = red.Set().Add("key2", "one")
|
|
_, _ = red.Set().Add("dest", "old")
|
|
|
|
cmd := redis.MustParse(ParseSUnionStore, "sunionstore dest key1 key2")
|
|
conn := redis.NewFakeConn()
|
|
res, err := cmd.Run(conn, red)
|
|
be.Err(t, err, nil)
|
|
be.Equal(t, res, 1)
|
|
be.Equal(t, conn.Out(), "1")
|
|
|
|
items, _ := red.Set().Items("dest")
|
|
be.Equal(t, items, []core.Value{core.Value("one")})
|
|
})
|
|
t.Run("single key", func(t *testing.T) {
|
|
red := getRedka(t)
|
|
_, _ = red.Set().Add("key1", "one", "two")
|
|
_, _ = red.Set().Add("dest", "old")
|
|
|
|
cmd := redis.MustParse(ParseSUnionStore, "sunionstore dest key1")
|
|
conn := redis.NewFakeConn()
|
|
res, err := cmd.Run(conn, red)
|
|
be.Err(t, err, nil)
|
|
be.Equal(t, res, 2)
|
|
be.Equal(t, conn.Out(), "2")
|
|
|
|
items, _ := red.Set().Items("dest")
|
|
sortValues(items)
|
|
be.Equal(t, items, []core.Value{core.Value("one"), core.Value("two")})
|
|
})
|
|
t.Run("empty", func(t *testing.T) {
|
|
red := getRedka(t)
|
|
_, _ = red.Set().Add("dest", "old")
|
|
|
|
cmd := redis.MustParse(ParseSUnionStore, "sunionstore dest key1 key2")
|
|
conn := redis.NewFakeConn()
|
|
res, err := cmd.Run(conn, red)
|
|
be.Err(t, err, nil)
|
|
be.Equal(t, res, 0)
|
|
be.Equal(t, conn.Out(), "0")
|
|
|
|
items, _ := red.Set().Items("dest")
|
|
be.Equal(t, items, []core.Value(nil))
|
|
})
|
|
t.Run("source key not found", func(t *testing.T) {
|
|
red := getRedka(t)
|
|
_, _ = red.Set().Add("key1", "one")
|
|
_, _ = red.Set().Add("key2", "one")
|
|
_, _ = red.Set().Add("dest", "old")
|
|
|
|
cmd := redis.MustParse(ParseSUnionStore, "sunionstore dest key1 key2 key3")
|
|
conn := redis.NewFakeConn()
|
|
res, err := cmd.Run(conn, red)
|
|
be.Err(t, err, nil)
|
|
be.Equal(t, res, 1)
|
|
be.Equal(t, conn.Out(), "1")
|
|
|
|
items, _ := red.Set().Items("dest")
|
|
be.Equal(t, items, []core.Value{core.Value("one")})
|
|
})
|
|
t.Run("source key type mismatch", func(t *testing.T) {
|
|
red := getRedka(t)
|
|
_, _ = red.Set().Add("key1", "one")
|
|
_, _ = red.Set().Add("key2", "one")
|
|
_ = red.Str().Set("key3", "one")
|
|
|
|
cmd := redis.MustParse(ParseSUnionStore, "sunionstore dest key1 key2 key3")
|
|
conn := redis.NewFakeConn()
|
|
res, err := cmd.Run(conn, red)
|
|
be.Err(t, err, nil)
|
|
be.Equal(t, res, 1)
|
|
be.Equal(t, conn.Out(), "1")
|
|
|
|
items, _ := red.Set().Items("dest")
|
|
be.Equal(t, items, []core.Value{core.Value("one")})
|
|
})
|
|
t.Run("dest key type mismatch", func(t *testing.T) {
|
|
red := getRedka(t)
|
|
_, _ = red.Set().Add("key1", "one")
|
|
_, _ = red.Set().Add("key2", "one")
|
|
_ = red.Str().Set("dest", "old")
|
|
|
|
cmd := redis.MustParse(ParseSUnionStore, "sunionstore dest key1 key2")
|
|
conn := redis.NewFakeConn()
|
|
res, err := cmd.Run(conn, red)
|
|
be.Err(t, err, core.ErrKeyType)
|
|
be.Equal(t, res, nil)
|
|
be.Equal(t, conn.Out(), core.ErrKeyType.Error()+" (sunionstore)")
|
|
|
|
sval, _ := red.Str().Get("dest")
|
|
be.Equal(t, sval, core.Value("old"))
|
|
})
|
|
}
|