|
1 | 1 | package proxy |
2 | 2 |
|
3 | 3 | import ( |
| 4 | + "context" |
4 | 5 | "fmt" |
5 | 6 | "io" |
| 7 | + "net" |
6 | 8 | "net/http" |
| 9 | + "sync" |
7 | 10 | "testing" |
8 | 11 | "time" |
9 | 12 |
|
| 13 | + "github.com/gogo/status" |
10 | 14 | "github.com/stretchr/testify/assert" |
11 | 15 | "go.temporal.io/api/workflowservice/v1" |
12 | 16 | "go.temporal.io/server/api/adminservice/v1" |
13 | 17 | "go.temporal.io/server/common/log" |
| 18 | + "go.temporal.io/server/common/log/tag" |
| 19 | + "google.golang.org/grpc" |
| 20 | + "google.golang.org/grpc/codes" |
| 21 | + "google.golang.org/grpc/credentials/insecure" |
14 | 22 |
|
15 | 23 | "github.com/temporalio/s2s-proxy/config" |
16 | 24 | ) |
|
52 | 60 | logger = log.NewTestLogger() |
53 | 61 | ) |
54 | 62 |
|
| 63 | +type hangupAdminServer struct { |
| 64 | + adminservice.UnimplementedAdminServiceServer |
| 65 | +} |
| 66 | + |
| 67 | +func (s *hangupAdminServer) StreamWorkflowReplicationMessages(server adminservice.AdminService_StreamWorkflowReplicationMessagesServer) error { |
| 68 | + go func() { |
| 69 | + for { |
| 70 | + _, err := server.Recv() |
| 71 | + if status.Code(err) == codes.Canceled { |
| 72 | + logger.Info("Client closed") |
| 73 | + return |
| 74 | + } else if err != nil { |
| 75 | + logger.Info("Got a message with error", tag.Error(err)) |
| 76 | + } |
| 77 | + } |
| 78 | + }() |
| 79 | + wg := sync.WaitGroup{} |
| 80 | + wg.Add(1) |
| 81 | + go func() { |
| 82 | + err := server.Send(&adminservice.StreamWorkflowReplicationMessagesResponse{}) |
| 83 | + if err != nil { |
| 84 | + logger.Info("Got a message with error", tag.Error(err)) |
| 85 | + } |
| 86 | + err = server.Send(&adminservice.StreamWorkflowReplicationMessagesResponse{}) |
| 87 | + if err != nil { |
| 88 | + logger.Info("Got a message with error", tag.Error(err)) |
| 89 | + } |
| 90 | + wg.Done() |
| 91 | + }() |
| 92 | + wg.Wait() |
| 93 | + return nil |
| 94 | +} |
| 95 | + |
| 96 | +func TestEOFFromServer(t *testing.T) { |
| 97 | + adminHandler := &hangupAdminServer{} |
| 98 | + grpcHost := grpc.NewServer() |
| 99 | + adminservice.RegisterAdminServiceServer(grpcHost, adminHandler) |
| 100 | + listener, _ := net.Listen("tcp", "localhost:8566") |
| 101 | + go func() { |
| 102 | + _ = grpcHost.Serve(listener) |
| 103 | + }() |
| 104 | + time.Sleep(10 * time.Millisecond) |
| 105 | + client, err := grpc.NewClient("localhost:8566", grpc.WithTransportCredentials(insecure.NewCredentials())) |
| 106 | + assert.NoError(t, err) |
| 107 | + adminServiceClient := adminservice.NewAdminServiceClient(client) |
| 108 | + clientCtx, cancelCtx := context.WithCancel(t.Context()) |
| 109 | + streamServer, err := adminServiceClient.StreamWorkflowReplicationMessages(clientCtx) |
| 110 | + assert.NoError(t, err) |
| 111 | + err = streamServer.Send(&adminservice.StreamWorkflowReplicationMessagesRequest{}) |
| 112 | + assert.NoError(t, err) |
| 113 | + _, err = streamServer.Recv() |
| 114 | + assert.NoError(t, err) |
| 115 | + _, err = streamServer.Recv() |
| 116 | + assert.NoError(t, err) |
| 117 | + _, err = streamServer.Recv() |
| 118 | + assert.True(t, err == io.EOF, "Should have thrown io.EOF, but got %v instead! Error() returned: %v", err, err.Error()) |
| 119 | + grpcHost.Stop() |
| 120 | + _ = listener.Close() |
| 121 | + cancelCtx() |
| 122 | +} |
| 123 | + |
55 | 124 | func TestWiringWithEchoService(t *testing.T) { |
56 | 125 | echoServer := newEchoServer(echoServerInfo, echoClientInfo, "EchoServer", logger, nil) |
57 | 126 | echoClient := newEchoServer(echoClientInfo, echoServerInfo, "EchoClient", logger, nil) |
|
0 commit comments