mirror of
https://github.com/go-micro/go-micro.git
synced 2024-12-12 08:23:58 +02:00
f96b48dad9
2. try fixing grpc plugin failed to get issue use v4.0.0-v4.0.0-00010101000000-000000000000 instead of specific version 3. kafka panic on disconnect panic: runtime error: invalid memory address or nil pointer dereference [signal 0xc0000005 code=0x0 addr=0x18 pc=0x1266c50] goroutine 31 [running]: github.com/asim/go-micro/plugins/broker/kafka/v3.(*kBroker).Disconnect(0xc0002400c0) C:/Workshop/Go/pkg/mod/github.com/asim/go-micro/plugins/broker/kafka/v3@v3.7.0/kafka.go:130 +0xd0 github.com/asim/go-micro/plugins/server/grpc/v3.(*grpcServer).Start.func2() C:/Workshop/Go/pkg/mod/github.com/asim/go-micro/plugins/server/grpc/v3@v3.0.0-20210712061837-0532fd9de8ae/grpc.go:998 +0xc8d created by github.com/asim/go-micro/plugins/server/grpc/v3.(*grpcServer).Start C:/Workshop/Go/pkg/mod/github.com/asim/go-micro/plugins/server/grpc/v3@v3.0.0-20210712061837-0532fd9de8ae/grpc.go:917 +0xcaf exit status 2
114 lines
2.2 KiB
Go
114 lines
2.2 KiB
Go
package grpc
|
|
|
|
import (
|
|
"context"
|
|
"net"
|
|
"testing"
|
|
|
|
"go-micro.dev/v4/client"
|
|
"go-micro.dev/v4/errors"
|
|
"go-micro.dev/v4/registry"
|
|
"go-micro.dev/v4/selector"
|
|
pgrpc "google.golang.org/grpc"
|
|
pb "google.golang.org/grpc/examples/helloworld/helloworld"
|
|
)
|
|
|
|
// server is used to implement helloworld.GreeterServer.
|
|
type greeterServer struct {
|
|
pb.UnimplementedGreeterServer
|
|
}
|
|
|
|
// SayHello implements helloworld.GreeterServer
|
|
func (g *greeterServer) SayHello(ctx context.Context, in *pb.HelloRequest) (*pb.HelloReply, error) {
|
|
if in.Name == "Error" {
|
|
return nil, &errors.Error{Id: "1", Code: 99, Detail: "detail"}
|
|
}
|
|
return &pb.HelloReply{Message: "Hello " + in.Name}, nil
|
|
}
|
|
|
|
func TestGRPCClient(t *testing.T) {
|
|
l, err := net.Listen("tcp", ":0")
|
|
if err != nil {
|
|
t.Fatalf("failed to listen: %v", err)
|
|
}
|
|
defer l.Close()
|
|
|
|
s := pgrpc.NewServer()
|
|
pb.RegisterGreeterServer(s, &greeterServer{})
|
|
|
|
go s.Serve(l)
|
|
defer s.Stop()
|
|
|
|
// create mock registry
|
|
r := registry.NewMemoryRegistry()
|
|
|
|
// register service
|
|
r.Register(®istry.Service{
|
|
Name: "helloworld",
|
|
Version: "test",
|
|
Nodes: []*registry.Node{
|
|
{
|
|
Id: "test-1",
|
|
Address: l.Addr().String(),
|
|
Metadata: map[string]string{
|
|
"protocol": "grpc",
|
|
},
|
|
},
|
|
},
|
|
})
|
|
|
|
// create selector
|
|
se := selector.NewSelector(
|
|
selector.Registry(r),
|
|
)
|
|
|
|
// create client
|
|
c := NewClient(
|
|
client.Registry(r),
|
|
client.Selector(se),
|
|
)
|
|
|
|
testMethods := []string{
|
|
"/helloworld.Greeter/SayHello",
|
|
"Greeter.SayHello",
|
|
}
|
|
|
|
for _, method := range testMethods {
|
|
req := c.NewRequest("helloworld", method, &pb.HelloRequest{
|
|
Name: "John",
|
|
})
|
|
|
|
rsp := pb.HelloReply{}
|
|
|
|
err = c.Call(context.TODO(), req, &rsp)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
if rsp.Message != "Hello John" {
|
|
t.Fatalf("Got unexpected response %v", rsp.Message)
|
|
}
|
|
}
|
|
|
|
req := c.NewRequest("helloworld", "/helloworld.Greeter/SayHello", &pb.HelloRequest{
|
|
Name: "Error",
|
|
})
|
|
|
|
rsp := pb.HelloReply{}
|
|
|
|
err = c.Call(context.TODO(), req, &rsp)
|
|
if err == nil {
|
|
t.Fatal("nil error received")
|
|
}
|
|
|
|
verr, ok := err.(*errors.Error)
|
|
if !ok {
|
|
t.Fatalf("invalid error received %#+v\n", err)
|
|
}
|
|
|
|
if verr.Code != 99 && verr.Id != "1" && verr.Detail != "detail" {
|
|
t.Fatalf("invalid error received %#+v\n", verr)
|
|
}
|
|
|
|
}
|