From cb4713171f8caace9678ce41383d014130c9bd47 Mon Sep 17 00:00:00 2001 From: Cody Oss Date: Mon, 15 Apr 2024 13:33:04 -0500 Subject: [PATCH] fix(rpcreplay): properly unmarshal dynamic message Fixes: #9773 --- rpcreplay/rpcreplay.go | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/rpcreplay/rpcreplay.go b/rpcreplay/rpcreplay.go index 5cf33939cb61..9521460cf5e0 100644 --- a/rpcreplay/rpcreplay.go +++ b/rpcreplay/rpcreplay.go @@ -726,14 +726,18 @@ func readEntry(r io.Reader) (*entry, error) { var msg message if pe.Message != nil { if pe.IsError { - var s *spb.Status + s := &spb.Status{} err := anypb.UnmarshalTo(pe.Message, s, proto.UnmarshalOptions{AllowPartial: true, DiscardUnknown: true}) if err != nil { return nil, err } msg.err = status.ErrorProto(s) } else { - msg.msg = pe.Message.ProtoReflect().Interface() + m, err := anypb.UnmarshalNew(pe.Message, proto.UnmarshalOptions{AllowPartial: true, DiscardUnknown: true}) + if err != nil { + return nil, err + } + msg.msg = m } } else if pe.IsError { msg.err = io.EOF