Skip to content

Commit

Permalink
Merge pull request #5 from smira/one2many-2
Browse files Browse the repository at this point in the history
More unary one-2-many tests, error propagation.
  • Loading branch information
smira authored Nov 22, 2019
2 parents 1f0cb46 + 436b338 commit 817b035
Show file tree
Hide file tree
Showing 3 changed files with 180 additions and 38 deletions.
61 changes: 56 additions & 5 deletions proxy/handler_multi_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -73,7 +73,7 @@ func (s *assertingMultiService) Ping(ctx context.Context, ping *pb.PingRequest)
}, nil
}

func (s *assertingMultiService) PingError(ctx context.Context, ping *pb.PingRequest) (*pb.Empty, error) {
func (s *assertingMultiService) PingError(ctx context.Context, ping *pb.PingRequest) (*pb.EmptyReply, error) {
return nil, status.Errorf(codes.FailedPrecondition, "Userspace error.")
}

Expand Down Expand Up @@ -168,10 +168,14 @@ func (b *assertingBackend) AppendInfo(resp []byte) ([]byte, error) {
}

func (b *assertingBackend) BuildError(err error) ([]byte, error) {
return proto.Marshal(&pb.ResponseMetadataPrepender{
Metadata: &pb.ResponseMetadata{
Hostname: fmt.Sprintf("server%d", b.i),
UpstreamError: err.Error(),
return proto.Marshal(&pb.EmptyReply{
Response: []*pb.EmptyResponse{
{
Metadata: &pb.ResponseMetadata{
Hostname: fmt.Sprintf("server%d", b.i),
UpstreamError: err.Error(),
},
},
},
})
}
Expand Down Expand Up @@ -216,6 +220,53 @@ func (s *MultiServiceSuite) TestPingEmptyCarriesClientMetadata() {
s.Require().Empty(expectedUpstreams)
}

func (s *MultiServiceSuite) TestPingEmpty_StressTest() {
for i := 0; i < 50; i++ {
s.TestPingEmptyCarriesClientMetadata()
}
}

func (s *MultiServiceSuite) TestPingCarriesServerHeadersAndTrailers() {
headerMd := make(metadata.MD)
trailerMd := make(metadata.MD)
// This is an awkward calling convention... but meh.
out, err := s.testClient.Ping(s.ctx, &pb.PingRequest{Value: "foo"}, grpc.Header(&headerMd), grpc.Trailer(&trailerMd))
require.NoError(s.T(), err, "Ping should succeed without errors")

s.Require().Len(out.Response, numUpstreams)
for _, resp := range out.Response {
s.Require().Equal("foo", resp.Value)
s.Require().EqualValues(42, resp.Counter)

// equal metadata set by proxy and server
s.Require().Equal(resp.Metadata.Hostname, resp.Server)
}

assert.Contains(s.T(), headerMd, serverHeaderMdKey, "server response headers must contain server data")
assert.Len(s.T(), trailerMd, 1, "server response trailers must contain server data")
}

func (s *MultiServiceSuite) TestPingErrorPropagatesAppError() {
out, err := s.testClient.PingError(s.ctx, &pb.PingRequest{Value: "foo"})
s.Require().NoError(err, "error should be encapsulated in the response")

s.Require().Len(out.Response, numUpstreams)
for _, resp := range out.Response {
s.Require().NotEmpty(resp.Metadata.UpstreamError)
s.Require().NotEmpty(resp.Metadata.Hostname)
s.Assert().Equal("rpc error: code = FailedPrecondition desc = Userspace error.", resp.Metadata.UpstreamError)
}
}

func (s *MultiServiceSuite) TestDirectorErrorIsPropagated() {
// See SetupSuite where the StreamDirector has a special case.
ctx := metadata.NewOutgoingContext(s.ctx, metadata.Pairs(rejectingMdKey, "true"))
_, err := s.testClient.Ping(ctx, &pb.PingRequest{Value: "foo"})
require.Error(s.T(), err, "Director should reject this RPC")
assert.Equal(s.T(), codes.PermissionDenied, status.Code(err))
assert.Equal(s.T(), "testing rejection", status.Convert(err).Message())
}

func (s *MultiServiceSuite) SetupTest() {
s.ctx, s.ctxCancel = context.WithTimeout(context.TODO(), 120*time.Second)
}
Expand Down
147 changes: 115 additions & 32 deletions testservice/test.pb.go

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

10 changes: 9 additions & 1 deletion testservice/test.proto
Original file line number Diff line number Diff line change
Expand Up @@ -47,12 +47,20 @@ message MultiPingReply {
repeated MultiPingResponse response = 1;
}

message EmptyReply {
repeated EmptyResponse response = 1;
}

message EmptyResponse {
ResponseMetadata metadata = 99;
}

service MultiService {
rpc PingEmpty(Empty) returns (MultiPingReply) {}

rpc Ping(PingRequest) returns (MultiPingReply) {}

rpc PingError(PingRequest) returns (Empty) {}
rpc PingError(PingRequest) returns (EmptyReply) {}

rpc PingList(PingRequest) returns (stream MultiPingReply) {}

Expand Down

0 comments on commit 817b035

Please sign in to comment.