postgres backend (#48)

This commit is contained in:
Anton Zhiyanov
2025-07-13 13:05:18 +05:00
committed by GitHub
parent 7c532df931
commit 2178c81fca
179 changed files with 8084 additions and 7408 deletions

View File

@@ -3,8 +3,8 @@ package string
import (
"testing"
"github.com/nalgeon/be"
"github.com/nalgeon/redka/internal/redis"
"github.com/nalgeon/redka/internal/testx"
)
func TestMSetParse(t *testing.T) {
@@ -46,11 +46,11 @@ func TestMSetParse(t *testing.T) {
for _, test := range tests {
t.Run(test.cmd, func(t *testing.T) {
cmd, err := redis.Parse(ParseMSet, test.cmd)
testx.AssertEqual(t, err, test.err)
be.Equal(t, err, test.err)
if err == nil {
testx.AssertEqual(t, cmd.items, test.want.items)
be.Equal(t, cmd.items, test.want.items)
} else {
testx.AssertEqual(t, cmd, test.want)
be.Equal(t, cmd, test.want)
}
})
}
@@ -58,73 +58,69 @@ func TestMSetParse(t *testing.T) {
func TestMSetExec(t *testing.T) {
t.Run("create single", func(t *testing.T) {
db, red := getDB(t)
defer db.Close()
red := getRedka(t)
cmd := redis.MustParse(ParseMSet, "mset name alice")
conn := redis.NewFakeConn()
res, err := cmd.Run(conn, red)
testx.AssertNoErr(t, err)
testx.AssertEqual(t, res, true)
testx.AssertEqual(t, conn.Out(), "OK")
be.Err(t, err, nil)
be.Equal(t, res, true)
be.Equal(t, conn.Out(), "OK")
name, _ := db.Str().Get("name")
testx.AssertEqual(t, name.String(), "alice")
name, _ := red.Str().Get("name")
be.Equal(t, name.String(), "alice")
})
t.Run("create multiple", func(t *testing.T) {
db, red := getDB(t)
defer db.Close()
red := getRedka(t)
cmd := redis.MustParse(ParseMSet, "mset name alice age 25")
conn := redis.NewFakeConn()
res, err := cmd.Run(conn, red)
testx.AssertNoErr(t, err)
testx.AssertEqual(t, res, true)
testx.AssertEqual(t, conn.Out(), "OK")
be.Err(t, err, nil)
be.Equal(t, res, true)
be.Equal(t, conn.Out(), "OK")
name, _ := db.Str().Get("name")
testx.AssertEqual(t, name.String(), "alice")
age, _ := db.Str().Get("age")
testx.AssertEqual(t, age.String(), "25")
name, _ := red.Str().Get("name")
be.Equal(t, name.String(), "alice")
age, _ := red.Str().Get("age")
be.Equal(t, age.String(), "25")
})
t.Run("create/update", func(t *testing.T) {
db, red := getDB(t)
defer db.Close()
red := getRedka(t)
_ = db.Str().Set("name", "alice")
_ = red.Str().Set("name", "alice")
cmd := redis.MustParse(ParseMSet, "mset name bob age 50")
conn := redis.NewFakeConn()
res, err := cmd.Run(conn, red)
testx.AssertNoErr(t, err)
testx.AssertEqual(t, res, true)
testx.AssertEqual(t, conn.Out(), "OK")
be.Err(t, err, nil)
be.Equal(t, res, true)
be.Equal(t, conn.Out(), "OK")
name, _ := db.Str().Get("name")
testx.AssertEqual(t, name.String(), "bob")
age, _ := db.Str().Get("age")
testx.AssertEqual(t, age.String(), "50")
name, _ := red.Str().Get("name")
be.Equal(t, name.String(), "bob")
age, _ := red.Str().Get("age")
be.Equal(t, age.String(), "50")
})
t.Run("update multiple", func(t *testing.T) {
db, red := getDB(t)
defer db.Close()
red := getRedka(t)
_ = db.Str().Set("name", "alice")
_ = db.Str().Set("age", 25)
_ = red.Str().Set("name", "alice")
_ = red.Str().Set("age", 25)
cmd := redis.MustParse(ParseMSet, "mset name bob age 50")
conn := redis.NewFakeConn()
res, err := cmd.Run(conn, red)
testx.AssertNoErr(t, err)
testx.AssertEqual(t, res, true)
testx.AssertEqual(t, conn.Out(), "OK")
be.Err(t, err, nil)
be.Equal(t, res, true)
be.Equal(t, conn.Out(), "OK")
name, _ := db.Str().Get("name")
testx.AssertEqual(t, name.String(), "bob")
age, _ := db.Str().Get("age")
testx.AssertEqual(t, age.String(), "50")
name, _ := red.Str().Get("name")
be.Equal(t, name.String(), "bob")
age, _ := red.Str().Get("age")
be.Equal(t, age.String(), "50")
})
}