summaryrefslogtreecommitdiff
path: root/tests/plugins/kv/memory
diff options
context:
space:
mode:
authorValery Piashchynski <[email protected]>2021-04-22 14:41:50 +0300
committerValery Piashchynski <[email protected]>2021-04-22 14:41:50 +0300
commitabf606afd6fd9fbb0fd374ab5da41a8ee8d5a15d (patch)
treeb0cfdeb5c478463d853b8a7409e88cfa7219c3fa /tests/plugins/kv/memory
parente4d65a41ec90747a387cfe769f743327959f7105 (diff)
- Implement tests for the KV
- Implement Storage interface for the boltdb,memory,memcached drivers Signed-off-by: Valery Piashchynski <[email protected]>
Diffstat (limited to 'tests/plugins/kv/memory')
-rw-r--r--tests/plugins/kv/memory/configs/.rr-init.yaml42
-rw-r--r--tests/plugins/kv/memory/plugin_test.go195
2 files changed, 0 insertions, 237 deletions
diff --git a/tests/plugins/kv/memory/configs/.rr-init.yaml b/tests/plugins/kv/memory/configs/.rr-init.yaml
deleted file mode 100644
index 8780a622..00000000
--- a/tests/plugins/kv/memory/configs/.rr-init.yaml
+++ /dev/null
@@ -1,42 +0,0 @@
-rpc:
- listen: tcp://127.0.0.1:6001
-
-server:
- command: "php ../../../psr-worker-bench.php"
- user: ""
- group: ""
- env:
- "RR_HTTP": "true"
- relay: "pipes"
- relay_timeout: "20s"
-
-logs:
- mode: development
- level: error
-
-http:
- address: 127.0.0.1:44933
- max_request_size: 1024
- middleware: ["gzip", "headers"]
- uploads:
- forbid: [".php", ".exe", ".bat"]
- trusted_subnets:
- [
- "10.0.0.0/8",
- "127.0.0.0/8",
- "172.16.0.0/12",
- "192.168.0.0/16",
- "::1/128",
- "fc00::/7",
- "fe80::/10",
- ]
- pool:
- num_workers: 6
- max_jobs: 0
- allocate_timeout: 60s
- destroy_timeout: 60s
-
-# in memory KV driver
-memory:
- # keys ttl check interval
- interval: 1
diff --git a/tests/plugins/kv/memory/plugin_test.go b/tests/plugins/kv/memory/plugin_test.go
deleted file mode 100644
index 23d23bc0..00000000
--- a/tests/plugins/kv/memory/plugin_test.go
+++ /dev/null
@@ -1,195 +0,0 @@
-package memory_test
-
-import (
- "net"
- "net/rpc"
- "os"
- "os/signal"
- "sync"
- "syscall"
- "testing"
- "time"
-
- endure "github.com/spiral/endure/pkg/container"
- goridgeRpc "github.com/spiral/goridge/v3/pkg/rpc"
- "github.com/spiral/roadrunner/v2/plugins/config"
- httpPlugin "github.com/spiral/roadrunner/v2/plugins/http"
- "github.com/spiral/roadrunner/v2/plugins/kv"
- "github.com/spiral/roadrunner/v2/plugins/kv/drivers/memory"
- "github.com/spiral/roadrunner/v2/plugins/logger"
- rpcPlugin "github.com/spiral/roadrunner/v2/plugins/rpc"
- "github.com/spiral/roadrunner/v2/plugins/server"
- "github.com/stretchr/testify/assert"
-)
-
-func TestInMemory(t *testing.T) {
- cont, err := endure.NewContainer(nil, endure.SetLogLevel(endure.ErrorLevel))
- assert.NoError(t, err)
-
- cfg := &config.Viper{
- Path: "configs/.rr-init.yaml",
- Prefix: "rr",
- }
-
- err = cont.RegisterAll(
- cfg,
- &memory.Plugin{},
- &rpcPlugin.Plugin{},
- &logger.ZapLogger{},
- &server.Plugin{},
- &httpPlugin.Plugin{},
- )
- assert.NoError(t, err)
-
- err = cont.Init()
- if err != nil {
- t.Fatal(err)
- }
-
- ch, err := cont.Serve()
- assert.NoError(t, err)
-
- sig := make(chan os.Signal, 1)
- signal.Notify(sig, os.Interrupt, syscall.SIGINT, syscall.SIGTERM)
-
- wg := &sync.WaitGroup{}
- wg.Add(1)
-
- stopCh := make(chan struct{}, 1)
-
- go func() {
- defer wg.Done()
- for {
- select {
- case e := <-ch:
- assert.Fail(t, "error", e.Error.Error())
- err = cont.Stop()
- if err != nil {
- assert.FailNow(t, "error", err.Error())
- }
- case <-sig:
- err = cont.Stop()
- if err != nil {
- assert.FailNow(t, "error", err.Error())
- }
- return
- case <-stopCh:
- // timeout
- err = cont.Stop()
- if err != nil {
- assert.FailNow(t, "error", err.Error())
- }
- return
- }
- }
- }()
-
- time.Sleep(time.Second * 1)
- t.Run("testInMemoryRPCMethods", testRPCMethods)
- stopCh <- struct{}{}
- wg.Wait()
-
- _ = os.Remove("rr")
-}
-
-func testRPCMethods(t *testing.T) {
- conn, err := net.Dial("tcp", "127.0.0.1:6001")
- assert.NoError(t, err)
- client := rpc.NewClientWithCodec(goridgeRpc.NewClientCodec(conn))
-
- var setRes bool
- items := make([]kv.Item, 0, 5)
- items = append(items, kv.Item{
- Key: "a",
- Value: "aa",
- })
- items = append(items, kv.Item{
- Key: "b",
- Value: "bb",
- })
- // add 5 second ttl
- tt := time.Now().Add(time.Second * 5).Format(time.RFC3339)
- items = append(items, kv.Item{
- Key: "c",
- Value: "cc",
- TTL: tt,
- })
-
- items = append(items, kv.Item{
- Key: "d",
- Value: "dd",
- })
-
- items = append(items, kv.Item{
- Key: "e",
- Value: "ee",
- })
-
- // Register 3 keys with values
- err = client.Call("memory.Set", items, &setRes)
- assert.NoError(t, err)
- assert.True(t, setRes)
-
- ret := make(map[string]bool)
- keys := []string{"a", "b", "c"}
- err = client.Call("memory.Has", keys, &ret)
- assert.NoError(t, err)
- assert.Len(t, ret, 3) // should be 3
-
- // key "c" should be deleted
- time.Sleep(time.Second * 7)
-
- ret = make(map[string]bool)
- err = client.Call("memory.Has", keys, &ret)
- assert.NoError(t, err)
- assert.Len(t, ret, 2) // should be 2
-
- mGet := make(map[string]interface{})
- keys = []string{"a", "b", "c"}
- err = client.Call("memory.MGet", keys, &mGet)
- assert.NoError(t, err)
- assert.Len(t, mGet, 2) // c is expired
- assert.Equal(t, string("aa"), mGet["a"].(string))
- assert.Equal(t, string("bb"), mGet["b"].(string))
-
- mExpKeys := make([]kv.Item, 0, 2)
- tt2 := time.Now().Add(time.Second * 10).Format(time.RFC3339)
- mExpKeys = append(mExpKeys, kv.Item{Key: "a", TTL: tt2})
- mExpKeys = append(mExpKeys, kv.Item{Key: "b", TTL: tt2})
- mExpKeys = append(mExpKeys, kv.Item{Key: "d", TTL: tt2})
-
- // MEXPIRE
- var mExpRes bool
- err = client.Call("memory.MExpire", mExpKeys, &mExpRes)
- assert.NoError(t, err)
- assert.True(t, mExpRes)
-
- // TTL
- keys = []string{"a", "b", "d"}
- ttlRes := make(map[string]interface{})
- err = client.Call("memory.TTL", keys, &ttlRes)
- assert.NoError(t, err)
- assert.Len(t, ttlRes, 3)
-
- // HAS AFTER TTL
- time.Sleep(time.Second * 15)
- ret = make(map[string]bool)
- keys = []string{"a", "b", "d"}
- err = client.Call("memory.Has", keys, &ret)
- assert.NoError(t, err)
- assert.Len(t, ret, 0)
-
- // DELETE
- keys = []string{"e"}
- var delRet bool
- err = client.Call("memory.Delete", keys, &delRet)
- assert.NoError(t, err)
- assert.True(t, delRet)
-
- // HAS AFTER DELETE
- ret = make(map[string]bool)
- keys = []string{"e"}
- err = client.Call("memory.Has", keys, &ret)
- assert.NoError(t, err)
- assert.Len(t, ret, 0)
-}