micro/client/mucp/mucp_test.go

160 lines
3.5 KiB
Go
Raw Normal View History

package mucp
2016-11-07 18:51:25 +00:00
import (
2018-03-03 11:53:52 +00:00
"context"
2016-11-07 18:51:25 +00:00
"fmt"
"testing"
"github.com/unistack-org/micro/v3/client"
"github.com/unistack-org/micro/v3/errors"
"github.com/unistack-org/micro/v3/registry"
"github.com/unistack-org/micro/v3/registry/memory"
"github.com/unistack-org/micro/v3/router"
regRouter "github.com/unistack-org/micro/v3/router/registry"
2016-11-07 18:51:25 +00:00
)
func newTestRouter() router.Router {
reg := memory.NewRegistry(memory.Services(testData))
return regRouter.NewRouter(router.Registry(reg))
2019-01-14 15:27:25 +00:00
}
2018-04-14 16:16:58 +01:00
func TestCallAddress(t *testing.T) {
var called bool
service := "test.service"
2019-01-10 21:25:31 +00:00
endpoint := "Test.Endpoint"
2019-07-08 08:01:42 +01:00
address := "10.1.10.1:8080"
2018-04-14 16:16:58 +01:00
wrap := func(cf client.CallFunc) client.CallFunc {
return func(ctx context.Context, node string, req client.Request, rsp interface{}, opts client.CallOptions) error {
2018-04-14 16:16:58 +01:00
called = true
if req.Service() != service {
return fmt.Errorf("expected service: %s got %s", service, req.Service())
}
2019-01-10 21:25:31 +00:00
if req.Endpoint() != endpoint {
return fmt.Errorf("expected service: %s got %s", endpoint, req.Endpoint())
2018-04-14 16:16:58 +01:00
}
if node != address {
return fmt.Errorf("expected address: %s got %s", address, node)
2019-01-18 12:30:39 +00:00
}
2018-04-14 16:16:58 +01:00
// don't do the call
return nil
}
}
r := newTestRouter()
2018-04-14 16:16:58 +01:00
c := NewClient(
client.Router(r),
client.WrapCall(wrap),
2018-04-14 16:16:58 +01:00
)
2019-01-10 21:25:31 +00:00
req := c.NewRequest(service, endpoint, nil)
2018-04-14 16:16:58 +01:00
// test calling remote address
if err := c.Call(context.Background(), req, nil, client.WithAddress(address)); err != nil {
2018-04-14 16:16:58 +01:00
t.Fatal("call with address error", err)
}
if !called {
t.Fatal("wrapper not called")
}
}
func TestCallRetry(t *testing.T) {
service := "test.service"
2019-01-10 21:25:31 +00:00
endpoint := "Test.Endpoint"
2019-01-18 12:30:39 +00:00
address := "10.1.10.1"
var called int
wrap := func(cf client.CallFunc) client.CallFunc {
return func(ctx context.Context, node string, req client.Request, rsp interface{}, opts client.CallOptions) error {
called++
if called == 1 {
return errors.InternalServerError("test.error", "retry request")
}
// don't do the call
return nil
}
}
r := newTestRouter()
c := NewClient(
client.Router(r),
client.WrapCall(wrap),
)
2019-01-10 21:25:31 +00:00
req := c.NewRequest(service, endpoint, nil)
// test calling remote address
if err := c.Call(context.Background(), req, nil, client.WithAddress(address)); err != nil {
t.Fatal("call with address error", err)
}
// num calls
if called < c.Options().CallOptions.Retries+1 {
t.Fatal("request not retried")
}
}
2016-11-07 18:51:25 +00:00
func TestCallWrapper(t *testing.T) {
var called bool
id := "test.1"
service := "test.service"
2019-01-10 21:25:31 +00:00
endpoint := "Test.Endpoint"
2019-07-08 08:01:42 +01:00
address := "10.1.10.1:8080"
2016-11-07 18:51:25 +00:00
wrap := func(cf client.CallFunc) client.CallFunc {
return func(ctx context.Context, node string, req client.Request, rsp interface{}, opts client.CallOptions) error {
2016-11-07 18:51:25 +00:00
called = true
if req.Service() != service {
return fmt.Errorf("expected service: %s got %s", service, req.Service())
}
2019-01-10 21:25:31 +00:00
if req.Endpoint() != endpoint {
return fmt.Errorf("expected service: %s got %s", endpoint, req.Endpoint())
2016-11-07 18:51:25 +00:00
}
if node != address {
return fmt.Errorf("expected address: %s got %s", address, node)
2016-11-07 18:51:25 +00:00
}
// don't do the call
return nil
}
}
r := newTestRouter()
2016-11-07 18:51:25 +00:00
c := NewClient(
client.Router(r),
client.WrapCall(wrap),
2016-11-07 18:51:25 +00:00
)
r.Options().Registry.Register(&registry.Service{
2016-11-07 18:51:25 +00:00
Name: service,
Version: "latest",
Nodes: []*registry.Node{
{
2016-11-07 18:51:25 +00:00
Id: id,
2019-01-18 12:30:39 +00:00
Address: address,
2016-11-07 18:51:25 +00:00
},
},
})
2019-01-10 21:25:31 +00:00
req := c.NewRequest(service, endpoint, nil)
2016-11-07 18:51:25 +00:00
if err := c.Call(context.Background(), req, nil); err != nil {
t.Fatal("call wrapper error", err)
}
if !called {
t.Fatal("wrapper not called")
}
}