aboutsummaryrefslogtreecommitdiff
path: root/internal/impl/message_reflect_test.go
diff options
context:
space:
mode:
Diffstat (limited to 'internal/impl/message_reflect_test.go')
-rw-r--r--internal/impl/message_reflect_test.go1606
1 files changed, 0 insertions, 1606 deletions
diff --git a/internal/impl/message_reflect_test.go b/internal/impl/message_reflect_test.go
deleted file mode 100644
index 96c7e1b6..00000000
--- a/internal/impl/message_reflect_test.go
+++ /dev/null
@@ -1,1606 +0,0 @@
-// Copyright 2018 The Go Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style
-// license that can be found in the LICENSE file.
-
-package impl_test
-
-import (
- "fmt"
- "math"
- "reflect"
- "runtime"
- "strings"
- "sync"
- "testing"
-
- cmp "github.com/google/go-cmp/cmp"
- cmpopts "github.com/google/go-cmp/cmp/cmpopts"
-
- "google.golang.org/protobuf/encoding/prototext"
- pimpl "google.golang.org/protobuf/internal/impl"
- "google.golang.org/protobuf/proto"
- pdesc "google.golang.org/protobuf/reflect/protodesc"
- pref "google.golang.org/protobuf/reflect/protoreflect"
- "google.golang.org/protobuf/reflect/protoregistry"
- "google.golang.org/protobuf/testing/protopack"
-
- proto2_20180125 "google.golang.org/protobuf/internal/testprotos/legacy/proto2_20180125_92554152"
- testpb "google.golang.org/protobuf/internal/testprotos/test"
- "google.golang.org/protobuf/types/descriptorpb"
-)
-
-// List of test operations to perform on messages, lists, or maps.
-type (
- messageOp interface{ isMessageOp() }
- messageOps []messageOp
-
- listOp interface{ isListOp() }
- listOps []listOp
-
- mapOp interface{ isMapOp() }
- mapOps []mapOp
-)
-
-// Test operations performed on a message.
-type (
- // check that the message contents match
- equalMessage struct{ pref.Message }
- // check presence for specific fields in the message
- hasFields map[pref.FieldNumber]bool
- // check that specific message fields match
- getFields map[pref.FieldNumber]pref.Value
- // set specific message fields
- setFields map[pref.FieldNumber]pref.Value
- // clear specific fields in the message
- clearFields []pref.FieldNumber
- // check for the presence of specific oneof member fields.
- whichOneofs map[pref.Name]pref.FieldNumber
- // apply messageOps on each specified message field
- messageFields map[pref.FieldNumber]messageOps
- messageFieldsMutable map[pref.FieldNumber]messageOps
- // apply listOps on each specified list field
- listFields map[pref.FieldNumber]listOps
- listFieldsMutable map[pref.FieldNumber]listOps
- // apply mapOps on each specified map fields
- mapFields map[pref.FieldNumber]mapOps
- mapFieldsMutable map[pref.FieldNumber]mapOps
- // range through all fields and check that they match
- rangeFields map[pref.FieldNumber]pref.Value
-)
-
-func (equalMessage) isMessageOp() {}
-func (hasFields) isMessageOp() {}
-func (getFields) isMessageOp() {}
-func (setFields) isMessageOp() {}
-func (clearFields) isMessageOp() {}
-func (whichOneofs) isMessageOp() {}
-func (messageFields) isMessageOp() {}
-func (messageFieldsMutable) isMessageOp() {}
-func (listFields) isMessageOp() {}
-func (listFieldsMutable) isMessageOp() {}
-func (mapFields) isMessageOp() {}
-func (mapFieldsMutable) isMessageOp() {}
-func (rangeFields) isMessageOp() {}
-
-// Test operations performed on a list.
-type (
- // check that the list contents match
- equalList struct{ pref.List }
- // check that list length matches
- lenList int
- // check that specific list entries match
- getList map[int]pref.Value
- // set specific list entries
- setList map[int]pref.Value
- // append entries to the list
- appendList []pref.Value
- // apply messageOps on a newly appended message
- appendMessageList messageOps
- // truncate the list to the specified length
- truncList int
-)
-
-func (equalList) isListOp() {}
-func (lenList) isListOp() {}
-func (getList) isListOp() {}
-func (setList) isListOp() {}
-func (appendList) isListOp() {}
-func (appendMessageList) isListOp() {}
-func (truncList) isListOp() {}
-
-// Test operations performed on a map.
-type (
- // check that the map contents match
- equalMap struct{ pref.Map }
- // check that map length matches
- lenMap int
- // check presence for specific entries in the map
- hasMap map[interface{}]bool
- // check that specific map entries match
- getMap map[interface{}]pref.Value
- // set specific map entries
- setMap map[interface{}]pref.Value
- // clear specific entries in the map
- clearMap []interface{}
- // apply messageOps on each specified message entry
- messageMap map[interface{}]messageOps
- // range through all entries and check that they match
- rangeMap map[interface{}]pref.Value
-)
-
-func (equalMap) isMapOp() {}
-func (lenMap) isMapOp() {}
-func (hasMap) isMapOp() {}
-func (getMap) isMapOp() {}
-func (setMap) isMapOp() {}
-func (clearMap) isMapOp() {}
-func (messageMap) isMapOp() {}
-func (rangeMap) isMapOp() {}
-
-type ScalarProto2 struct {
- Bool *bool `protobuf:"1"`
- Int32 *int32 `protobuf:"2"`
- Int64 *int64 `protobuf:"3"`
- Uint32 *uint32 `protobuf:"4"`
- Uint64 *uint64 `protobuf:"5"`
- Float32 *float32 `protobuf:"6"`
- Float64 *float64 `protobuf:"7"`
- String *string `protobuf:"8"`
- StringA []byte `protobuf:"9"`
- Bytes []byte `protobuf:"10"`
- BytesA *string `protobuf:"11"`
-
- MyBool *MyBool `protobuf:"12"`
- MyInt32 *MyInt32 `protobuf:"13"`
- MyInt64 *MyInt64 `protobuf:"14"`
- MyUint32 *MyUint32 `protobuf:"15"`
- MyUint64 *MyUint64 `protobuf:"16"`
- MyFloat32 *MyFloat32 `protobuf:"17"`
- MyFloat64 *MyFloat64 `protobuf:"18"`
- MyString *MyString `protobuf:"19"`
- MyStringA MyBytes `protobuf:"20"`
- MyBytes MyBytes `protobuf:"21"`
- MyBytesA *MyString `protobuf:"22"`
-}
-
-func mustMakeEnumDesc(path string, syntax pref.Syntax, enumDesc string) pref.EnumDescriptor {
- s := fmt.Sprintf(`name:%q syntax:%q enum_type:[{%s}]`, path, syntax, enumDesc)
- pb := new(descriptorpb.FileDescriptorProto)
- if err := prototext.Unmarshal([]byte(s), pb); err != nil {
- panic(err)
- }
- fd, err := pdesc.NewFile(pb, nil)
- if err != nil {
- panic(err)
- }
- return fd.Enums().Get(0)
-}
-
-func mustMakeMessageDesc(path string, syntax pref.Syntax, fileDesc, msgDesc string, r pdesc.Resolver) pref.MessageDescriptor {
- s := fmt.Sprintf(`name:%q syntax:%q %s message_type:[{%s}]`, path, syntax, fileDesc, msgDesc)
- pb := new(descriptorpb.FileDescriptorProto)
- if err := prototext.Unmarshal([]byte(s), pb); err != nil {
- panic(err)
- }
- fd, err := pdesc.NewFile(pb, r)
- if err != nil {
- panic(err)
- }
- return fd.Messages().Get(0)
-}
-
-var V = pref.ValueOf
-var VE = func(n pref.EnumNumber) pref.Value { return V(n) }
-
-type (
- MyBool bool
- MyInt32 int32
- MyInt64 int64
- MyUint32 uint32
- MyUint64 uint64
- MyFloat32 float32
- MyFloat64 float64
- MyString string
- MyBytes []byte
-
- ListStrings []MyString
- ListBytes []MyBytes
-
- MapStrings map[MyString]MyString
- MapBytes map[MyString]MyBytes
-)
-
-var scalarProto2Type = pimpl.MessageInfo{GoReflectType: reflect.TypeOf(new(ScalarProto2)), Desc: mustMakeMessageDesc("scalar2.proto", pref.Proto2, "", `
- name: "ScalarProto2"
- field: [
- {name:"f1" number:1 label:LABEL_OPTIONAL type:TYPE_BOOL default_value:"true"},
- {name:"f2" number:2 label:LABEL_OPTIONAL type:TYPE_INT32 default_value:"2"},
- {name:"f3" number:3 label:LABEL_OPTIONAL type:TYPE_INT64 default_value:"3"},
- {name:"f4" number:4 label:LABEL_OPTIONAL type:TYPE_UINT32 default_value:"4"},
- {name:"f5" number:5 label:LABEL_OPTIONAL type:TYPE_UINT64 default_value:"5"},
- {name:"f6" number:6 label:LABEL_OPTIONAL type:TYPE_FLOAT default_value:"6"},
- {name:"f7" number:7 label:LABEL_OPTIONAL type:TYPE_DOUBLE default_value:"7"},
- {name:"f8" number:8 label:LABEL_OPTIONAL type:TYPE_STRING default_value:"8"},
- {name:"f9" number:9 label:LABEL_OPTIONAL type:TYPE_STRING default_value:"9"},
- {name:"f10" number:10 label:LABEL_OPTIONAL type:TYPE_BYTES default_value:"10"},
- {name:"f11" number:11 label:LABEL_OPTIONAL type:TYPE_BYTES default_value:"11"},
-
- {name:"f12" number:12 label:LABEL_OPTIONAL type:TYPE_BOOL default_value:"true"},
- {name:"f13" number:13 label:LABEL_OPTIONAL type:TYPE_INT32 default_value:"13"},
- {name:"f14" number:14 label:LABEL_OPTIONAL type:TYPE_INT64 default_value:"14"},
- {name:"f15" number:15 label:LABEL_OPTIONAL type:TYPE_UINT32 default_value:"15"},
- {name:"f16" number:16 label:LABEL_OPTIONAL type:TYPE_UINT64 default_value:"16"},
- {name:"f17" number:17 label:LABEL_OPTIONAL type:TYPE_FLOAT default_value:"17"},
- {name:"f18" number:18 label:LABEL_OPTIONAL type:TYPE_DOUBLE default_value:"18"},
- {name:"f19" number:19 label:LABEL_OPTIONAL type:TYPE_STRING default_value:"19"},
- {name:"f20" number:20 label:LABEL_OPTIONAL type:TYPE_STRING default_value:"20"},
- {name:"f21" number:21 label:LABEL_OPTIONAL type:TYPE_BYTES default_value:"21"},
- {name:"f22" number:22 label:LABEL_OPTIONAL type:TYPE_BYTES default_value:"22"}
- ]
- `, nil),
-}
-
-func (m *ScalarProto2) ProtoReflect() pref.Message { return scalarProto2Type.MessageOf(m) }
-
-func TestScalarProto2(t *testing.T) {
- testMessage(t, nil, new(ScalarProto2).ProtoReflect(), messageOps{
- hasFields{
- 1: false, 2: false, 3: false, 4: false, 5: false, 6: false, 7: false, 8: false, 9: false, 10: false, 11: false,
- 12: false, 13: false, 14: false, 15: false, 16: false, 17: false, 18: false, 19: false, 20: false, 21: false, 22: false,
- },
- getFields{
- 1: V(bool(true)), 2: V(int32(2)), 3: V(int64(3)), 4: V(uint32(4)), 5: V(uint64(5)), 6: V(float32(6)), 7: V(float64(7)), 8: V(string("8")), 9: V(string("9")), 10: V([]byte("10")), 11: V([]byte("11")),
- 12: V(bool(true)), 13: V(int32(13)), 14: V(int64(14)), 15: V(uint32(15)), 16: V(uint64(16)), 17: V(float32(17)), 18: V(float64(18)), 19: V(string("19")), 20: V(string("20")), 21: V([]byte("21")), 22: V([]byte("22")),
- },
- setFields{
- 1: V(bool(false)), 2: V(int32(0)), 3: V(int64(0)), 4: V(uint32(0)), 5: V(uint64(0)), 6: V(float32(0)), 7: V(float64(0)), 8: V(string("")), 9: V(string("")), 10: V([]byte(nil)), 11: V([]byte(nil)),
- 12: V(bool(false)), 13: V(int32(0)), 14: V(int64(0)), 15: V(uint32(0)), 16: V(uint64(0)), 17: V(float32(0)), 18: V(float64(0)), 19: V(string("")), 20: V(string("")), 21: V([]byte(nil)), 22: V([]byte(nil)),
- },
- hasFields{
- 1: true, 2: true, 3: true, 4: true, 5: true, 6: true, 7: true, 8: true, 9: true, 10: true, 11: true,
- 12: true, 13: true, 14: true, 15: true, 16: true, 17: true, 18: true, 19: true, 20: true, 21: true, 22: true,
- },
- equalMessage{(&ScalarProto2{
- new(bool), new(int32), new(int64), new(uint32), new(uint64), new(float32), new(float64), new(string), []byte{}, []byte{}, new(string),
- new(MyBool), new(MyInt32), new(MyInt64), new(MyUint32), new(MyUint64), new(MyFloat32), new(MyFloat64), new(MyString), MyBytes{}, MyBytes{}, new(MyString),
- }).ProtoReflect()},
- clearFields{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22},
- equalMessage{new(ScalarProto2).ProtoReflect()},
-
- // Setting a bytes field nil empty bytes should preserve presence.
- setFields{10: V([]byte(nil)), 11: V([]byte(nil)), 21: V([]byte(nil)), 22: V([]byte(nil))},
- getFields{10: V([]byte{}), 11: V([]byte(nil)), 21: V([]byte{}), 22: V([]byte(nil))},
- hasFields{10: true, 11: true, 21: true, 22: true},
- })
-
- // Test read-only operations on nil message.
- testMessage(t, nil, (*ScalarProto2)(nil).ProtoReflect(), messageOps{
- hasFields{
- 1: false, 2: false, 3: false, 4: false, 5: false, 6: false, 7: false, 8: false, 9: false, 10: false, 11: false,
- 12: false, 13: false, 14: false, 15: false, 16: false, 17: false, 18: false, 19: false, 20: false, 21: false, 22: false,
- },
- getFields{
- 1: V(bool(true)), 2: V(int32(2)), 3: V(int64(3)), 4: V(uint32(4)), 5: V(uint64(5)), 6: V(float32(6)), 7: V(float64(7)), 8: V(string("8")), 9: V(string("9")), 10: V([]byte("10")), 11: V([]byte("11")),
- 12: V(bool(true)), 13: V(int32(13)), 14: V(int64(14)), 15: V(uint32(15)), 16: V(uint64(16)), 17: V(float32(17)), 18: V(float64(18)), 19: V(string("19")), 20: V(string("20")), 21: V([]byte("21")), 22: V([]byte("22")),
- },
- })
-}
-
-type ScalarProto3 struct {
- Bool bool `protobuf:"1"`
- Int32 int32 `protobuf:"2"`
- Int64 int64 `protobuf:"3"`
- Uint32 uint32 `protobuf:"4"`
- Uint64 uint64 `protobuf:"5"`
- Float32 float32 `protobuf:"6"`
- Float64 float64 `protobuf:"7"`
- String string `protobuf:"8"`
- StringA []byte `protobuf:"9"`
- Bytes []byte `protobuf:"10"`
- BytesA string `protobuf:"11"`
-
- MyBool MyBool `protobuf:"12"`
- MyInt32 MyInt32 `protobuf:"13"`
- MyInt64 MyInt64 `protobuf:"14"`
- MyUint32 MyUint32 `protobuf:"15"`
- MyUint64 MyUint64 `protobuf:"16"`
- MyFloat32 MyFloat32 `protobuf:"17"`
- MyFloat64 MyFloat64 `protobuf:"18"`
- MyString MyString `protobuf:"19"`
- MyStringA MyBytes `protobuf:"20"`
- MyBytes MyBytes `protobuf:"21"`
- MyBytesA MyString `protobuf:"22"`
-}
-
-var scalarProto3Type = pimpl.MessageInfo{GoReflectType: reflect.TypeOf(new(ScalarProto3)), Desc: mustMakeMessageDesc("scalar3.proto", pref.Proto3, "", `
- name: "ScalarProto3"
- field: [
- {name:"f1" number:1 label:LABEL_OPTIONAL type:TYPE_BOOL},
- {name:"f2" number:2 label:LABEL_OPTIONAL type:TYPE_INT32},
- {name:"f3" number:3 label:LABEL_OPTIONAL type:TYPE_INT64},
- {name:"f4" number:4 label:LABEL_OPTIONAL type:TYPE_UINT32},
- {name:"f5" number:5 label:LABEL_OPTIONAL type:TYPE_UINT64},
- {name:"f6" number:6 label:LABEL_OPTIONAL type:TYPE_FLOAT},
- {name:"f7" number:7 label:LABEL_OPTIONAL type:TYPE_DOUBLE},
- {name:"f8" number:8 label:LABEL_OPTIONAL type:TYPE_STRING},
- {name:"f9" number:9 label:LABEL_OPTIONAL type:TYPE_STRING},
- {name:"f10" number:10 label:LABEL_OPTIONAL type:TYPE_BYTES},
- {name:"f11" number:11 label:LABEL_OPTIONAL type:TYPE_BYTES},
-
- {name:"f12" number:12 label:LABEL_OPTIONAL type:TYPE_BOOL},
- {name:"f13" number:13 label:LABEL_OPTIONAL type:TYPE_INT32},
- {name:"f14" number:14 label:LABEL_OPTIONAL type:TYPE_INT64},
- {name:"f15" number:15 label:LABEL_OPTIONAL type:TYPE_UINT32},
- {name:"f16" number:16 label:LABEL_OPTIONAL type:TYPE_UINT64},
- {name:"f17" number:17 label:LABEL_OPTIONAL type:TYPE_FLOAT},
- {name:"f18" number:18 label:LABEL_OPTIONAL type:TYPE_DOUBLE},
- {name:"f19" number:19 label:LABEL_OPTIONAL type:TYPE_STRING},
- {name:"f20" number:20 label:LABEL_OPTIONAL type:TYPE_STRING},
- {name:"f21" number:21 label:LABEL_OPTIONAL type:TYPE_BYTES},
- {name:"f22" number:22 label:LABEL_OPTIONAL type:TYPE_BYTES}
- ]
- `, nil),
-}
-
-func (m *ScalarProto3) ProtoReflect() pref.Message { return scalarProto3Type.MessageOf(m) }
-
-func TestScalarProto3(t *testing.T) {
- testMessage(t, nil, new(ScalarProto3).ProtoReflect(), messageOps{
- hasFields{
- 1: false, 2: false, 3: false, 4: false, 5: false, 6: false, 7: false, 8: false, 9: false, 10: false, 11: false,
- 12: false, 13: false, 14: false, 15: false, 16: false, 17: false, 18: false, 19: false, 20: false, 21: false, 22: false,
- },
- getFields{
- 1: V(bool(false)), 2: V(int32(0)), 3: V(int64(0)), 4: V(uint32(0)), 5: V(uint64(0)), 6: V(float32(0)), 7: V(float64(0)), 8: V(string("")), 9: V(string("")), 10: V([]byte(nil)), 11: V([]byte(nil)),
- 12: V(bool(false)), 13: V(int32(0)), 14: V(int64(0)), 15: V(uint32(0)), 16: V(uint64(0)), 17: V(float32(0)), 18: V(float64(0)), 19: V(string("")), 20: V(string("")), 21: V([]byte(nil)), 22: V([]byte(nil)),
- },
- setFields{
- 1: V(bool(false)), 2: V(int32(0)), 3: V(int64(0)), 4: V(uint32(0)), 5: V(uint64(0)), 6: V(float32(0)), 7: V(float64(0)), 8: V(string("")), 9: V(string("")), 10: V([]byte(nil)), 11: V([]byte(nil)),
- 12: V(bool(false)), 13: V(int32(0)), 14: V(int64(0)), 15: V(uint32(0)), 16: V(uint64(0)), 17: V(float32(0)), 18: V(float64(0)), 19: V(string("")), 20: V(string("")), 21: V([]byte(nil)), 22: V([]byte(nil)),
- },
- hasFields{
- 1: false, 2: false, 3: false, 4: false, 5: false, 6: false, 7: false, 8: false, 9: false, 10: false, 11: false,
- 12: false, 13: false, 14: false, 15: false, 16: false, 17: false, 18: false, 19: false, 20: false, 21: false, 22: false,
- },
- equalMessage{new(ScalarProto3).ProtoReflect()},
- setFields{
- 1: V(bool(true)), 2: V(int32(2)), 3: V(int64(3)), 4: V(uint32(4)), 5: V(uint64(5)), 6: V(float32(6)), 7: V(float64(7)), 8: V(string("8")), 9: V(string("9")), 10: V([]byte("10")), 11: V([]byte("11")),
- 12: V(bool(true)), 13: V(int32(13)), 14: V(int64(14)), 15: V(uint32(15)), 16: V(uint64(16)), 17: V(float32(17)), 18: V(float64(18)), 19: V(string("19")), 20: V(string("20")), 21: V([]byte("21")), 22: V([]byte("22")),
- },
- hasFields{
- 1: true, 2: true, 3: true, 4: true, 5: true, 6: true, 7: true, 8: true, 9: true, 10: true, 11: true,
- 12: true, 13: true, 14: true, 15: true, 16: true, 17: true, 18: true, 19: true, 20: true, 21: true, 22: true,
- },
- equalMessage{(&ScalarProto3{
- true, 2, 3, 4, 5, 6, 7, "8", []byte("9"), []byte("10"), "11",
- true, 13, 14, 15, 16, 17, 18, "19", []byte("20"), []byte("21"), "22",
- }).ProtoReflect()},
- setFields{
- 2: V(int32(-2)), 3: V(int64(-3)), 6: V(float32(math.Inf(-1))), 7: V(float64(math.NaN())),
- },
- hasFields{
- 2: true, 3: true, 6: true, 7: true,
- },
- clearFields{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22},
- equalMessage{new(ScalarProto3).ProtoReflect()},
-
- // Verify that -0 triggers proper Has behavior.
- hasFields{6: false, 7: false},
- setFields{6: V(float32(math.Copysign(0, -1))), 7: V(float64(math.Copysign(0, -1)))},
- hasFields{6: true, 7: true},
-
- // Setting a bytes field to non-nil empty bytes should not preserve presence.
- setFields{10: V([]byte{}), 11: V([]byte{}), 21: V([]byte{}), 22: V([]byte{})},
- getFields{10: V([]byte(nil)), 11: V([]byte(nil)), 21: V([]byte(nil)), 22: V([]byte(nil))},
- hasFields{10: false, 11: false, 21: false, 22: false},
- })
-
- // Test read-only operations on nil message.
- testMessage(t, nil, (*ScalarProto3)(nil).ProtoReflect(), messageOps{
- hasFields{
- 1: false, 2: false, 3: false, 4: false, 5: false, 6: false, 7: false, 8: false, 9: false, 10: false, 11: false,
- 12: false, 13: false, 14: false, 15: false, 16: false, 17: false, 18: false, 19: false, 20: false, 21: false, 22: false,
- },
- getFields{
- 1: V(bool(false)), 2: V(int32(0)), 3: V(int64(0)), 4: V(uint32(0)), 5: V(uint64(0)), 6: V(float32(0)), 7: V(float64(0)), 8: V(string("")), 9: V(string("")), 10: V([]byte(nil)), 11: V([]byte(nil)),
- 12: V(bool(false)), 13: V(int32(0)), 14: V(int64(0)), 15: V(uint32(0)), 16: V(uint64(0)), 17: V(float32(0)), 18: V(float64(0)), 19: V(string("")), 20: V(string("")), 21: V([]byte(nil)), 22: V([]byte(nil)),
- },
- })
-}
-
-type ListScalars struct {
- Bools []bool `protobuf:"1"`
- Int32s []int32 `protobuf:"2"`
- Int64s []int64 `protobuf:"3"`
- Uint32s []uint32 `protobuf:"4"`
- Uint64s []uint64 `protobuf:"5"`
- Float32s []float32 `protobuf:"6"`
- Float64s []float64 `protobuf:"7"`
- Strings []string `protobuf:"8"`
- StringsA [][]byte `protobuf:"9"`
- Bytes [][]byte `protobuf:"10"`
- BytesA []string `protobuf:"11"`
-
- MyStrings1 []MyString `protobuf:"12"`
- MyStrings2 []MyBytes `protobuf:"13"`
- MyBytes1 []MyBytes `protobuf:"14"`
- MyBytes2 []MyString `protobuf:"15"`
-
- MyStrings3 ListStrings `protobuf:"16"`
- MyStrings4 ListBytes `protobuf:"17"`
- MyBytes3 ListBytes `protobuf:"18"`
- MyBytes4 ListStrings `protobuf:"19"`
-}
-
-var listScalarsType = pimpl.MessageInfo{GoReflectType: reflect.TypeOf(new(ListScalars)), Desc: mustMakeMessageDesc("list-scalars.proto", pref.Proto2, "", `
- name: "ListScalars"
- field: [
- {name:"f1" number:1 label:LABEL_REPEATED type:TYPE_BOOL},
- {name:"f2" number:2 label:LABEL_REPEATED type:TYPE_INT32},
- {name:"f3" number:3 label:LABEL_REPEATED type:TYPE_INT64},
- {name:"f4" number:4 label:LABEL_REPEATED type:TYPE_UINT32},
- {name:"f5" number:5 label:LABEL_REPEATED type:TYPE_UINT64},
- {name:"f6" number:6 label:LABEL_REPEATED type:TYPE_FLOAT},
- {name:"f7" number:7 label:LABEL_REPEATED type:TYPE_DOUBLE},
- {name:"f8" number:8 label:LABEL_REPEATED type:TYPE_STRING},
- {name:"f9" number:9 label:LABEL_REPEATED type:TYPE_STRING},
- {name:"f10" number:10 label:LABEL_REPEATED type:TYPE_BYTES},
- {name:"f11" number:11 label:LABEL_REPEATED type:TYPE_BYTES},
-
- {name:"f12" number:12 label:LABEL_REPEATED type:TYPE_STRING},
- {name:"f13" number:13 label:LABEL_REPEATED type:TYPE_STRING},
- {name:"f14" number:14 label:LABEL_REPEATED type:TYPE_BYTES},
- {name:"f15" number:15 label:LABEL_REPEATED type:TYPE_BYTES},
-
- {name:"f16" number:16 label:LABEL_REPEATED type:TYPE_STRING},
- {name:"f17" number:17 label:LABEL_REPEATED type:TYPE_STRING},
- {name:"f18" number:18 label:LABEL_REPEATED type:TYPE_BYTES},
- {name:"f19" number:19 label:LABEL_REPEATED type:TYPE_BYTES}
- ]
- `, nil),
-}
-
-func (m *ListScalars) ProtoReflect() pref.Message { return listScalarsType.MessageOf(m) }
-
-func TestListScalars(t *testing.T) {
- empty := new(ListScalars).ProtoReflect()
- want := (&ListScalars{
- Bools: []bool{true, false, true},
- Int32s: []int32{2, math.MinInt32, math.MaxInt32},
- Int64s: []int64{3, math.MinInt64, math.MaxInt64},
- Uint32s: []uint32{4, math.MaxUint32 / 2, math.MaxUint32},
- Uint64s: []uint64{5, math.MaxUint64 / 2, math.MaxUint64},
- Float32s: []float32{6, math.SmallestNonzeroFloat32, float32(math.NaN()), math.MaxFloat32},
- Float64s: []float64{7, math.SmallestNonzeroFloat64, float64(math.NaN()), math.MaxFloat64},
- Strings: []string{"8", "", "eight"},
- StringsA: [][]byte{[]byte("9"), nil, []byte("nine")},
- Bytes: [][]byte{[]byte("10"), nil, []byte("ten")},
- BytesA: []string{"11", "", "eleven"},
-
- MyStrings1: []MyString{"12", "", "twelve"},
- MyStrings2: []MyBytes{[]byte("13"), nil, []byte("thirteen")},
- MyBytes1: []MyBytes{[]byte("14"), nil, []byte("fourteen")},
- MyBytes2: []MyString{"15", "", "fifteen"},
-
- MyStrings3: ListStrings{"16", "", "sixteen"},
- MyStrings4: ListBytes{[]byte("17"), nil, []byte("seventeen")},
- MyBytes3: ListBytes{[]byte("18"), nil, []byte("eighteen")},
- MyBytes4: ListStrings{"19", "", "nineteen"},
- }).ProtoReflect()
-
- testMessage(t, nil, new(ListScalars).ProtoReflect(), messageOps{
- hasFields{1: false, 2: false, 3: false, 4: false, 5: false, 6: false, 7: false, 8: false, 9: false, 10: false, 11: false, 12: false, 13: false, 14: false, 15: false, 16: false, 17: false, 18: false, 19: false},
- getFields{1: getField(empty, 1), 3: getField(empty, 3), 5: getField(empty, 5), 7: getField(empty, 7), 9: getField(empty, 9), 11: getField(empty, 11), 13: getField(empty, 13), 15: getField(empty, 15), 17: getField(empty, 17), 19: getField(empty, 19)},
- setFields{1: getField(want, 1), 3: getField(want, 3), 5: getField(want, 5), 7: getField(want, 7), 9: getField(want, 9), 11: getField(want, 11), 13: getField(want, 13), 15: getField(want, 15), 17: getField(want, 17), 19: getField(want, 19)},
- listFieldsMutable{
- 2: {
- lenList(0),
- appendList{V(int32(2)), V(int32(math.MinInt32)), V(int32(math.MaxInt32))},
- getList{0: V(int32(2)), 1: V(int32(math.MinInt32)), 2: V(int32(math.MaxInt32))},
- equalList{getField(want, 2).List()},
- },
- 4: {
- appendList{V(uint32(0)), V(uint32(0)), V(uint32(0))},
- setList{0: V(uint32(4)), 1: V(uint32(math.MaxUint32 / 2)), 2: V(uint32(math.MaxUint32))},
- lenList(3),
- },
- 6: {
- appendList{V(float32(6)), V(float32(math.SmallestNonzeroFloat32)), V(float32(math.NaN())), V(float32(math.MaxFloat32))},
- equalList{getField(want, 6).List()},
- },
- 8: {
- appendList{V(""), V(""), V(""), V(""), V(""), V("")},
- lenList(6),
- setList{0: V("8"), 2: V("eight")},
- truncList(3),
- equalList{getField(want, 8).List()},
- },
- 10: {
- appendList{V([]byte(nil)), V([]byte(nil))},
- setList{0: V([]byte("10"))},
- appendList{V([]byte("wrong"))},
- setList{2: V([]byte("ten"))},
- equalList{getField(want, 10).List()},
- },
- 12: {
- appendList{V("12"), V("wrong"), V("twelve")},
- setList{1: V("")},
- equalList{getField(want, 12).List()},
- },
- 14: {
- appendList{V([]byte("14")), V([]byte(nil)), V([]byte("fourteen"))},
- equalList{getField(want, 14).List()},
- },
- 16: {
- appendList{V("16"), V(""), V("sixteen"), V("extra")},
- truncList(3),
- equalList{getField(want, 16).List()},
- },
- 18: {
- appendList{V([]byte("18")), V([]byte(nil)), V([]byte("eighteen"))},
- equalList{getField(want, 18).List()},
- },
- },
- hasFields{1: true, 2: true, 3: true, 4: true, 5: true, 6: true, 7: true, 8: true, 9: true, 10: true, 11: true, 12: true, 13: true, 14: true, 15: true, 16: true, 17: true, 18: true, 19: true},
- equalMessage{want},
- clearFields{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19},
- equalMessage{empty},
- })
-
- // Test read-only operations on nil message.
- testMessage(t, nil, (*ListScalars)(nil).ProtoReflect(), messageOps{
- hasFields{1: false, 2: false, 3: false, 4: false, 5: false, 6: false, 7: false, 8: false, 9: false, 10: false, 11: false, 12: false, 13: false, 14: false, 15: false, 16: false, 17: false, 18: false, 19: false},
- listFields{2: {lenList(0)}, 4: {lenList(0)}, 6: {lenList(0)}, 8: {lenList(0)}, 10: {lenList(0)}, 12: {lenList(0)}, 14: {lenList(0)}, 16: {lenList(0)}, 18: {lenList(0)}},
- })
-}
-
-type MapScalars struct {
- KeyBools map[bool]string `protobuf:"1"`
- KeyInt32s map[int32]string `protobuf:"2"`
- KeyInt64s map[int64]string `protobuf:"3"`
- KeyUint32s map[uint32]string `protobuf:"4"`
- KeyUint64s map[uint64]string `protobuf:"5"`
- KeyStrings map[string]string `protobuf:"6"`
-
- ValBools map[string]bool `protobuf:"7"`
- ValInt32s map[string]int32 `protobuf:"8"`
- ValInt64s map[string]int64 `protobuf:"9"`
- ValUint32s map[string]uint32 `protobuf:"10"`
- ValUint64s map[string]uint64 `protobuf:"11"`
- ValFloat32s map[string]float32 `protobuf:"12"`
- ValFloat64s map[string]float64 `protobuf:"13"`
- ValStrings map[string]string `protobuf:"14"`
- ValStringsA map[string][]byte `protobuf:"15"`
- ValBytes map[string][]byte `protobuf:"16"`
- ValBytesA map[string]string `protobuf:"17"`
-
- MyStrings1 map[MyString]MyString `protobuf:"18"`
- MyStrings2 map[MyString]MyBytes `protobuf:"19"`
- MyBytes1 map[MyString]MyBytes `protobuf:"20"`
- MyBytes2 map[MyString]MyString `protobuf:"21"`
-
- MyStrings3 MapStrings `protobuf:"22"`
- MyStrings4 MapBytes `protobuf:"23"`
- MyBytes3 MapBytes `protobuf:"24"`
- MyBytes4 MapStrings `protobuf:"25"`
-}
-
-var mapScalarsType = pimpl.MessageInfo{GoReflectType: reflect.TypeOf(new(MapScalars)), Desc: mustMakeMessageDesc("map-scalars.proto", pref.Proto2, "", `
- name: "MapScalars"
- field: [
- {name:"f1" number:1 label:LABEL_REPEATED type:TYPE_MESSAGE type_name:".MapScalars.F1Entry"},
- {name:"f2" number:2 label:LABEL_REPEATED type:TYPE_MESSAGE type_name:".MapScalars.F2Entry"},
- {name:"f3" number:3 label:LABEL_REPEATED type:TYPE_MESSAGE type_name:".MapScalars.F3Entry"},
- {name:"f4" number:4 label:LABEL_REPEATED type:TYPE_MESSAGE type_name:".MapScalars.F4Entry"},
- {name:"f5" number:5 label:LABEL_REPEATED type:TYPE_MESSAGE type_name:".MapScalars.F5Entry"},
- {name:"f6" number:6 label:LABEL_REPEATED type:TYPE_MESSAGE type_name:".MapScalars.F6Entry"},
-
- {name:"f7" number:7 label:LABEL_REPEATED type:TYPE_MESSAGE type_name:".MapScalars.F7Entry"},
- {name:"f8" number:8 label:LABEL_REPEATED type:TYPE_MESSAGE type_name:".MapScalars.F8Entry"},
- {name:"f9" number:9 label:LABEL_REPEATED type:TYPE_MESSAGE type_name:".MapScalars.F9Entry"},
- {name:"f10" number:10 label:LABEL_REPEATED type:TYPE_MESSAGE type_name:".MapScalars.F10Entry"},
- {name:"f11" number:11 label:LABEL_REPEATED type:TYPE_MESSAGE type_name:".MapScalars.F11Entry"},
- {name:"f12" number:12 label:LABEL_REPEATED type:TYPE_MESSAGE type_name:".MapScalars.F12Entry"},
- {name:"f13" number:13 label:LABEL_REPEATED type:TYPE_MESSAGE type_name:".MapScalars.F13Entry"},
- {name:"f14" number:14 label:LABEL_REPEATED type:TYPE_MESSAGE type_name:".MapScalars.F14Entry"},
- {name:"f15" number:15 label:LABEL_REPEATED type:TYPE_MESSAGE type_name:".MapScalars.F15Entry"},
- {name:"f16" number:16 label:LABEL_REPEATED type:TYPE_MESSAGE type_name:".MapScalars.F16Entry"},
- {name:"f17" number:17 label:LABEL_REPEATED type:TYPE_MESSAGE type_name:".MapScalars.F17Entry"},
-
- {name:"f18" number:18 label:LABEL_REPEATED type:TYPE_MESSAGE type_name:".MapScalars.F18Entry"},
- {name:"f19" number:19 label:LABEL_REPEATED type:TYPE_MESSAGE type_name:".MapScalars.F19Entry"},
- {name:"f20" number:20 label:LABEL_REPEATED type:TYPE_MESSAGE type_name:".MapScalars.F20Entry"},
- {name:"f21" number:21 label:LABEL_REPEATED type:TYPE_MESSAGE type_name:".MapScalars.F21Entry"},
-
- {name:"f22" number:22 label:LABEL_REPEATED type:TYPE_MESSAGE type_name:".MapScalars.F22Entry"},
- {name:"f23" number:23 label:LABEL_REPEATED type:TYPE_MESSAGE type_name:".MapScalars.F23Entry"},
- {name:"f24" number:24 label:LABEL_REPEATED type:TYPE_MESSAGE type_name:".MapScalars.F24Entry"},
- {name:"f25" number:25 label:LABEL_REPEATED type:TYPE_MESSAGE type_name:".MapScalars.F25Entry"}
- ]
- nested_type: [
- {name:"F1Entry" field:[{name:"key" number:1 label:LABEL_OPTIONAL type:TYPE_BOOL}, {name:"value" number:2 label:LABEL_OPTIONAL type:TYPE_STRING}] options:{map_entry:true}},
- {name:"F2Entry" field:[{name:"key" number:1 label:LABEL_OPTIONAL type:TYPE_INT32}, {name:"value" number:2 label:LABEL_OPTIONAL type:TYPE_STRING}] options:{map_entry:true}},
- {name:"F3Entry" field:[{name:"key" number:1 label:LABEL_OPTIONAL type:TYPE_INT64}, {name:"value" number:2 label:LABEL_OPTIONAL type:TYPE_STRING}] options:{map_entry:true}},
- {name:"F4Entry" field:[{name:"key" number:1 label:LABEL_OPTIONAL type:TYPE_UINT32}, {name:"value" number:2 label:LABEL_OPTIONAL type:TYPE_STRING}] options:{map_entry:true}},
- {name:"F5Entry" field:[{name:"key" number:1 label:LABEL_OPTIONAL type:TYPE_UINT64}, {name:"value" number:2 label:LABEL_OPTIONAL type:TYPE_STRING}] options:{map_entry:true}},
- {name:"F6Entry" field:[{name:"key" number:1 label:LABEL_OPTIONAL type:TYPE_STRING}, {name:"value" number:2 label:LABEL_OPTIONAL type:TYPE_STRING}] options:{map_entry:true}},
-
- {name:"F7Entry" field:[{name:"key" number:1 label:LABEL_OPTIONAL type:TYPE_STRING}, {name:"value" number:2 label:LABEL_OPTIONAL type:TYPE_BOOL}] options:{map_entry:true}},
- {name:"F8Entry" field:[{name:"key" number:1 label:LABEL_OPTIONAL type:TYPE_STRING}, {name:"value" number:2 label:LABEL_OPTIONAL type:TYPE_INT32}] options:{map_entry:true}},
- {name:"F9Entry" field:[{name:"key" number:1 label:LABEL_OPTIONAL type:TYPE_STRING}, {name:"value" number:2 label:LABEL_OPTIONAL type:TYPE_INT64}] options:{map_entry:true}},
- {name:"F10Entry" field:[{name:"key" number:1 label:LABEL_OPTIONAL type:TYPE_STRING}, {name:"value" number:2 label:LABEL_OPTIONAL type:TYPE_UINT32}] options:{map_entry:true}},
- {name:"F11Entry" field:[{name:"key" number:1 label:LABEL_OPTIONAL type:TYPE_STRING}, {name:"value" number:2 label:LABEL_OPTIONAL type:TYPE_UINT64}] options:{map_entry:true}},
- {name:"F12Entry" field:[{name:"key" number:1 label:LABEL_OPTIONAL type:TYPE_STRING}, {name:"value" number:2 label:LABEL_OPTIONAL type:TYPE_FLOAT}] options:{map_entry:true}},
- {name:"F13Entry" field:[{name:"key" number:1 label:LABEL_OPTIONAL type:TYPE_STRING}, {name:"value" number:2 label:LABEL_OPTIONAL type:TYPE_DOUBLE}] options:{map_entry:true}},
- {name:"F14Entry" field:[{name:"key" number:1 label:LABEL_OPTIONAL type:TYPE_STRING}, {name:"value" number:2 label:LABEL_OPTIONAL type:TYPE_STRING}] options:{map_entry:true}},
- {name:"F15Entry" field:[{name:"key" number:1 label:LABEL_OPTIONAL type:TYPE_STRING}, {name:"value" number:2 label:LABEL_OPTIONAL type:TYPE_STRING}] options:{map_entry:true}},
- {name:"F16Entry" field:[{name:"key" number:1 label:LABEL_OPTIONAL type:TYPE_STRING}, {name:"value" number:2 label:LABEL_OPTIONAL type:TYPE_BYTES}] options:{map_entry:true}},
- {name:"F17Entry" field:[{name:"key" number:1 label:LABEL_OPTIONAL type:TYPE_STRING}, {name:"value" number:2 label:LABEL_OPTIONAL type:TYPE_BYTES}] options:{map_entry:true}},
-
- {name:"F18Entry" field:[{name:"key" number:1 label:LABEL_OPTIONAL type:TYPE_STRING}, {name:"value" number:2 label:LABEL_OPTIONAL type:TYPE_STRING}] options:{map_entry:true}},
- {name:"F19Entry" field:[{name:"key" number:1 label:LABEL_OPTIONAL type:TYPE_STRING}, {name:"value" number:2 label:LABEL_OPTIONAL type:TYPE_STRING}] options:{map_entry:true}},
- {name:"F20Entry" field:[{name:"key" number:1 label:LABEL_OPTIONAL type:TYPE_STRING}, {name:"value" number:2 label:LABEL_OPTIONAL type:TYPE_BYTES}] options:{map_entry:true}},
- {name:"F21Entry" field:[{name:"key" number:1 label:LABEL_OPTIONAL type:TYPE_STRING}, {name:"value" number:2 label:LABEL_OPTIONAL type:TYPE_BYTES}] options:{map_entry:true}},
-
- {name:"F22Entry" field:[{name:"key" number:1 label:LABEL_OPTIONAL type:TYPE_STRING}, {name:"value" number:2 label:LABEL_OPTIONAL type:TYPE_STRING}] options:{map_entry:true}},
- {name:"F23Entry" field:[{name:"key" number:1 label:LABEL_OPTIONAL type:TYPE_STRING}, {name:"value" number:2 label:LABEL_OPTIONAL type:TYPE_STRING}] options:{map_entry:true}},
- {name:"F24Entry" field:[{name:"key" number:1 label:LABEL_OPTIONAL type:TYPE_STRING}, {name:"value" number:2 label:LABEL_OPTIONAL type:TYPE_BYTES}] options:{map_entry:true}},
- {name:"F25Entry" field:[{name:"key" number:1 label:LABEL_OPTIONAL type:TYPE_STRING}, {name:"value" number:2 label:LABEL_OPTIONAL type:TYPE_BYTES}] options:{map_entry:true}}
- ]
- `, nil),
-}
-
-func (m *MapScalars) ProtoReflect() pref.Message { return mapScalarsType.MessageOf(m) }
-
-func TestMapScalars(t *testing.T) {
- empty := new(MapScalars).ProtoReflect()
- want := (&MapScalars{
- KeyBools: map[bool]string{true: "true", false: "false"},
- KeyInt32s: map[int32]string{0: "zero", -1: "one", 2: "two"},
- KeyInt64s: map[int64]string{0: "zero", -10: "ten", 20: "twenty"},
- KeyUint32s: map[uint32]string{0: "zero", 1: "one", 2: "two"},
- KeyUint64s: map[uint64]string{0: "zero", 10: "ten", 20: "twenty"},
- KeyStrings: map[string]string{"": "", "foo": "bar"},
-
- ValBools: map[string]bool{"true": true, "false": false},
- ValInt32s: map[string]int32{"one": 1, "two": 2, "three": 3},
- ValInt64s: map[string]int64{"ten": 10, "twenty": -20, "thirty": 30},
- ValUint32s: map[string]uint32{"0x00": 0x00, "0xff": 0xff, "0xdead": 0xdead},
- ValUint64s: map[string]uint64{"0x00": 0x00, "0xff": 0xff, "0xdead": 0xdead},
- ValFloat32s: map[string]float32{"nan": float32(math.NaN()), "pi": float32(math.Pi)},
- ValFloat64s: map[string]float64{"nan": float64(math.NaN()), "pi": float64(math.Pi)},
- ValStrings: map[string]string{"s1": "s1", "s2": "s2"},
- ValStringsA: map[string][]byte{"s1": []byte("s1"), "s2": []byte("s2")},
- ValBytes: map[string][]byte{"s1": []byte("s1"), "s2": []byte("s2")},
- ValBytesA: map[string]string{"s1": "s1", "s2": "s2"},
-
- MyStrings1: map[MyString]MyString{"s1": "s1", "s2": "s2"},
- MyStrings2: map[MyString]MyBytes{"s1": []byte("s1"), "s2": []byte("s2")},
- MyBytes1: map[MyString]MyBytes{"s1": []byte("s1"), "s2": []byte("s2")},
- MyBytes2: map[MyString]MyString{"s1": "s1", "s2": "s2"},
-
- MyStrings3: MapStrings{"s1": "s1", "s2": "s2"},
- MyStrings4: MapBytes{"s1": []byte("s1"), "s2": []byte("s2")},
- MyBytes3: MapBytes{"s1": []byte("s1"), "s2": []byte("s2")},
- MyBytes4: MapStrings{"s1": "s1", "s2": "s2"},
- }).ProtoReflect()
-
- testMessage(t, nil, new(MapScalars).ProtoReflect(), messageOps{
- hasFields{1: false, 2: false, 3: false, 4: false, 5: false, 6: false, 7: false, 8: false, 9: false, 10: false, 11: false, 12: false, 13: false, 14: false, 15: false, 16: false, 17: false, 18: false, 19: false, 20: false, 21: false, 22: false, 23: false, 24: false, 25: false},
- getFields{1: getField(empty, 1), 3: getField(empty, 3), 5: getField(empty, 5), 7: getField(empty, 7), 9: getField(empty, 9), 11: getField(empty, 11), 13: getField(empty, 13), 15: getField(empty, 15), 17: getField(empty, 17), 19: getField(empty, 19), 21: getField(empty, 21), 23: getField(empty, 23), 25: getField(empty, 25)},
- setFields{1: getField(want, 1), 3: getField(want, 3), 5: getField(want, 5), 7: getField(want, 7), 9: getField(want, 9), 11: getField(want, 11), 13: getField(want, 13), 15: getField(want, 15), 17: getField(want, 17), 19: getField(want, 19), 21: getField(want, 21), 23: getField(want, 23), 25: getField(want, 25)},
- mapFieldsMutable{
- 2: {
- lenMap(0),
- hasMap{int32(0): false, int32(-1): false, int32(2): false},
- setMap{int32(0): V("zero")},
- lenMap(1),
- hasMap{int32(0): true, int32(-1): false, int32(2): false},
- setMap{int32(-1): V("one")},
- lenMap(2),
- hasMap{int32(0): true, int32(-1): true, int32(2): false},
- setMap{int32(2): V("two")},
- lenMap(3),
- hasMap{int32(0): true, int32(-1): true, int32(2): true},
- },
- 4: {
- setMap{uint32(0): V("zero"), uint32(1): V("one"), uint32(2): V("two")},
- equalMap{getField(want, 4).Map()},
- },
- 6: {
- clearMap{"noexist"},
- setMap{"foo": V("bar")},
- setMap{"": V("empty")},
- getMap{"": V("empty"), "foo": V("bar"), "noexist": V(nil)},
- setMap{"": V(""), "extra": V("extra")},
- clearMap{"extra", "noexist"},
- },
- 8: {
- equalMap{getField(empty, 8).Map()},
- setMap{"one": V(int32(1)), "two": V(int32(2)), "three": V(int32(3))},
- },
- 10: {
- setMap{"0x00": V(uint32(0x00)), "0xff": V(uint32(0xff)), "0xdead": V(uint32(0xdead))},
- lenMap(3),
- equalMap{getField(want, 10).Map()},
- getMap{"0x00": V(uint32(0x00)), "0xff": V(uint32(0xff)), "0xdead": V(uint32(0xdead)), "0xdeadbeef": V(nil)},
- },
- 12: {
- setMap{"nan": V(float32(math.NaN())), "pi": V(float32(math.Pi)), "e": V(float32(math.E))},
- clearMap{"e", "phi"},
- rangeMap{"nan": V(float32(math.NaN())), "pi": V(float32(math.Pi))},
- },
- 14: {
- equalMap{getField(empty, 14).Map()},
- setMap{"s1": V("s1"), "s2": V("s2")},
- },
- 16: {
- setMap{"s1": V([]byte("s1")), "s2": V([]byte("s2"))},
- equalMap{getField(want, 16).Map()},
- },
- 18: {
- hasMap{"s1": false, "s2": false, "s3": false},
- setMap{"s1": V("s1"), "s2": V("s2")},
- hasMap{"s1": true, "s2": true, "s3": false},
- },
- 20: {
- equalMap{getField(empty, 20).Map()},
- setMap{"s1": V([]byte("s1")), "s2": V([]byte("s2"))},
- },
- 22: {
- rangeMap{},
- setMap{"s1": V("s1"), "s2": V("s2")},
- rangeMap{"s1": V("s1"), "s2": V("s2")},
- lenMap(2),
- },
- 24: {
- setMap{"s1": V([]byte("s1")), "s2": V([]byte("s2"))},
- equalMap{getField(want, 24).Map()},
- },
- },
- hasFields{1: true, 2: true, 3: true, 4: true, 5: true, 6: true, 7: true, 8: true, 9: true, 10: true, 11: true, 12: true, 13: true, 14: true, 15: true, 16: true, 17: true, 18: true, 19: true, 20: true, 21: true, 22: true, 23: true, 24: true, 25: true},
- equalMessage{want},
- clearFields{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25},
- equalMessage{empty},
- })
-
- // Test read-only operations on nil message.
- testMessage(t, nil, (*MapScalars)(nil).ProtoReflect(), messageOps{
- hasFields{1: false, 2: false, 3: false, 4: false, 5: false, 6: false, 7: false, 8: false, 9: false, 10: false, 11: false, 12: false, 13: false, 14: false, 15: false, 16: false, 17: false, 18: false, 19: false, 20: false, 21: false, 22: false, 23: false, 24: false, 25: false},
- mapFields{2: {lenMap(0)}, 4: {lenMap(0)}, 6: {lenMap(0)}, 8: {lenMap(0)}, 10: {lenMap(0)}, 12: {lenMap(0)}, 14: {lenMap(0)}, 16: {lenMap(0)}, 18: {lenMap(0)}, 20: {lenMap(0)}, 22: {lenMap(0)}, 24: {lenMap(0)}},
- })
-}
-
-type OneofScalars struct {
- Union isOneofScalars_Union `protobuf_oneof:"union"`
-}
-
-var oneofScalarsType = pimpl.MessageInfo{GoReflectType: reflect.TypeOf(new(OneofScalars)), Desc: mustMakeMessageDesc("oneof-scalars.proto", pref.Proto2, "", `
- name: "OneofScalars"
- field: [
- {name:"f1" number:1 label:LABEL_OPTIONAL type:TYPE_BOOL default_value:"true" oneof_index:0},
- {name:"f2" number:2 label:LABEL_OPTIONAL type:TYPE_INT32 default_value:"2" oneof_index:0},
- {name:"f3" number:3 label:LABEL_OPTIONAL type:TYPE_INT64 default_value:"3" oneof_index:0},
- {name:"f4" number:4 label:LABEL_OPTIONAL type:TYPE_UINT32 default_value:"4" oneof_index:0},
- {name:"f5" number:5 label:LABEL_OPTIONAL type:TYPE_UINT64 default_value:"5" oneof_index:0},
- {name:"f6" number:6 label:LABEL_OPTIONAL type:TYPE_FLOAT default_value:"6" oneof_index:0},
- {name:"f7" number:7 label:LABEL_OPTIONAL type:TYPE_DOUBLE default_value:"7" oneof_index:0},
- {name:"f8" number:8 label:LABEL_OPTIONAL type:TYPE_STRING default_value:"8" oneof_index:0},
- {name:"f9" number:9 label:LABEL_OPTIONAL type:TYPE_STRING default_value:"9" oneof_index:0},
- {name:"f10" number:10 label:LABEL_OPTIONAL type:TYPE_STRING default_value:"10" oneof_index:0},
- {name:"f11" number:11 label:LABEL_OPTIONAL type:TYPE_BYTES default_value:"11" oneof_index:0},
- {name:"f12" number:12 label:LABEL_OPTIONAL type:TYPE_BYTES default_value:"12" oneof_index:0},
- {name:"f13" number:13 label:LABEL_OPTIONAL type:TYPE_BYTES default_value:"13" oneof_index:0}
- ]
- oneof_decl: [{name:"union"}]
- `, nil),
-}
-
-func (m *OneofScalars) ProtoReflect() pref.Message { return oneofScalarsType.MessageOf(m) }
-
-func (*OneofScalars) XXX_OneofWrappers() []interface{} {
- return []interface{}{
- (*OneofScalars_Bool)(nil),
- (*OneofScalars_Int32)(nil),
- (*OneofScalars_Int64)(nil),
- (*OneofScalars_Uint32)(nil),
- (*OneofScalars_Uint64)(nil),
- (*OneofScalars_Float32)(nil),
- (*OneofScalars_Float64)(nil),
- (*OneofScalars_String)(nil),
- (*OneofScalars_StringA)(nil),
- (*OneofScalars_StringB)(nil),
- (*OneofScalars_Bytes)(nil),
- (*OneofScalars_BytesA)(nil),
- (*OneofScalars_BytesB)(nil),
- }
-}
-
-type (
- isOneofScalars_Union interface {
- isOneofScalars_Union()
- }
- OneofScalars_Bool struct {
- Bool bool `protobuf:"1"`
- }
- OneofScalars_Int32 struct {
- Int32 MyInt32 `protobuf:"2"`
- }
- OneofScalars_Int64 struct {
- Int64 int64 `protobuf:"3"`
- }
- OneofScalars_Uint32 struct {
- Uint32 MyUint32 `protobuf:"4"`
- }
- OneofScalars_Uint64 struct {
- Uint64 uint64 `protobuf:"5"`
- }
- OneofScalars_Float32 struct {
- Float32 MyFloat32 `protobuf:"6"`
- }
- OneofScalars_Float64 struct {
- Float64 float64 `protobuf:"7"`
- }
- OneofScalars_String struct {
- String string `protobuf:"8"`
- }
- OneofScalars_StringA struct {
- StringA []byte `protobuf:"9"`
- }
- OneofScalars_StringB struct {
- StringB MyString `protobuf:"10"`
- }
- OneofScalars_Bytes struct {
- Bytes []byte `protobuf:"11"`
- }
- OneofScalars_BytesA struct {
- BytesA string `protobuf:"12"`
- }
- OneofScalars_BytesB struct {
- BytesB MyBytes `protobuf:"13"`
- }
-)
-
-func (*OneofScalars_Bool) isOneofScalars_Union() {}
-func (*OneofScalars_Int32) isOneofScalars_Union() {}
-func (*OneofScalars_Int64) isOneofScalars_Union() {}
-func (*OneofScalars_Uint32) isOneofScalars_Union() {}
-func (*OneofScalars_Uint64) isOneofScalars_Union() {}
-func (*OneofScalars_Float32) isOneofScalars_Union() {}
-func (*OneofScalars_Float64) isOneofScalars_Union() {}
-func (*OneofScalars_String) isOneofScalars_Union() {}
-func (*OneofScalars_StringA) isOneofScalars_Union() {}
-func (*OneofScalars_StringB) isOneofScalars_Union() {}
-func (*OneofScalars_Bytes) isOneofScalars_Union() {}
-func (*OneofScalars_BytesA) isOneofScalars_Union() {}
-func (*OneofScalars_BytesB) isOneofScalars_Union() {}
-
-func TestOneofs(t *testing.T) {
- empty := &OneofScalars{}
- want1 := &OneofScalars{Union: &OneofScalars_Bool{true}}
- want2 := &OneofScalars{Union: &OneofScalars_Int32{20}}
- want3 := &OneofScalars{Union: &OneofScalars_Int64{30}}
- want4 := &OneofScalars{Union: &OneofScalars_Uint32{40}}
- want5 := &OneofScalars{Union: &OneofScalars_Uint64{50}}
- want6 := &OneofScalars{Union: &OneofScalars_Float32{60}}
- want7 := &OneofScalars{Union: &OneofScalars_Float64{70}}
- want8 := &OneofScalars{Union: &OneofScalars_String{string("80")}}
- want9 := &OneofScalars{Union: &OneofScalars_StringA{[]byte("90")}}
- want10 := &OneofScalars{Union: &OneofScalars_StringB{MyString("100")}}
- want11 := &OneofScalars{Union: &OneofScalars_Bytes{[]byte("110")}}
- want12 := &OneofScalars{Union: &OneofScalars_BytesA{string("120")}}
- want13 := &OneofScalars{Union: &OneofScalars_BytesB{MyBytes("130")}}
-
- testMessage(t, nil, new(OneofScalars).ProtoReflect(), messageOps{
- hasFields{1: false, 2: false, 3: false, 4: false, 5: false, 6: false, 7: false, 8: false, 9: false, 10: false, 11: false, 12: false, 13: false},
- getFields{1: V(bool(true)), 2: V(int32(2)), 3: V(int64(3)), 4: V(uint32(4)), 5: V(uint64(5)), 6: V(float32(6)), 7: V(float64(7)), 8: V(string("8")), 9: V(string("9")), 10: V(string("10")), 11: V([]byte("11")), 12: V([]byte("12")), 13: V([]byte("13"))},
- whichOneofs{"union": 0},
-
- setFields{1: V(bool(true))}, hasFields{1: true}, equalMessage{want1.ProtoReflect()},
- setFields{2: V(int32(20))}, hasFields{2: true}, equalMessage{want2.ProtoReflect()},
- setFields{3: V(int64(30))}, hasFields{3: true}, equalMessage{want3.ProtoReflect()},
- setFields{4: V(uint32(40))}, hasFields{4: true}, equalMessage{want4.ProtoReflect()},
- setFields{5: V(uint64(50))}, hasFields{5: true}, equalMessage{want5.ProtoReflect()},
- setFields{6: V(float32(60))}, hasFields{6: true}, equalMessage{want6.ProtoReflect()},
- setFields{7: V(float64(70))}, hasFields{7: true}, equalMessage{want7.ProtoReflect()},
-
- hasFields{1: false, 2: false, 3: false, 4: false, 5: false, 6: false, 7: true, 8: false, 9: false, 10: false, 11: false, 12: false, 13: false},
- whichOneofs{"union": 7},
-
- setFields{8: V(string("80"))}, hasFields{8: true}, equalMessage{want8.ProtoReflect()},
- setFields{9: V(string("90"))}, hasFields{9: true}, equalMessage{want9.ProtoReflect()},
- setFields{10: V(string("100"))}, hasFields{10: true}, equalMessage{want10.ProtoReflect()},
- setFields{11: V([]byte("110"))}, hasFields{11: true}, equalMessage{want11.ProtoReflect()},
- setFields{12: V([]byte("120"))}, hasFields{12: true}, equalMessage{want12.ProtoReflect()},
- setFields{13: V([]byte("130"))}, hasFields{13: true}, equalMessage{want13.ProtoReflect()},
-
- hasFields{1: false, 2: false, 3: false, 4: false, 5: false, 6: false, 7: false, 8: false, 9: false, 10: false, 11: false, 12: false, 13: true},
- getFields{1: V(bool(true)), 2: V(int32(2)), 3: V(int64(3)), 4: V(uint32(4)), 5: V(uint64(5)), 6: V(float32(6)), 7: V(float64(7)), 8: V(string("8")), 9: V(string("9")), 10: V(string("10")), 11: V([]byte("11")), 12: V([]byte("12")), 13: V([]byte("130"))},
- clearFields{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12},
- whichOneofs{"union": 13},
- equalMessage{want13.ProtoReflect()},
- clearFields{13},
- whichOneofs{"union": 0},
- equalMessage{empty.ProtoReflect()},
- })
-
- // Test read-only operations on nil message.
- testMessage(t, nil, (*OneofScalars)(nil).ProtoReflect(), messageOps{
- hasFields{1: false, 2: false, 3: false, 4: false, 5: false, 6: false, 7: false, 8: false, 9: false, 10: false, 11: false, 12: false, 13: false},
- getFields{1: V(bool(true)), 2: V(int32(2)), 3: V(int64(3)), 4: V(uint32(4)), 5: V(uint64(5)), 6: V(float32(6)), 7: V(float64(7)), 8: V(string("8")), 9: V(string("9")), 10: V(string("10")), 11: V([]byte("11")), 12: V([]byte("12")), 13: V([]byte("13"))},
- })
-}
-
-type EnumProto2 int32
-
-var enumProto2Desc = mustMakeEnumDesc("enum2.proto", pref.Proto2, `
- name: "EnumProto2"
- value: [{name:"DEAD" number:0xdead}, {name:"BEEF" number:0xbeef}]
-`)
-
-func (e EnumProto2) Descriptor() pref.EnumDescriptor { return enumProto2Desc }
-func (e EnumProto2) Type() pref.EnumType { return e }
-func (e EnumProto2) Enum() *EnumProto2 { return &e }
-func (e EnumProto2) Number() pref.EnumNumber { return pref.EnumNumber(e) }
-func (t EnumProto2) New(n pref.EnumNumber) pref.Enum { return EnumProto2(n) }
-
-type EnumProto3 int32
-
-var enumProto3Desc = mustMakeEnumDesc("enum3.proto", pref.Proto3, `
- name: "EnumProto3",
- value: [{name:"ALPHA" number:0}, {name:"BRAVO" number:1}]
-`)
-
-func (e EnumProto3) Descriptor() pref.EnumDescriptor { return enumProto3Desc }
-func (e EnumProto3) Type() pref.EnumType { return e }
-func (e EnumProto3) Enum() *EnumProto3 { return &e }
-func (e EnumProto3) Number() pref.EnumNumber { return pref.EnumNumber(e) }
-func (t EnumProto3) New(n pref.EnumNumber) pref.Enum { return EnumProto3(n) }
-
-type EnumMessages struct {
- EnumP2 *EnumProto2 `protobuf:"1"`
- EnumP3 *EnumProto3 `protobuf:"2"`
- MessageLegacy *proto2_20180125.Message `protobuf:"3"`
- MessageCycle *EnumMessages `protobuf:"4"`
- EnumList []EnumProto2 `protobuf:"5"`
- MessageList []*ScalarProto2 `protobuf:"6"`
- EnumMap map[string]EnumProto3 `protobuf:"7"`
- MessageMap map[string]*ScalarProto3 `protobuf:"8"`
- Union isEnumMessages_Union `protobuf_oneof:"union"`
-}
-
-var enumMessagesType = pimpl.MessageInfo{GoReflectType: reflect.TypeOf(new(EnumMessages)), Desc: mustMakeMessageDesc("enum-messages.proto", pref.Proto2, `
- dependency: ["enum2.proto", "enum3.proto", "scalar2.proto", "scalar3.proto", "proto2_20180125_92554152/test.proto"]
- `, `
- name: "EnumMessages"
- field: [
- {name:"f1" number:1 label:LABEL_OPTIONAL type:TYPE_ENUM type_name:".EnumProto2" default_value:"BEEF"},
- {name:"f2" number:2 label:LABEL_OPTIONAL type:TYPE_ENUM type_name:".EnumProto3" default_value:"BRAVO"},
- {name:"f3" number:3 label:LABEL_OPTIONAL type:TYPE_MESSAGE type_name:".google.golang.org.proto2_20180125.Message"},
- {name:"f4" number:4 label:LABEL_OPTIONAL type:TYPE_MESSAGE type_name:".EnumMessages"},
- {name:"f5" number:5 label:LABEL_REPEATED type:TYPE_ENUM type_name:".EnumProto2"},
- {name:"f6" number:6 label:LABEL_REPEATED type:TYPE_MESSAGE type_name:".ScalarProto2"},
- {name:"f7" number:7 label:LABEL_REPEATED type:TYPE_MESSAGE type_name:".EnumMessages.F7Entry"},
- {name:"f8" number:8 label:LABEL_REPEATED type:TYPE_MESSAGE type_name:".EnumMessages.F8Entry"},
- {name:"f9" number:9 label:LABEL_OPTIONAL type:TYPE_ENUM type_name:".EnumProto2" oneof_index:0 default_value:"BEEF"},
- {name:"f10" number:10 label:LABEL_OPTIONAL type:TYPE_ENUM type_name:".EnumProto3" oneof_index:0 default_value:"BRAVO"},
- {name:"f11" number:11 label:LABEL_OPTIONAL type:TYPE_MESSAGE type_name:".ScalarProto2" oneof_index:0},
- {name:"f12" number:12 label:LABEL_OPTIONAL type:TYPE_MESSAGE type_name:".ScalarProto3" oneof_index:0}
- ]
- oneof_decl: [{name:"union"}]
- nested_type: [
- {name:"F7Entry" field:[{name:"key" number:1 label:LABEL_OPTIONAL type:TYPE_STRING}, {name:"value" number:2 label:LABEL_OPTIONAL type:TYPE_ENUM type_name:".EnumProto3"}] options:{map_entry:true}},
- {name:"F8Entry" field:[{name:"key" number:1 label:LABEL_OPTIONAL type:TYPE_STRING}, {name:"value" number:2 label:LABEL_OPTIONAL type:TYPE_MESSAGE type_name:".ScalarProto3"}] options:{map_entry:true}}
- ]
- `, newFileRegistry(
- EnumProto2(0).Descriptor().ParentFile(),
- EnumProto3(0).Descriptor().ParentFile(),
- ((*ScalarProto2)(nil)).ProtoReflect().Descriptor().ParentFile(),
- ((*ScalarProto3)(nil)).ProtoReflect().Descriptor().ParentFile(),
- pimpl.Export{}.MessageDescriptorOf((*proto2_20180125.Message)(nil)).ParentFile(),
-)),
-}
-
-func newFileRegistry(files ...pref.FileDescriptor) *protoregistry.Files {
- r := new(protoregistry.Files)
- for _, file := range files {
- r.RegisterFile(file)
- }
- return r
-}
-
-func (m *EnumMessages) ProtoReflect() pref.Message { return enumMessagesType.MessageOf(m) }
-
-func (*EnumMessages) XXX_OneofWrappers() []interface{} {
- return []interface{}{
- (*EnumMessages_OneofE2)(nil),
- (*EnumMessages_OneofE3)(nil),
- (*EnumMessages_OneofM2)(nil),
- (*EnumMessages_OneofM3)(nil),
- }
-}
-
-type (
- isEnumMessages_Union interface {
- isEnumMessages_Union()
- }
- EnumMessages_OneofE2 struct {
- OneofE2 EnumProto2 `protobuf:"9"`
- }
- EnumMessages_OneofE3 struct {
- OneofE3 EnumProto3 `protobuf:"10"`
- }
- EnumMessages_OneofM2 struct {
- OneofM2 *ScalarProto2 `protobuf:"11"`
- }
- EnumMessages_OneofM3 struct {
- OneofM3 *ScalarProto3 `protobuf:"12"`
- }
-)
-
-func (*EnumMessages_OneofE2) isEnumMessages_Union() {}
-func (*EnumMessages_OneofE3) isEnumMessages_Union() {}
-func (*EnumMessages_OneofM2) isEnumMessages_Union() {}
-func (*EnumMessages_OneofM3) isEnumMessages_Union() {}
-
-func TestEnumMessages(t *testing.T) {
- emptyL := pimpl.Export{}.MessageOf(new(proto2_20180125.Message))
- emptyM := new(EnumMessages).ProtoReflect()
- emptyM2 := new(ScalarProto2).ProtoReflect()
- emptyM3 := new(ScalarProto3).ProtoReflect()
-
- wantL := pimpl.Export{}.MessageOf(&proto2_20180125.Message{OptionalFloat: proto.Float32(math.E)})
- wantM := (&EnumMessages{EnumP2: EnumProto2(1234).Enum()}).ProtoReflect()
- wantM2a := &ScalarProto2{Float32: proto.Float32(math.Pi)}
- wantM2b := &ScalarProto2{Float32: proto.Float32(math.Phi)}
- wantM3a := &ScalarProto3{Float32: math.Pi}
- wantM3b := &ScalarProto3{Float32: math.Ln2}
-
- wantList5 := getField((&EnumMessages{EnumList: []EnumProto2{333, 222}}).ProtoReflect(), 5)
- wantList6 := getField((&EnumMessages{MessageList: []*ScalarProto2{wantM2a, wantM2b}}).ProtoReflect(), 6)
-
- wantMap7 := getField((&EnumMessages{EnumMap: map[string]EnumProto3{"one": 1, "two": 2}}).ProtoReflect(), 7)
- wantMap8 := getField((&EnumMessages{MessageMap: map[string]*ScalarProto3{"pi": wantM3a, "ln2": wantM3b}}).ProtoReflect(), 8)
-
- testMessage(t, nil, new(EnumMessages).ProtoReflect(), messageOps{
- hasFields{1: false, 2: false, 3: false, 4: false, 5: false, 6: false, 7: false, 8: false, 9: false, 10: false, 11: false, 12: false},
- getFields{1: VE(0xbeef), 2: VE(1), 3: V(emptyL), 4: V(emptyM), 9: VE(0xbeef), 10: VE(1)},
-
- // Test singular enums.
- setFields{1: VE(0xdead), 2: VE(0)},
- getFields{1: VE(0xdead), 2: VE(0)},
- hasFields{1: true, 2: true},
-
- // Test singular messages.
- messageFieldsMutable{3: messageOps{setFields{109: V(float32(math.E))}}},
- messageFieldsMutable{4: messageOps{setFields{1: VE(1234)}}},
- getFields{3: V(wantL), 4: V(wantM)},
- clearFields{3, 4},
- hasFields{3: false, 4: false},
- setFields{3: V(wantL), 4: V(wantM)},
- hasFields{3: true, 4: true},
-
- // Test list of enums and messages.
- listFieldsMutable{
- 5: listOps{
- appendList{VE(111), VE(222)},
- setList{0: VE(333)},
- getList{0: VE(333), 1: VE(222)},
- lenList(2),
- },
- 6: listOps{
- appendMessageList{setFields{4: V(uint32(1e6))}},
- appendMessageList{setFields{6: V(float32(math.Phi))}},
- setList{0: V(wantM2a.ProtoReflect())},
- getList{0: V(wantM2a.ProtoReflect()), 1: V(wantM2b.ProtoReflect())},
- },
- },
- getFields{5: wantList5, 6: wantList6},
- hasFields{5: true, 6: true},
- listFields{5: listOps{truncList(0)}},
- hasFields{5: false, 6: true},
-
- // Test maps of enums and messages.
- mapFieldsMutable{
- 7: mapOps{
- setMap{"one": VE(1), "two": VE(2)},
- hasMap{"one": true, "two": true, "three": false},
- lenMap(2),
- },
- 8: mapOps{
- messageMap{"pi": messageOps{setFields{6: V(float32(math.Pi))}}},
- setMap{"ln2": V(wantM3b.ProtoReflect())},
- getMap{"pi": V(wantM3a.ProtoReflect()), "ln2": V(wantM3b.ProtoReflect()), "none": V(nil)},
- lenMap(2),
- },
- },
- getFields{7: wantMap7, 8: wantMap8},
- hasFields{7: true, 8: true},
- mapFields{8: mapOps{clearMap{"pi", "ln2", "none"}}},
- hasFields{7: true, 8: false},
-
- // Test oneofs of enums and messages.
- setFields{9: VE(0xdead)},
- hasFields{1: true, 2: true, 9: true, 10: false, 11: false, 12: false},
- setFields{10: VE(0)},
- hasFields{1: true, 2: true, 9: false, 10: true, 11: false, 12: false},
- messageFieldsMutable{11: messageOps{setFields{6: V(float32(math.Pi))}}},
- getFields{11: V(wantM2a.ProtoReflect())},
- hasFields{1: true, 2: true, 9: false, 10: false, 11: true, 12: false},
- messageFieldsMutable{12: messageOps{setFields{6: V(float32(math.Pi))}}},
- getFields{12: V(wantM3a.ProtoReflect())},
- hasFields{1: true, 2: true, 9: false, 10: false, 11: false, 12: true},
-
- // Check entire message.
- rangeFields{1: VE(0xdead), 2: VE(0), 3: V(wantL), 4: V(wantM), 6: wantList6, 7: wantMap7, 12: V(wantM3a.ProtoReflect())},
- equalMessage{(&EnumMessages{
- EnumP2: EnumProto2(0xdead).Enum(),
- EnumP3: EnumProto3(0).Enum(),
- MessageLegacy: &proto2_20180125.Message{OptionalFloat: proto.Float32(math.E)},
- MessageCycle: wantM.Interface().(*EnumMessages),
- MessageList: []*ScalarProto2{wantM2a, wantM2b},
- EnumMap: map[string]EnumProto3{"one": 1, "two": 2},
- Union: &EnumMessages_OneofM3{wantM3a},
- }).ProtoReflect()},
- clearFields{1, 2, 3, 4, 6, 7, 12},
- equalMessage{new(EnumMessages).ProtoReflect()},
- })
-
- // Test read-only operations on nil message.
- testMessage(t, nil, (*EnumMessages)(nil).ProtoReflect(), messageOps{
- hasFields{1: false, 2: false, 3: false, 4: false, 5: false, 6: false, 7: false, 8: false, 9: false, 10: false, 11: false, 12: false},
- getFields{1: VE(0xbeef), 2: VE(1), 3: V(emptyL), 4: V(emptyM), 9: VE(0xbeef), 10: VE(1), 11: V(emptyM2), 12: V(emptyM3)},
- listFields{5: {lenList(0)}, 6: {lenList(0)}},
- mapFields{7: {lenMap(0)}, 8: {lenMap(0)}},
- })
-}
-
-var cmpOpts = cmp.Options{
- cmp.Comparer(func(x, y *proto2_20180125.Message) bool {
- mx := pimpl.Export{}.MessageOf(x).Interface()
- my := pimpl.Export{}.MessageOf(y).Interface()
- return proto.Equal(mx, my)
- }),
- cmp.Transformer("UnwrapValue", func(pv pref.Value) interface{} {
- switch v := pv.Interface().(type) {
- case pref.Message:
- out := make(map[pref.FieldNumber]pref.Value)
- v.Range(func(fd pref.FieldDescriptor, v pref.Value) bool {
- out[fd.Number()] = v
- return true
- })
- return out
- case pref.List:
- var out []pref.Value
- for i := 0; i < v.Len(); i++ {
- out = append(out, v.Get(i))
- }
- return out
- case pref.Map:
- out := make(map[interface{}]pref.Value)
- v.Range(func(k pref.MapKey, v pref.Value) bool {
- out[k.Interface()] = v
- return true
- })
- return out
- default:
- return v
- }
- }),
- cmpopts.EquateNaNs(),
-}
-
-func testMessage(t *testing.T, p path, m pref.Message, tt messageOps) {
- fieldDescs := m.Descriptor().Fields()
- oneofDescs := m.Descriptor().Oneofs()
- for i, op := range tt {
- p.Push(i)
- switch op := op.(type) {
- case equalMessage:
- if diff := cmp.Diff(V(op.Message), V(m), cmpOpts); diff != "" {
- t.Errorf("operation %v, message mismatch (-want, +got):\n%s", p, diff)
- }
- case hasFields:
- got := map[pref.FieldNumber]bool{}
- want := map[pref.FieldNumber]bool(op)
- for n := range want {
- fd := fieldDescs.ByNumber(n)
- got[n] = m.Has(fd)
- }
- if diff := cmp.Diff(want, got); diff != "" {
- t.Errorf("operation %v, Message.Has mismatch (-want, +got):\n%s", p, diff)
- }
- case getFields:
- got := map[pref.FieldNumber]pref.Value{}
- want := map[pref.FieldNumber]pref.Value(op)
- for n := range want {
- fd := fieldDescs.ByNumber(n)
- got[n] = m.Get(fd)
- }
- if diff := cmp.Diff(want, got, cmpOpts); diff != "" {
- t.Errorf("operation %v, Message.Get mismatch (-want, +got):\n%s", p, diff)
- }
- case setFields:
- for n, v := range op {
- fd := fieldDescs.ByNumber(n)
- m.Set(fd, v)
- }
- case clearFields:
- for _, n := range op {
- fd := fieldDescs.ByNumber(n)
- m.Clear(fd)
- }
- case whichOneofs:
- got := map[pref.Name]pref.FieldNumber{}
- want := map[pref.Name]pref.FieldNumber(op)
- for s := range want {
- od := oneofDescs.ByName(s)
- fd := m.WhichOneof(od)
- if fd == nil {
- got[s] = 0
- } else {
- got[s] = fd.Number()
- }
- }
- if diff := cmp.Diff(want, got); diff != "" {
- t.Errorf("operation %v, Message.WhichOneof mismatch (-want, +got):\n%s", p, diff)
- }
- case messageFields:
- for n, tt := range op {
- p.Push(int(n))
- fd := fieldDescs.ByNumber(n)
- testMessage(t, p, m.Get(fd).Message(), tt)
- p.Pop()
- }
- case messageFieldsMutable:
- for n, tt := range op {
- p.Push(int(n))
- fd := fieldDescs.ByNumber(n)
- testMessage(t, p, m.Mutable(fd).Message(), tt)
- p.Pop()
- }
- case listFields:
- for n, tt := range op {
- p.Push(int(n))
- fd := fieldDescs.ByNumber(n)
- testLists(t, p, m.Get(fd).List(), tt)
- p.Pop()
- }
- case listFieldsMutable:
- for n, tt := range op {
- p.Push(int(n))
- fd := fieldDescs.ByNumber(n)
- testLists(t, p, m.Mutable(fd).List(), tt)
- p.Pop()
- }
- case mapFields:
- for n, tt := range op {
- p.Push(int(n))
- fd := fieldDescs.ByNumber(n)
- testMaps(t, p, m.Get(fd).Map(), tt)
- p.Pop()
- }
- case mapFieldsMutable:
- for n, tt := range op {
- p.Push(int(n))
- fd := fieldDescs.ByNumber(n)
- testMaps(t, p, m.Mutable(fd).Map(), tt)
- p.Pop()
- }
- case rangeFields:
- got := map[pref.FieldNumber]pref.Value{}
- want := map[pref.FieldNumber]pref.Value(op)
- m.Range(func(fd pref.FieldDescriptor, v pref.Value) bool {
- got[fd.Number()] = v
- return true
- })
- if diff := cmp.Diff(want, got, cmpOpts); diff != "" {
- t.Errorf("operation %v, Message.Range mismatch (-want, +got):\n%s", p, diff)
- }
- default:
- t.Fatalf("operation %v, invalid operation: %T", p, op)
- }
- p.Pop()
- }
-}
-
-func testLists(t *testing.T, p path, v pref.List, tt listOps) {
- for i, op := range tt {
- p.Push(i)
- switch op := op.(type) {
- case equalList:
- if diff := cmp.Diff(V(op.List), V(v), cmpOpts); diff != "" {
- t.Errorf("operation %v, list mismatch (-want, +got):\n%s", p, diff)
- }
- case lenList:
- if got, want := v.Len(), int(op); got != want {
- t.Errorf("operation %v, List.Len = %d, want %d", p, got, want)
- }
- case getList:
- got := map[int]pref.Value{}
- want := map[int]pref.Value(op)
- for n := range want {
- got[n] = v.Get(n)
- }
- if diff := cmp.Diff(want, got, cmpOpts); diff != "" {
- t.Errorf("operation %v, List.Get mismatch (-want, +got):\n%s", p, diff)
- }
- case setList:
- for n, e := range op {
- v.Set(n, e)
- }
- case appendList:
- for _, e := range op {
- v.Append(e)
- }
- case appendMessageList:
- e := v.NewElement()
- v.Append(e)
- testMessage(t, p, e.Message(), messageOps(op))
- case truncList:
- v.Truncate(int(op))
- default:
- t.Fatalf("operation %v, invalid operation: %T", p, op)
- }
- p.Pop()
- }
-}
-
-func testMaps(t *testing.T, p path, m pref.Map, tt mapOps) {
- for i, op := range tt {
- p.Push(i)
- switch op := op.(type) {
- case equalMap:
- if diff := cmp.Diff(V(op.Map), V(m), cmpOpts); diff != "" {
- t.Errorf("operation %v, map mismatch (-want, +got):\n%s", p, diff)
- }
- case lenMap:
- if got, want := m.Len(), int(op); got != want {
- t.Errorf("operation %v, Map.Len = %d, want %d", p, got, want)
- }
- case hasMap:
- got := map[interface{}]bool{}
- want := map[interface{}]bool(op)
- for k := range want {
- got[k] = m.Has(V(k).MapKey())
- }
- if diff := cmp.Diff(want, got, cmpOpts); diff != "" {
- t.Errorf("operation %v, Map.Has mismatch (-want, +got):\n%s", p, diff)
- }
- case getMap:
- got := map[interface{}]pref.Value{}
- want := map[interface{}]pref.Value(op)
- for k := range want {
- got[k] = m.Get(V(k).MapKey())
- }
- if diff := cmp.Diff(want, got, cmpOpts); diff != "" {
- t.Errorf("operation %v, Map.Get mismatch (-want, +got):\n%s", p, diff)
- }
- case setMap:
- for k, v := range op {
- m.Set(V(k).MapKey(), v)
- }
- case clearMap:
- for _, k := range op {
- m.Clear(V(k).MapKey())
- }
- case messageMap:
- for k, tt := range op {
- mk := V(k).MapKey()
- if !m.Has(mk) {
- m.Set(mk, m.NewValue())
- }
- testMessage(t, p, m.Get(mk).Message(), tt)
- }
- case rangeMap:
- got := map[interface{}]pref.Value{}
- want := map[interface{}]pref.Value(op)
- m.Range(func(k pref.MapKey, v pref.Value) bool {
- got[k.Interface()] = v
- return true
- })
- if diff := cmp.Diff(want, got, cmpOpts); diff != "" {
- t.Errorf("operation %v, Map.Range mismatch (-want, +got):\n%s", p, diff)
- }
- default:
- t.Fatalf("operation %v, invalid operation: %T", p, op)
- }
- p.Pop()
- }
-}
-
-func getField(m pref.Message, n pref.FieldNumber) pref.Value {
- fd := m.Descriptor().Fields().ByNumber(n)
- return m.Get(fd)
-}
-
-type path []int
-
-func (p *path) Push(i int) { *p = append(*p, i) }
-func (p *path) Pop() { *p = (*p)[:len(*p)-1] }
-func (p path) String() string {
- var ss []string
- for _, i := range p {
- ss = append(ss, fmt.Sprint(i))
- }
- return strings.Join(ss, ".")
-}
-
-type UnknownFieldsA struct {
- XXX_unrecognized []byte
-}
-
-var unknownFieldsAType = pimpl.MessageInfo{
- GoReflectType: reflect.TypeOf(new(UnknownFieldsA)),
- Desc: mustMakeMessageDesc("unknown.proto", pref.Proto2, "", `name: "UnknownFieldsA"`, nil),
-}
-
-func (m *UnknownFieldsA) ProtoReflect() pref.Message { return unknownFieldsAType.MessageOf(m) }
-
-type UnknownFieldsB struct {
- XXX_unrecognized *[]byte
-}
-
-var unknownFieldsBType = pimpl.MessageInfo{
- GoReflectType: reflect.TypeOf(new(UnknownFieldsB)),
- Desc: mustMakeMessageDesc("unknown.proto", pref.Proto2, "", `name: "UnknownFieldsB"`, nil),
-}
-
-func (m *UnknownFieldsB) ProtoReflect() pref.Message { return unknownFieldsBType.MessageOf(m) }
-
-func TestUnknownFields(t *testing.T) {
- for _, m := range []proto.Message{new(UnknownFieldsA), new(UnknownFieldsB)} {
- t.Run(reflect.TypeOf(m).Elem().Name(), func(t *testing.T) {
- want := protopack.Message{
- protopack.Tag{1, protopack.BytesType}, protopack.String("Hello, world!"),
- }.Marshal()
- m.ProtoReflect().SetUnknown(want)
- got := []byte(m.ProtoReflect().GetUnknown())
- if diff := cmp.Diff(want, got); diff != "" {
- t.Errorf("UnknownFields mismatch (-want +got):\n%s", diff)
- }
- })
- }
-}
-
-func TestReset(t *testing.T) {
- mi := new(testpb.TestAllTypes)
-
- // ProtoReflect is implemented using a messageState cache.
- m := mi.ProtoReflect()
-
- // Reset must not clear the messageState cache.
- mi.Reset()
-
- // If Reset accidentally cleared the messageState cache, this panics.
- m.Descriptor()
-}
-
-func TestIsValid(t *testing.T) {
- var m *testpb.TestAllTypes
- if got, want := m.ProtoReflect().IsValid(), false; got != want {
- t.Errorf("((*M)(nil)).ProtoReflect().IsValid() = %v, want %v", got, want)
- }
- m = &testpb.TestAllTypes{}
- if got, want := m.ProtoReflect().IsValid(), true; got != want {
- t.Errorf("(&M{}).ProtoReflect().IsValid() = %v, want %v", got, want)
- }
-}
-
-// The MessageState implementation makes the assumption that when a
-// concrete message is unsafe casted as a *MessageState, the Go GC does
-// not reclaim the memory for the remainder of the concrete message.
-func TestUnsafeAssumptions(t *testing.T) {
- if !pimpl.UnsafeEnabled {
- t.Skip()
- }
-
- var wg sync.WaitGroup
- for i := 0; i < 10; i++ {
- wg.Add(1)
- go func() {
- var ms [10]pref.Message
-
- // Store the message only in its reflective form.
- // Trigger the GC after each iteration.
- for j := 0; j < 10; j++ {
- ms[j] = (&testpb.TestAllTypes{
- OptionalInt32: proto.Int32(int32(j)),
- OptionalFloat: proto.Float32(float32(j)),
- RepeatedInt32: []int32{int32(j)},
- RepeatedFloat: []float32{float32(j)},
- DefaultInt32: proto.Int32(int32(j)),
- DefaultFloat: proto.Float32(float32(j)),
- }).ProtoReflect()
- runtime.GC()
- }
-
- // Convert the reflective form back into a concrete form.
- // Verify that the values written previously are still the same.
- for j := 0; j < 10; j++ {
- switch m := ms[j].Interface().(*testpb.TestAllTypes); {
- case m.GetOptionalInt32() != int32(j):
- case m.GetOptionalFloat() != float32(j):
- case m.GetRepeatedInt32()[0] != int32(j):
- case m.GetRepeatedFloat()[0] != float32(j):
- case m.GetDefaultInt32() != int32(j):
- case m.GetDefaultFloat() != float32(j):
- default:
- continue
- }
- t.Error("memory corrupted detected")
- }
- defer wg.Done()
- }()
- }
- wg.Wait()
-}
-
-func BenchmarkName(b *testing.B) {
- var sink pref.FullName
- b.Run("Value", func(b *testing.B) {
- b.ReportAllocs()
- m := new(descriptorpb.FileDescriptorProto)
- for i := 0; i < b.N; i++ {
- sink = m.ProtoReflect().Descriptor().FullName()
- }
- })
- b.Run("Nil", func(b *testing.B) {
- b.ReportAllocs()
- m := (*descriptorpb.FileDescriptorProto)(nil)
- for i := 0; i < b.N; i++ {
- sink = m.ProtoReflect().Descriptor().FullName()
- }
- })
- runtime.KeepAlive(sink)
-}
-
-func BenchmarkReflect(b *testing.B) {
- m := new(testpb.TestAllTypes).ProtoReflect()
- fds := m.Descriptor().Fields()
- vs := make([]pref.Value, fds.Len())
- for i := range vs {
- vs[i] = m.NewField(fds.Get(i))
- }
-
- b.Run("Has", func(b *testing.B) {
- b.ReportAllocs()
- for i := 0; i < b.N; i++ {
- for j := 0; j < fds.Len(); j++ {
- m.Has(fds.Get(j))
- }
- }
- })
- b.Run("Get", func(b *testing.B) {
- b.ReportAllocs()
- for i := 0; i < b.N; i++ {
- for j := 0; j < fds.Len(); j++ {
- m.Get(fds.Get(j))
- }
- }
- })
- b.Run("Set", func(b *testing.B) {
- b.ReportAllocs()
- for i := 0; i < b.N; i++ {
- for j := 0; j < fds.Len(); j++ {
- m.Set(fds.Get(j), vs[j])
- }
- }
- })
- b.Run("Clear", func(b *testing.B) {
- b.ReportAllocs()
- for i := 0; i < b.N; i++ {
- for j := 0; j < fds.Len(); j++ {
- m.Clear(fds.Get(j))
- }
- }
- })
- b.Run("Range", func(b *testing.B) {
- b.ReportAllocs()
- for i := 0; i < b.N; i++ {
- m.Range(func(pref.FieldDescriptor, pref.Value) bool {
- return true
- })
- }
- })
-}