mirror of
https://github.com/nalgeon/redka.git
synced 2025-10-06 00:16:52 +08:00
postgres backend (#48)
This commit is contained in:
@@ -3,9 +3,9 @@ package set
|
||||
import (
|
||||
"testing"
|
||||
|
||||
"github.com/nalgeon/be"
|
||||
"github.com/nalgeon/redka/internal/core"
|
||||
"github.com/nalgeon/redka/internal/redis"
|
||||
"github.com/nalgeon/redka/internal/testx"
|
||||
)
|
||||
|
||||
func TestSInterParse(t *testing.T) {
|
||||
@@ -34,11 +34,11 @@ func TestSInterParse(t *testing.T) {
|
||||
for _, test := range tests {
|
||||
t.Run(test.cmd, func(t *testing.T) {
|
||||
cmd, err := redis.Parse(ParseSInter, test.cmd)
|
||||
testx.AssertEqual(t, err, test.err)
|
||||
be.Equal(t, err, test.err)
|
||||
if err == nil {
|
||||
testx.AssertEqual(t, cmd.keys, test.want.keys)
|
||||
be.Equal(t, cmd.keys, test.want.keys)
|
||||
} else {
|
||||
testx.AssertEqual(t, cmd, test.want)
|
||||
be.Equal(t, cmd, test.want)
|
||||
}
|
||||
})
|
||||
}
|
||||
@@ -46,92 +46,85 @@ func TestSInterParse(t *testing.T) {
|
||||
|
||||
func TestSInterExec(t *testing.T) {
|
||||
t.Run("non-empty", func(t *testing.T) {
|
||||
db, red := getDB(t)
|
||||
defer db.Close()
|
||||
_, _ = db.Set().Add("key1", "one", "two", "thr")
|
||||
_, _ = db.Set().Add("key2", "two", "thr", "fou")
|
||||
_, _ = db.Set().Add("key3", "one", "two", "thr", "fou")
|
||||
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(ParseSInter, "sinter key1 key2 key3")
|
||||
conn := redis.NewFakeConn()
|
||||
res, err := cmd.Run(conn, red)
|
||||
testx.AssertNoErr(t, err)
|
||||
testx.AssertEqual(t, len(res.([]core.Value)), 2)
|
||||
testx.AssertEqual(t, conn.Out(), "2,thr,two")
|
||||
be.Err(t, err, nil)
|
||||
be.Equal(t, len(res.([]core.Value)), 2)
|
||||
be.Equal(t, conn.Out(), "2,thr,two")
|
||||
})
|
||||
t.Run("no keys", func(t *testing.T) {
|
||||
db, red := getDB(t)
|
||||
defer db.Close()
|
||||
red := getRedka(t)
|
||||
|
||||
cmd := redis.MustParse(ParseSInter, "sinter key1")
|
||||
conn := redis.NewFakeConn()
|
||||
res, err := cmd.Run(conn, red)
|
||||
testx.AssertNoErr(t, err)
|
||||
testx.AssertEqual(t, len(res.([]core.Value)), 0)
|
||||
testx.AssertEqual(t, conn.Out(), "0")
|
||||
be.Err(t, err, nil)
|
||||
be.Equal(t, len(res.([]core.Value)), 0)
|
||||
be.Equal(t, conn.Out(), "0")
|
||||
})
|
||||
t.Run("single key", func(t *testing.T) {
|
||||
db, red := getDB(t)
|
||||
defer db.Close()
|
||||
_, _ = db.Set().Add("key1", "one", "two", "thr")
|
||||
red := getRedka(t)
|
||||
_, _ = red.Set().Add("key1", "one", "two", "thr")
|
||||
|
||||
cmd := redis.MustParse(ParseSInter, "sinter key1")
|
||||
conn := redis.NewFakeConn()
|
||||
res, err := cmd.Run(conn, red)
|
||||
testx.AssertNoErr(t, err)
|
||||
testx.AssertEqual(t, len(res.([]core.Value)), 3)
|
||||
testx.AssertEqual(t, conn.Out(), "3,one,thr,two")
|
||||
be.Err(t, err, nil)
|
||||
be.Equal(t, len(res.([]core.Value)), 3)
|
||||
be.Equal(t, conn.Out(), "3,one,thr,two")
|
||||
})
|
||||
t.Run("empty", func(t *testing.T) {
|
||||
db, red := getDB(t)
|
||||
defer db.Close()
|
||||
_, _ = db.Set().Add("key1", "one", "two")
|
||||
_, _ = db.Set().Add("key2", "two", "thr")
|
||||
_, _ = db.Set().Add("key3", "thr", "fou")
|
||||
red := getRedka(t)
|
||||
_, _ = red.Set().Add("key1", "one", "two")
|
||||
_, _ = red.Set().Add("key2", "two", "thr")
|
||||
_, _ = red.Set().Add("key3", "thr", "fou")
|
||||
|
||||
cmd := redis.MustParse(ParseSInter, "sinter key1 key2 key3")
|
||||
conn := redis.NewFakeConn()
|
||||
res, err := cmd.Run(conn, red)
|
||||
testx.AssertNoErr(t, err)
|
||||
testx.AssertEqual(t, len(res.([]core.Value)), 0)
|
||||
testx.AssertEqual(t, conn.Out(), "0")
|
||||
be.Err(t, err, nil)
|
||||
be.Equal(t, len(res.([]core.Value)), 0)
|
||||
be.Equal(t, conn.Out(), "0")
|
||||
})
|
||||
t.Run("key not found", func(t *testing.T) {
|
||||
db, red := getDB(t)
|
||||
defer db.Close()
|
||||
_, _ = db.Set().Add("key1", "one")
|
||||
_, _ = db.Set().Add("key2", "one")
|
||||
red := getRedka(t)
|
||||
_, _ = red.Set().Add("key1", "one")
|
||||
_, _ = red.Set().Add("key2", "one")
|
||||
|
||||
cmd := redis.MustParse(ParseSInter, "sinter key1 key2 key3")
|
||||
conn := redis.NewFakeConn()
|
||||
res, err := cmd.Run(conn, red)
|
||||
testx.AssertNoErr(t, err)
|
||||
testx.AssertEqual(t, len(res.([]core.Value)), 0)
|
||||
testx.AssertEqual(t, conn.Out(), "0")
|
||||
be.Err(t, err, nil)
|
||||
be.Equal(t, len(res.([]core.Value)), 0)
|
||||
be.Equal(t, conn.Out(), "0")
|
||||
})
|
||||
t.Run("all not found", func(t *testing.T) {
|
||||
db, red := getDB(t)
|
||||
defer db.Close()
|
||||
red := getRedka(t)
|
||||
|
||||
cmd := redis.MustParse(ParseSInter, "sinter key1 key2 key3")
|
||||
conn := redis.NewFakeConn()
|
||||
res, err := cmd.Run(conn, red)
|
||||
testx.AssertNoErr(t, err)
|
||||
testx.AssertEqual(t, len(res.([]core.Value)), 0)
|
||||
testx.AssertEqual(t, conn.Out(), "0")
|
||||
be.Err(t, err, nil)
|
||||
be.Equal(t, len(res.([]core.Value)), 0)
|
||||
be.Equal(t, conn.Out(), "0")
|
||||
})
|
||||
t.Run("key type mismatch", func(t *testing.T) {
|
||||
db, red := getDB(t)
|
||||
defer db.Close()
|
||||
_, _ = db.Set().Add("key1", "one")
|
||||
_ = db.Str().Set("key2", "one")
|
||||
_, _ = db.Set().Add("key3", "one")
|
||||
red := getRedka(t)
|
||||
_, _ = red.Set().Add("key1", "one")
|
||||
_ = red.Str().Set("key2", "one")
|
||||
_, _ = red.Set().Add("key3", "one")
|
||||
|
||||
cmd := redis.MustParse(ParseSInter, "sinter key1 key2 key3")
|
||||
conn := redis.NewFakeConn()
|
||||
res, err := cmd.Run(conn, red)
|
||||
testx.AssertNoErr(t, err)
|
||||
testx.AssertEqual(t, len(res.([]core.Value)), 0)
|
||||
testx.AssertEqual(t, conn.Out(), "0")
|
||||
be.Err(t, err, nil)
|
||||
be.Equal(t, len(res.([]core.Value)), 0)
|
||||
be.Equal(t, conn.Out(), "0")
|
||||
})
|
||||
}
|
||||
|
Reference in New Issue
Block a user