2019-06-03 19:44:43 +02:00
|
|
|
package grpc
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"crypto/tls"
|
|
|
|
"sync"
|
|
|
|
"testing"
|
2019-12-11 18:24:26 +02:00
|
|
|
"time"
|
2019-06-03 19:44:43 +02:00
|
|
|
|
2020-01-30 13:39:00 +02:00
|
|
|
"github.com/micro/go-micro/v2/registry/memory"
|
|
|
|
"github.com/micro/go-micro/v2/service"
|
|
|
|
hello "github.com/micro/go-micro/v2/service/grpc/proto"
|
|
|
|
mls "github.com/micro/go-micro/v2/util/tls"
|
2019-06-03 19:44:43 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
type testHandler struct{}
|
|
|
|
|
2019-06-05 11:22:28 +02:00
|
|
|
func (t *testHandler) Call(ctx context.Context, req *hello.Request, rsp *hello.Response) error {
|
2019-06-03 19:44:43 +02:00
|
|
|
rsp.Msg = "Hello " + req.Name
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestGRPCService(t *testing.T) {
|
|
|
|
var wg sync.WaitGroup
|
|
|
|
wg.Add(1)
|
|
|
|
|
|
|
|
ctx, cancel := context.WithCancel(context.Background())
|
|
|
|
defer cancel()
|
|
|
|
|
|
|
|
// create memory registry
|
|
|
|
r := memory.NewRegistry()
|
|
|
|
|
|
|
|
// create GRPC service
|
|
|
|
service := NewService(
|
2019-12-29 23:07:55 +02:00
|
|
|
service.Name("test.service"),
|
|
|
|
service.Registry(r),
|
|
|
|
service.AfterStart(func() error {
|
2019-06-03 19:44:43 +02:00
|
|
|
wg.Done()
|
|
|
|
return nil
|
|
|
|
}),
|
2019-12-29 23:07:55 +02:00
|
|
|
service.Context(ctx),
|
2019-06-03 19:44:43 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
// register test handler
|
2019-06-05 11:22:28 +02:00
|
|
|
hello.RegisterTestHandler(service.Server(), &testHandler{})
|
2019-06-03 19:44:43 +02:00
|
|
|
|
|
|
|
// run service
|
2019-12-11 18:24:26 +02:00
|
|
|
errCh := make(chan error, 1)
|
2019-06-03 19:44:43 +02:00
|
|
|
go func() {
|
2019-12-11 18:24:26 +02:00
|
|
|
defer close(errCh)
|
|
|
|
errCh <- service.Run()
|
2019-06-03 19:44:43 +02:00
|
|
|
}()
|
|
|
|
|
|
|
|
// wait for start
|
|
|
|
wg.Wait()
|
|
|
|
|
|
|
|
// create client
|
2019-06-05 11:22:28 +02:00
|
|
|
test := hello.NewTestService("test.service", service.Client())
|
2019-06-03 19:44:43 +02:00
|
|
|
|
|
|
|
// call service
|
2019-12-11 18:24:26 +02:00
|
|
|
ctx2, cancel2 := context.WithTimeout(context.Background(), time.Duration(time.Second))
|
|
|
|
defer cancel2()
|
|
|
|
rsp, err := test.Call(ctx2, &hello.Request{
|
2019-06-03 19:44:43 +02:00
|
|
|
Name: "John",
|
|
|
|
})
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
|
2019-12-11 18:24:26 +02:00
|
|
|
// check server
|
|
|
|
select {
|
|
|
|
case err := <-errCh:
|
|
|
|
t.Fatal(err)
|
|
|
|
case <-time.After(time.Second):
|
|
|
|
break
|
|
|
|
}
|
|
|
|
|
2019-06-03 19:44:43 +02:00
|
|
|
// check message
|
|
|
|
if rsp.Msg != "Hello John" {
|
|
|
|
t.Fatalf("unexpected response %s", rsp.Msg)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestGRPCTLSService(t *testing.T) {
|
|
|
|
var wg sync.WaitGroup
|
|
|
|
wg.Add(1)
|
|
|
|
|
|
|
|
ctx, cancel := context.WithCancel(context.Background())
|
|
|
|
defer cancel()
|
|
|
|
|
|
|
|
// create memory registry
|
|
|
|
r := memory.NewRegistry()
|
|
|
|
|
|
|
|
// create cert
|
|
|
|
cert, err := mls.Certificate("test.service")
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
config := &tls.Config{
|
|
|
|
Certificates: []tls.Certificate{cert},
|
|
|
|
InsecureSkipVerify: true,
|
|
|
|
}
|
|
|
|
|
|
|
|
// create GRPC service
|
|
|
|
service := NewService(
|
2019-12-29 23:07:55 +02:00
|
|
|
service.Name("test.service"),
|
|
|
|
service.Registry(r),
|
|
|
|
service.AfterStart(func() error {
|
2019-06-03 19:44:43 +02:00
|
|
|
wg.Done()
|
|
|
|
return nil
|
|
|
|
}),
|
2019-12-29 23:07:55 +02:00
|
|
|
service.Context(ctx),
|
2019-06-03 19:44:43 +02:00
|
|
|
// set TLS config
|
|
|
|
WithTLS(config),
|
|
|
|
)
|
|
|
|
|
|
|
|
// register test handler
|
2019-06-05 11:22:28 +02:00
|
|
|
hello.RegisterTestHandler(service.Server(), &testHandler{})
|
2019-06-03 19:44:43 +02:00
|
|
|
|
|
|
|
// run service
|
2019-12-11 18:28:49 +02:00
|
|
|
errCh := make(chan error, 1)
|
2019-06-03 19:44:43 +02:00
|
|
|
go func() {
|
2019-12-11 18:28:49 +02:00
|
|
|
defer close(errCh)
|
|
|
|
errCh <- service.Run()
|
2019-06-03 19:44:43 +02:00
|
|
|
}()
|
|
|
|
|
|
|
|
// wait for start
|
|
|
|
wg.Wait()
|
|
|
|
|
|
|
|
// create client
|
2019-06-05 11:22:28 +02:00
|
|
|
test := hello.NewTestService("test.service", service.Client())
|
2019-06-03 19:44:43 +02:00
|
|
|
|
|
|
|
// call service
|
2019-12-11 18:28:49 +02:00
|
|
|
ctx2, cancel2 := context.WithTimeout(context.Background(), time.Duration(time.Second))
|
|
|
|
defer cancel2()
|
|
|
|
rsp, err := test.Call(ctx2, &hello.Request{
|
2019-06-03 19:44:43 +02:00
|
|
|
Name: "John",
|
|
|
|
})
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
|
2019-12-11 18:28:49 +02:00
|
|
|
// check server
|
|
|
|
select {
|
|
|
|
case err := <-errCh:
|
|
|
|
t.Fatal(err)
|
|
|
|
case <-time.After(time.Second):
|
|
|
|
break
|
|
|
|
}
|
|
|
|
|
2019-06-03 19:44:43 +02:00
|
|
|
// check message
|
|
|
|
if rsp.Msg != "Hello John" {
|
|
|
|
t.Fatalf("unexpected response %s", rsp.Msg)
|
|
|
|
}
|
|
|
|
}
|