You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
238 lines
6.5 KiB
238 lines
6.5 KiB
package testproto
|
|
|
|
import (
|
|
context "context"
|
|
"errors"
|
|
"fmt"
|
|
stdhttp "net/http"
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/go-kratos/kratos/v2/encoding"
|
|
"github.com/go-kratos/kratos/v2/metadata"
|
|
mmd "github.com/go-kratos/kratos/v2/middleware/metadata"
|
|
"github.com/go-kratos/kratos/v2/transport"
|
|
"github.com/go-kratos/kratos/v2/transport/grpc"
|
|
"github.com/go-kratos/kratos/v2/transport/http"
|
|
|
|
_struct "github.com/golang/protobuf/ptypes/struct"
|
|
stdgrpc "google.golang.org/grpc"
|
|
grpcmd "google.golang.org/grpc/metadata"
|
|
)
|
|
|
|
var md = metadata.Metadata{"x-md-global-test": "test_value"}
|
|
|
|
type echoService struct {
|
|
UnimplementedEchoServiceServer
|
|
}
|
|
|
|
func (s *echoService) Echo(ctx context.Context, m *SimpleMessage) (*SimpleMessage, error) {
|
|
md, _ := metadata.FromServerContext(ctx)
|
|
if v := md.Get("x-md-global-test"); v != "test_value" {
|
|
return nil, errors.New("md not match" + v)
|
|
}
|
|
|
|
if tr, ok := transport.FromServerContext(ctx); ok {
|
|
tr.ReplyHeader().Set("2233", "niang")
|
|
}
|
|
return m, nil
|
|
}
|
|
|
|
func (s *echoService) EchoBody(ctx context.Context, m *SimpleMessage) (*SimpleMessage, error) {
|
|
return m, nil
|
|
}
|
|
|
|
func (s *echoService) EchoDelete(ctx context.Context, m *SimpleMessage) (*SimpleMessage, error) {
|
|
return m, nil
|
|
}
|
|
|
|
func (s *echoService) EchoPatch(ctx context.Context, m *DynamicMessageUpdate) (*DynamicMessageUpdate, error) {
|
|
return m, nil
|
|
}
|
|
|
|
func (s *echoService) EchoResponseBody(ctx context.Context, m *DynamicMessageUpdate) (*DynamicMessageUpdate, error) {
|
|
return m, nil
|
|
}
|
|
|
|
type echoClient struct {
|
|
client EchoServiceHTTPClient
|
|
}
|
|
|
|
// post: /v1/example/echo/{id}
|
|
func (c *echoClient) Echo(ctx context.Context, in *SimpleMessage, opts ...http.CallOption) (out *SimpleMessage, err error) {
|
|
return c.client.Echo(ctx, in, opts...)
|
|
}
|
|
|
|
// post: /v1/example/echo_body
|
|
func (c *echoClient) EchoBody(ctx context.Context, in *SimpleMessage) (out *SimpleMessage, err error) {
|
|
return c.client.EchoBody(ctx, in)
|
|
}
|
|
|
|
// delete: /v1/example/echo_delete/{id}/{num}
|
|
func (c *echoClient) EchoDelete(ctx context.Context, in *SimpleMessage) (out *SimpleMessage, err error) {
|
|
return c.client.EchoDelete(ctx, in)
|
|
}
|
|
|
|
// patch: /v1/example/echo_patch
|
|
func (c *echoClient) EchoPatch(ctx context.Context, in *DynamicMessageUpdate) (out *DynamicMessageUpdate, err error) {
|
|
return c.client.EchoPatch(ctx, in)
|
|
}
|
|
|
|
// post: /v1/example/echo_response_body
|
|
func (c *echoClient) EchoResponseBody(ctx context.Context, in *DynamicMessageUpdate) (out *DynamicMessageUpdate, err error) {
|
|
return c.client.EchoResponseBody(ctx, in)
|
|
}
|
|
|
|
func TestJSON(t *testing.T) {
|
|
in := &SimpleMessage{Id: "test_id", Num: 100}
|
|
out := &SimpleMessage{}
|
|
codec := encoding.GetCodec("json")
|
|
data, err := codec.Marshal(in)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
if err := codec.Unmarshal(data, out); err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
// body
|
|
in2 := &DynamicMessageUpdate{Body: &DynamicMessage{
|
|
ValueField: &_struct.Value{Kind: &_struct.Value_StringValue{StringValue: "test"}},
|
|
}}
|
|
out2 := &DynamicMessageUpdate{}
|
|
data, err = codec.Marshal(&in2.Body)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
if err := codec.Unmarshal(data, &out2.Body); err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
}
|
|
|
|
func TestEchoHTTPServer(t *testing.T) {
|
|
echo := &echoService{}
|
|
ctx := context.Background()
|
|
srv := http.NewServer(
|
|
http.Address(":2333"),
|
|
http.Middleware(mmd.Server()),
|
|
)
|
|
RegisterEchoServiceHTTPServer(srv, echo)
|
|
go func() {
|
|
if err := srv.Start(ctx); err != nil {
|
|
panic(err)
|
|
}
|
|
}()
|
|
time.Sleep(time.Second)
|
|
testEchoHTTPClient(t, fmt.Sprintf("127.0.0.1:2333"))
|
|
srv.Stop(ctx)
|
|
}
|
|
|
|
func testEchoHTTPClient(t *testing.T, addr string) {
|
|
var (
|
|
err error
|
|
in = &SimpleMessage{Id: "test_id", Num: 100, Ext: &SimpleMessage_No{
|
|
No: &Embedded{Mark: &Embedded_Note{Note: "2233"}},
|
|
}}
|
|
out = &SimpleMessage{}
|
|
)
|
|
check := func(name string, in, out *SimpleMessage) {
|
|
if in.Id != out.Id || in.Num != out.Num {
|
|
t.Errorf("[%s] expected %v got %v", name, in, out)
|
|
}
|
|
}
|
|
cc, _ := http.NewClient(context.Background(),
|
|
http.WithEndpoint(addr),
|
|
http.WithMiddleware(mmd.Client()),
|
|
)
|
|
|
|
cli := &echoClient{client: NewEchoServiceHTTPClient(cc)}
|
|
|
|
ctx := context.Background()
|
|
ctx = metadata.NewClientContext(ctx, md)
|
|
var header stdhttp.Header
|
|
if out, err = cli.Echo(ctx, in, http.Header(&header)); err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
if header.Get("2233") != "niang" {
|
|
t.Errorf("[echo] header key 2233 expected niang got %v", header.Get("2233"))
|
|
}
|
|
check("echo", &SimpleMessage{Id: "test_id", Num: 100, Ext: &SimpleMessage_No{No: &Embedded{Mark: &Embedded_Note{Note: "2233"}}}}, out)
|
|
|
|
if out, err = cli.EchoBody(context.Background(), in); err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
check("echoBody", in, out)
|
|
|
|
if out, err = cli.EchoDelete(context.Background(), in); err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
check("echoDelete", in, out)
|
|
|
|
var (
|
|
din = &DynamicMessageUpdate{Body: &DynamicMessage{
|
|
ValueField: &_struct.Value{Kind: &_struct.Value_StringValue{StringValue: "test"}},
|
|
}}
|
|
dout *DynamicMessageUpdate
|
|
)
|
|
if dout, err = cli.EchoResponseBody(context.Background(), din); err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
if din.Body.ValueField.GetStringValue() != dout.Body.ValueField.GetStringValue() {
|
|
t.Fatalf("EchoResponseBody expected %s got %s", din, dout)
|
|
}
|
|
if dout, err = cli.EchoPatch(context.Background(), din); err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
if dout.Body == nil {
|
|
panic("dout.body is nil")
|
|
}
|
|
if din.Body.ValueField.GetStringValue() != dout.Body.ValueField.GetStringValue() {
|
|
t.Fatalf("EchoPatch expected %s got %s", din, dout)
|
|
}
|
|
fmt.Println("echo test success!")
|
|
}
|
|
|
|
func TestEchoGRPCServer(t *testing.T) {
|
|
echo := &echoService{}
|
|
ctx := context.Background()
|
|
srv := grpc.NewServer(
|
|
grpc.Address(":2233"),
|
|
grpc.Middleware(mmd.Server()),
|
|
)
|
|
RegisterEchoServiceServer(srv, echo)
|
|
go func() {
|
|
if err := srv.Start(ctx); err != nil {
|
|
panic(err)
|
|
}
|
|
}()
|
|
time.Sleep(time.Second)
|
|
testEchoGRPCClient(t, fmt.Sprintf("127.0.0.1:2233"))
|
|
srv.Stop(ctx)
|
|
}
|
|
|
|
func testEchoGRPCClient(t *testing.T, addr string) {
|
|
cc, err := grpc.DialInsecure(
|
|
context.Background(),
|
|
grpc.WithEndpoint(addr),
|
|
grpc.WithMiddleware(mmd.Client()),
|
|
)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
var (
|
|
in = &SimpleMessage{Id: "test_id", Num: 100}
|
|
out = &SimpleMessage{}
|
|
)
|
|
client := NewEchoServiceClient(cc)
|
|
ctx := context.Background()
|
|
ctx = metadata.NewClientContext(ctx, md)
|
|
var md grpcmd.MD
|
|
if out, err = client.Echo(ctx, in, stdgrpc.Header(&md)); err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
if len(md.Get("2233")) != 1 || md.Get("2233")[0] != "niang" {
|
|
t.Errorf("[echo] header key 2233 expected niang got %v", md.Get("2233"))
|
|
}
|
|
if in.Id != out.Id || in.Num != out.Num {
|
|
t.Errorf("expected %v got %v", in, out)
|
|
}
|
|
}
|
|
|