Produce an error when unmarshaling text protos if a oneof field is set more than once.
PiperOrigin-RevId: 137859856
diff --git a/proto/text_parser.go b/proto/text_parser.go
index 4fd0531..a6bab2f 100644
--- a/proto/text_parser.go
+++ b/proto/text_parser.go
@@ -592,7 +592,11 @@
props = oop.Prop
nv := reflect.New(oop.Type.Elem())
dst = nv.Elem().Field(0)
- sv.Field(oop.Field).Set(nv)
+ field := sv.Field(oop.Field)
+ if !field.IsNil() {
+ return p.errorf("oneof field '%s' is already set", name)
+ }
+ field.Set(nv)
}
if !dst.IsValid() {
return p.errorf("unknown field name %q in %v", name, st)
diff --git a/proto/text_parser_test.go b/proto/text_parser_test.go
index b26500b..d757ab3 100644
--- a/proto/text_parser_test.go
+++ b/proto/text_parser_test.go
@@ -635,6 +635,17 @@
if !Equal(m, want) {
t.Errorf("\n got %v\nwant %v", m, want)
}
+
+ const inOverwrite = `name:"Shrek" number:42`
+ m = new(Communique)
+ testErr := "line 1.13: oneof field 'number' is already set"
+ if err := UnmarshalText(inOverwrite, m); err == nil {
+ t.Errorf("TestOneofParsing: Didn't get expected error: %v", testErr)
+ } else if err.Error() != testErr {
+ t.Errorf("TestOneofParsing: Incorrect error.\nHave: %v\nWant: %v",
+ err.Error(), testErr)
+ }
+
}
var benchInput string