2020-05-23 11:34:44 +01:00
|
|
|
package client
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
|
2020-07-27 13:22:00 +01:00
|
|
|
"github.com/micro/go-micro/v3/metadata"
|
2020-05-23 11:34:44 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestCache(t *testing.T) {
|
|
|
|
ctx := context.TODO()
|
2020-07-27 13:22:00 +01:00
|
|
|
req := &testRequest{service: "go.micro.service.foo", method: "Foo.Bar"}
|
2020-05-23 11:34:44 +01:00
|
|
|
|
|
|
|
t.Run("CacheMiss", func(t *testing.T) {
|
2020-07-27 13:22:00 +01:00
|
|
|
if _, ok := NewCache().Get(ctx, req); ok {
|
2020-05-23 11:34:44 +01:00
|
|
|
t.Errorf("Expected to get no result from Get")
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("CacheHit", func(t *testing.T) {
|
|
|
|
c := NewCache()
|
|
|
|
|
|
|
|
rsp := "theresponse"
|
2020-07-27 13:22:00 +01:00
|
|
|
c.Set(ctx, req, rsp, time.Minute)
|
2020-05-23 11:34:44 +01:00
|
|
|
|
2020-07-27 13:22:00 +01:00
|
|
|
if res, ok := c.Get(ctx, req); !ok {
|
2020-05-23 11:34:44 +01:00
|
|
|
t.Errorf("Expected a result, got nothing")
|
|
|
|
} else if res != rsp {
|
|
|
|
t.Errorf("Expected '%v' result, got '%v'", rsp, res)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestCacheKey(t *testing.T) {
|
|
|
|
ctx := context.TODO()
|
2020-07-27 13:22:00 +01:00
|
|
|
|
|
|
|
req1 := &testRequest{service: "go.micro.service.foo", method: "Foo.Bar"}
|
|
|
|
req2 := &testRequest{service: "go.micro.service.foo", method: "Foo.Baz"}
|
|
|
|
req3 := &testRequest{service: "go.micro.service.foo", method: "Foo.Bar", body: "customquery"}
|
2020-05-23 11:34:44 +01:00
|
|
|
|
|
|
|
t.Run("IdenticalRequests", func(t *testing.T) {
|
2020-07-27 13:22:00 +01:00
|
|
|
key1 := key(ctx, req1)
|
|
|
|
key2 := key(ctx, req1)
|
2020-05-23 11:34:44 +01:00
|
|
|
if key1 != key2 {
|
|
|
|
t.Errorf("Expected the keys to match for identical requests and context")
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("DifferentRequestEndpoints", func(t *testing.T) {
|
2020-07-27 13:22:00 +01:00
|
|
|
key1 := key(ctx, req1)
|
|
|
|
key2 := key(ctx, req2)
|
2020-05-23 11:34:44 +01:00
|
|
|
|
|
|
|
if key1 == key2 {
|
|
|
|
t.Errorf("Expected the keys to differ for different request endpoints")
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("DifferentRequestBody", func(t *testing.T) {
|
2020-07-27 13:22:00 +01:00
|
|
|
key1 := key(ctx, req2)
|
|
|
|
key2 := key(ctx, req3)
|
2020-05-23 11:34:44 +01:00
|
|
|
|
|
|
|
if key1 == key2 {
|
|
|
|
t.Errorf("Expected the keys to differ for different request bodies")
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
t.Run("DifferentMetadata", func(t *testing.T) {
|
2020-05-27 09:14:16 +01:00
|
|
|
mdCtx := metadata.Set(context.TODO(), "Micro-Namespace", "bar")
|
2020-07-27 13:22:00 +01:00
|
|
|
key1 := key(mdCtx, req1)
|
|
|
|
key2 := key(ctx, req1)
|
2020-05-23 11:34:44 +01:00
|
|
|
|
|
|
|
if key1 == key2 {
|
|
|
|
t.Errorf("Expected the keys to differ for different metadata")
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|