add sql wrapper tests, regen
Signed-off-by: Vasiliy Tolstov <v.tolstov@unistack.org>
This commit is contained in:
@@ -3,6 +3,7 @@ package grpc_test
|
||||
import (
|
||||
"context"
|
||||
"io"
|
||||
"net"
|
||||
"net/http"
|
||||
"testing"
|
||||
|
||||
@@ -17,17 +18,26 @@ import (
|
||||
"go.unistack.org/micro/v3/client"
|
||||
"go.unistack.org/micro/v3/codec"
|
||||
"go.unistack.org/micro/v3/errors"
|
||||
"go.unistack.org/micro/v3/logger"
|
||||
"go.unistack.org/micro/v3/metadata"
|
||||
"go.unistack.org/micro/v3/register"
|
||||
"go.unistack.org/micro/v3/router"
|
||||
"go.unistack.org/micro/v3/server"
|
||||
health "go.unistack.org/micro/v3/server/health"
|
||||
jsonpb "google.golang.org/protobuf/encoding/protojson"
|
||||
"google.golang.org/grpc"
|
||||
"google.golang.org/grpc/credentials/insecure"
|
||||
"google.golang.org/grpc/encoding/gzip"
|
||||
gmetadata "google.golang.org/grpc/metadata"
|
||||
)
|
||||
|
||||
type testServer struct {
|
||||
pb.UnimplementedTestServer
|
||||
}
|
||||
|
||||
type testnServer struct {
|
||||
pb.UnimplementedTestServer
|
||||
}
|
||||
|
||||
func NewServerHandlerWrapper() server.HandlerWrapper {
|
||||
return func(fn server.HandlerFunc) server.HandlerFunc {
|
||||
return func(ctx context.Context, req server.Request, rsp interface{}) error {
|
||||
@@ -38,6 +48,10 @@ func NewServerHandlerWrapper() server.HandlerWrapper {
|
||||
}
|
||||
|
||||
func (g *testServer) Call(ctx context.Context, req *pb.Request, rsp *pb.Response) error {
|
||||
_, ok := metadata.FromIncomingContext(ctx)
|
||||
if !ok {
|
||||
return errors.InternalServerError("xxx", "missing metadata")
|
||||
}
|
||||
if req.Name == "Error" {
|
||||
return &errors.Error{ID: "id", Code: 99, Detail: "detail"}
|
||||
}
|
||||
@@ -47,16 +61,34 @@ func (g *testServer) Call(ctx context.Context, req *pb.Request, rsp *pb.Response
|
||||
return nil
|
||||
}
|
||||
|
||||
func (g *testnServer) Call(ctx context.Context, req *pb.Request) (*pb.Response, error) {
|
||||
_, ok := gmetadata.FromIncomingContext(ctx)
|
||||
if !ok {
|
||||
return nil, errors.InternalServerError("xxx", "missing metadata")
|
||||
}
|
||||
|
||||
if req.Name == "Error" {
|
||||
return nil, &errors.Error{ID: "id", Code: 99, Detail: "detail"}
|
||||
}
|
||||
rsp := &pb.Response{}
|
||||
|
||||
for i := 0; i < 650; i++ {
|
||||
rsp.Msg += "Hello " + req.Name
|
||||
}
|
||||
return rsp, nil
|
||||
}
|
||||
|
||||
func TestGRPCServer(t *testing.T) {
|
||||
var err error
|
||||
|
||||
codec.DefaultMaxMsgSize = 8 * 1024 * 1024
|
||||
ctx, cancel := context.WithCancel(context.Background())
|
||||
defer cancel()
|
||||
|
||||
_ = logger.DefaultLogger.Init(logger.WithLevel(logger.ErrorLevel))
|
||||
r := register.NewRegister()
|
||||
b := broker.NewBroker(broker.Register(r))
|
||||
s := gserver.NewServer(
|
||||
server.Codec("application/grpc+proto", protocodec.NewCodec()),
|
||||
server.Codec("application/grpc", protocodec.NewCodec()),
|
||||
server.Address("127.0.0.1:0"),
|
||||
server.Register(r),
|
||||
server.Name("helloworld"),
|
||||
@@ -122,35 +154,91 @@ func TestGRPCServer(t *testing.T) {
|
||||
t.Fatalf("unknown version returned from health handler: %s", buf)
|
||||
}
|
||||
|
||||
lis, err := net.Listen("tcp", "127.0.0.1:0")
|
||||
if err != nil {
|
||||
t.Fatalf("failed to listen: %v", err)
|
||||
}
|
||||
gs := grpc.NewServer()
|
||||
pb.RegisterTestServer(gs, &testnServer{})
|
||||
go func() {
|
||||
if err := gs.Serve(lis); err != nil {
|
||||
t.Fatalf("failed to serve: %v", err)
|
||||
}
|
||||
}()
|
||||
|
||||
// lookup server
|
||||
service, err := r.LookupService(ctx, "helloworld")
|
||||
if err != nil {
|
||||
t.Fatal(err)
|
||||
}
|
||||
|
||||
if len(service) != 1 {
|
||||
t.Fatalf("Expected 1 service got %d: %+v", len(service), service)
|
||||
}
|
||||
|
||||
if len(service[0].Nodes) != 1 {
|
||||
t.Fatalf("Expected 1 node got %d: %+v", len(service[0].Nodes), service[0].Nodes)
|
||||
}
|
||||
|
||||
// create client
|
||||
c := gclient.NewClient(client.Codec("application/grpc+proto", protocodec.NewCodec()), client.Router(rtr), client.Register(r), client.Broker(b))
|
||||
gc := gclient.NewClient(
|
||||
client.ContentType("application/grpc"),
|
||||
client.Codec("application/grpc", protocodec.NewCodec()), client.Router(rtr), client.Register(r), client.Broker(b))
|
||||
|
||||
testMethods := []string{
|
||||
"Test.Call",
|
||||
c := gpb.NewTestClient("helloworld", gc)
|
||||
|
||||
var md metadata.Metadata
|
||||
t.Logf("call micro via micro")
|
||||
rq := &pb.Request{Name: "John"}
|
||||
for i := 0; i < 1500; i++ {
|
||||
rq.Name += "name"
|
||||
}
|
||||
|
||||
for _, method := range testMethods {
|
||||
req := c.NewRequest("helloworld", method, &pb.Request{
|
||||
Name: "John",
|
||||
})
|
||||
|
||||
rsp := &pb.Response{}
|
||||
|
||||
err = c.Call(context.TODO(), req, rsp)
|
||||
if err != nil {
|
||||
t.Fatalf("method: %s err: %v", method, err)
|
||||
}
|
||||
|
||||
if rsp.Msg != "Hello John" {
|
||||
t.Fatalf("Got unexpected response %v", rsp.Msg)
|
||||
}
|
||||
|
||||
enc := &jsonpb.MarshalOptions{EmitUnpopulated: true}
|
||||
_, err := enc.Marshal(rsp)
|
||||
if err != nil {
|
||||
t.Fatal(err)
|
||||
}
|
||||
_, err = c.Call(ctx, rq,
|
||||
client.WithResponseMetadata(&md),
|
||||
gclient.CallOptions(grpc.UseCompressor(gzip.Name)))
|
||||
if err != nil {
|
||||
t.Fatalf("err: %v", err)
|
||||
}
|
||||
t.Logf("response md %#+v", md)
|
||||
|
||||
ngcli, err := grpc.DialContext(ctx,
|
||||
// lis.Addr().String(),
|
||||
service[0].Nodes[0].Address,
|
||||
grpc.WithTransportCredentials(insecure.NewCredentials()),
|
||||
)
|
||||
if err != nil {
|
||||
t.Fatal(err)
|
||||
}
|
||||
defer ngcli.Close()
|
||||
|
||||
var gmd gmetadata.MD
|
||||
ngrpcsvc := pb.NewTestClient(ngcli)
|
||||
t.Logf("call micro via native")
|
||||
if _, err = ngrpcsvc.Call(ctx, rq,
|
||||
grpc.UseCompressor(gzip.Name),
|
||||
grpc.Header(&gmd)); err != nil {
|
||||
t.Fatal(err)
|
||||
}
|
||||
t.Logf("gmd %#+v\n", gmd)
|
||||
|
||||
nxgcli, err := grpc.DialContext(ctx,
|
||||
lis.Addr().String(),
|
||||
// service[0].Nodes[0].Address,
|
||||
grpc.WithTransportCredentials(insecure.NewCredentials()),
|
||||
)
|
||||
if err != nil {
|
||||
t.Fatal(err)
|
||||
}
|
||||
defer nxgcli.Close()
|
||||
|
||||
ngrpcsvc = pb.NewTestClient(nxgcli)
|
||||
t.Logf("call native via native")
|
||||
if _, err := ngrpcsvc.Call(ctx, rq,
|
||||
grpc.UseCompressor(gzip.Name),
|
||||
grpc.Header(&gmd)); err != nil {
|
||||
t.Fatal(err)
|
||||
}
|
||||
t.Logf("gmd %#+v\n", gmd)
|
||||
|
||||
//rsp := rpb.ServerReflectionResponse{}
|
||||
//req := c.NewRequest("helloworld", "Test.ServerReflectionInfo", &rpb.ServerReflectionRequest{}, client.StreamingRequest())
|
||||
|
Reference in New Issue
Block a user