Joe Tsai | 90fe996 | 2018-10-18 11:06:29 -0700 | [diff] [blame] | 1 | // Copyright 2018 The Go Authors. All rights reserved. |
| 2 | // Use of this source code is governed by a BSD-style |
| 3 | // license that can be found in the LICENSE file. |
| 4 | |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 5 | package impl_test |
Joe Tsai | 90fe996 | 2018-10-18 11:06:29 -0700 | [diff] [blame] | 6 | |
| 7 | import ( |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 8 | "fmt" |
Joe Tsai | 90fe996 | 2018-10-18 11:06:29 -0700 | [diff] [blame] | 9 | "reflect" |
Joe Tsai | 21ade49 | 2019-05-22 13:42:54 -0400 | [diff] [blame] | 10 | "sync" |
Joe Tsai | 90fe996 | 2018-10-18 11:06:29 -0700 | [diff] [blame] | 11 | "testing" |
| 12 | |
Joe Tsai | 378c132 | 2019-04-25 23:48:08 -0700 | [diff] [blame] | 13 | "github.com/google/go-cmp/cmp" |
| 14 | "github.com/google/go-cmp/cmp/cmpopts" |
Joe Tsai | e0daf31 | 2020-02-25 12:51:10 -0800 | [diff] [blame] | 15 | |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 16 | "google.golang.org/protobuf/encoding/prototext" |
Damien Neil | e89e624 | 2019-05-13 23:55:40 -0700 | [diff] [blame] | 17 | pimpl "google.golang.org/protobuf/internal/impl" |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 18 | "google.golang.org/protobuf/internal/pragma" |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 19 | "google.golang.org/protobuf/proto" |
| 20 | pdesc "google.golang.org/protobuf/reflect/protodesc" |
Damien Neil | e89e624 | 2019-05-13 23:55:40 -0700 | [diff] [blame] | 21 | pref "google.golang.org/protobuf/reflect/protoreflect" |
| 22 | preg "google.golang.org/protobuf/reflect/protoregistry" |
| 23 | piface "google.golang.org/protobuf/runtime/protoiface" |
Joe Tsai | ea11813 | 2018-11-11 17:56:21 -0800 | [diff] [blame] | 24 | |
Joe Tsai | 55f1825 | 2020-01-11 00:25:01 -0800 | [diff] [blame] | 25 | proto2_20180125 "google.golang.org/protobuf/internal/testprotos/legacy/proto2_20180125_92554152" |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 26 | "google.golang.org/protobuf/types/descriptorpb" |
Joe Tsai | 90fe996 | 2018-10-18 11:06:29 -0700 | [diff] [blame] | 27 | ) |
| 28 | |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 29 | type LegacyTestMessage struct { |
Joe Tsai | 4fddeba | 2019-03-20 18:29:32 -0700 | [diff] [blame] | 30 | XXX_unrecognized []byte |
Joe Tsai | 89d4963 | 2019-06-04 16:20:00 -0700 | [diff] [blame] | 31 | XXX_InternalExtensions map[int32]pimpl.ExtensionField |
Joe Tsai | 95b0290 | 2018-10-31 18:23:42 -0700 | [diff] [blame] | 32 | } |
| 33 | |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 34 | func (*LegacyTestMessage) Reset() {} |
| 35 | func (*LegacyTestMessage) String() string { return "" } |
| 36 | func (*LegacyTestMessage) ProtoMessage() {} |
| 37 | func (*LegacyTestMessage) ExtensionRangeArray() []piface.ExtensionRangeV1 { |
Joe Tsai | 4fddeba | 2019-03-20 18:29:32 -0700 | [diff] [blame] | 38 | return []piface.ExtensionRangeV1{{Start: 10, End: 20}, {Start: 40, End: 80}, {Start: 10000, End: 20000}} |
Joe Tsai | 95b0290 | 2018-10-31 18:23:42 -0700 | [diff] [blame] | 39 | } |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 40 | func (*LegacyTestMessage) Descriptor() ([]byte, []int) { return legacyFD, []int{0} } |
| 41 | |
| 42 | var legacyFD = func() []byte { |
| 43 | b, _ := proto.Marshal(pdesc.ToFileDescriptorProto(mustMakeFileDesc(` |
| 44 | name: "legacy.proto" |
| 45 | syntax: "proto2" |
| 46 | message_type: [{ |
| 47 | name: "LegacyTestMessage" |
| 48 | extension_range: [{start:10 end:20}, {start:40 end:80}, {start:10000 end:20000}] |
| 49 | }] |
| 50 | `, nil))) |
| 51 | return pimpl.Export{}.CompressGZIP(b) |
| 52 | }() |
Joe Tsai | 95b0290 | 2018-10-31 18:23:42 -0700 | [diff] [blame] | 53 | |
Joe Tsai | 0fc49f8 | 2019-05-01 12:29:25 -0700 | [diff] [blame] | 54 | func init() { |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 55 | mt := pimpl.Export{}.MessageTypeOf((*LegacyTestMessage)(nil)) |
Damien Neil | c826885 | 2019-10-08 13:28:53 -0700 | [diff] [blame] | 56 | preg.GlobalFiles.RegisterFile(mt.Descriptor().ParentFile()) |
| 57 | preg.GlobalTypes.RegisterMessage(mt) |
Joe Tsai | 0fc49f8 | 2019-05-01 12:29:25 -0700 | [diff] [blame] | 58 | } |
| 59 | |
Damien Neil | 954bd92 | 2019-07-17 16:52:10 -0700 | [diff] [blame] | 60 | func mustMakeExtensionType(fileDesc, extDesc string, t reflect.Type, r pdesc.Resolver) pref.ExtensionType { |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 61 | s := fmt.Sprintf(`name:"test.proto" syntax:"proto2" %s extension:[{%s}]`, fileDesc, extDesc) |
| 62 | xd := mustMakeFileDesc(s, r).Extensions().Get(0) |
Damien Neil | f1e905b | 2019-08-08 15:45:59 -0700 | [diff] [blame] | 63 | xi := &pimpl.ExtensionInfo{} |
| 64 | pimpl.InitExtensionInfo(xi, xd, t) |
| 65 | return xi |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 66 | } |
| 67 | |
| 68 | func mustMakeFileDesc(s string, r pdesc.Resolver) pref.FileDescriptor { |
| 69 | pb := new(descriptorpb.FileDescriptorProto) |
| 70 | if err := prototext.Unmarshal([]byte(s), pb); err != nil { |
| 71 | panic(err) |
| 72 | } |
| 73 | fd, err := pdesc.NewFile(pb, r) |
| 74 | if err != nil { |
| 75 | panic(err) |
| 76 | } |
| 77 | return fd |
| 78 | } |
| 79 | |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 80 | var ( |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 81 | testParentDesc = pimpl.Export{}.MessageDescriptorOf((*LegacyTestMessage)(nil)) |
Joe Tsai | 21ade49 | 2019-05-22 13:42:54 -0400 | [diff] [blame] | 82 | testEnumV1Desc = pimpl.Export{}.EnumDescriptorOf(proto2_20180125.Message_ChildEnum(0)) |
| 83 | testMessageV1Desc = pimpl.Export{}.MessageDescriptorOf((*proto2_20180125.Message_ChildMessage)(nil)) |
Damien Neil | 16163b4 | 2019-08-06 15:43:25 -0700 | [diff] [blame] | 84 | testMessageV2Desc = enumMessagesType.Desc |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 85 | |
Damien Neil | c826885 | 2019-10-08 13:28:53 -0700 | [diff] [blame] | 86 | depReg = newFileRegistry( |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 87 | testParentDesc.ParentFile(), |
| 88 | testEnumV1Desc.ParentFile(), |
| 89 | testMessageV1Desc.ParentFile(), |
Damien Neil | 16163b4 | 2019-08-06 15:43:25 -0700 | [diff] [blame] | 90 | enumProto2Desc.ParentFile(), |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 91 | testMessageV2Desc.ParentFile(), |
| 92 | ) |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 93 | extensionTypes = []pref.ExtensionType{ |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 94 | mustMakeExtensionType( |
| 95 | `package:"fizz.buzz" dependency:"legacy.proto"`, |
| 96 | `name:"optional_bool" number:10000 label:LABEL_OPTIONAL type:TYPE_BOOL default_value:"true" extendee:".LegacyTestMessage"`, |
Damien Neil | 954bd92 | 2019-07-17 16:52:10 -0700 | [diff] [blame] | 97 | reflect.TypeOf(false), depReg, |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 98 | ), |
| 99 | mustMakeExtensionType( |
| 100 | `package:"fizz.buzz" dependency:"legacy.proto"`, |
| 101 | `name:"optional_int32" number:10001 label:LABEL_OPTIONAL type:TYPE_INT32 default_value:"-12345" extendee:".LegacyTestMessage"`, |
Damien Neil | 954bd92 | 2019-07-17 16:52:10 -0700 | [diff] [blame] | 102 | reflect.TypeOf(int32(0)), depReg, |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 103 | ), |
| 104 | mustMakeExtensionType( |
| 105 | `package:"fizz.buzz" dependency:"legacy.proto"`, |
| 106 | `name:"optional_uint32" number:10002 label:LABEL_OPTIONAL type:TYPE_UINT32 default_value:"3200" extendee:".LegacyTestMessage"`, |
Damien Neil | 954bd92 | 2019-07-17 16:52:10 -0700 | [diff] [blame] | 107 | reflect.TypeOf(uint32(0)), depReg, |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 108 | ), |
| 109 | mustMakeExtensionType( |
| 110 | `package:"fizz.buzz" dependency:"legacy.proto"`, |
| 111 | `name:"optional_float" number:10003 label:LABEL_OPTIONAL type:TYPE_FLOAT default_value:"3.14159" extendee:".LegacyTestMessage"`, |
Damien Neil | 954bd92 | 2019-07-17 16:52:10 -0700 | [diff] [blame] | 112 | reflect.TypeOf(float32(0)), depReg, |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 113 | ), |
| 114 | mustMakeExtensionType( |
| 115 | `package:"fizz.buzz" dependency:"legacy.proto"`, |
| 116 | `name:"optional_string" number:10004 label:LABEL_OPTIONAL type:TYPE_STRING default_value:"hello, \"world!\"\n" extendee:".LegacyTestMessage"`, |
Damien Neil | 954bd92 | 2019-07-17 16:52:10 -0700 | [diff] [blame] | 117 | reflect.TypeOf(""), depReg, |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 118 | ), |
| 119 | mustMakeExtensionType( |
| 120 | `package:"fizz.buzz" dependency:"legacy.proto"`, |
| 121 | `name:"optional_bytes" number:10005 label:LABEL_OPTIONAL type:TYPE_BYTES default_value:"dead\\336\\255\\276\\357beef" extendee:".LegacyTestMessage"`, |
Damien Neil | 954bd92 | 2019-07-17 16:52:10 -0700 | [diff] [blame] | 122 | reflect.TypeOf(([]byte)(nil)), depReg, |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 123 | ), |
| 124 | mustMakeExtensionType( |
Joe Tsai | 55f1825 | 2020-01-11 00:25:01 -0800 | [diff] [blame] | 125 | `package:"fizz.buzz" dependency:["legacy.proto", "proto2_20180125_92554152/test.proto"]`, |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 126 | `name:"optional_enum_v1" number:10006 label:LABEL_OPTIONAL type:TYPE_ENUM type_name:".google.golang.org.proto2_20180125.Message.ChildEnum" default_value:"ALPHA" extendee:".LegacyTestMessage"`, |
Damien Neil | 954bd92 | 2019-07-17 16:52:10 -0700 | [diff] [blame] | 127 | reflect.TypeOf(proto2_20180125.Message_ChildEnum(0)), depReg, |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 128 | ), |
| 129 | mustMakeExtensionType( |
Joe Tsai | 55f1825 | 2020-01-11 00:25:01 -0800 | [diff] [blame] | 130 | `package:"fizz.buzz" dependency:["legacy.proto", "proto2_20180125_92554152/test.proto"]`, |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 131 | `name:"optional_message_v1" number:10007 label:LABEL_OPTIONAL type:TYPE_MESSAGE type_name:".google.golang.org.proto2_20180125.Message.ChildMessage" extendee:".LegacyTestMessage"`, |
Damien Neil | 954bd92 | 2019-07-17 16:52:10 -0700 | [diff] [blame] | 132 | reflect.TypeOf((*proto2_20180125.Message_ChildMessage)(nil)), depReg, |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 133 | ), |
| 134 | mustMakeExtensionType( |
| 135 | `package:"fizz.buzz" dependency:["legacy.proto", "enum2.proto"]`, |
| 136 | `name:"optional_enum_v2" number:10008 label:LABEL_OPTIONAL type:TYPE_ENUM type_name:".EnumProto2" default_value:"DEAD" extendee:".LegacyTestMessage"`, |
Damien Neil | 954bd92 | 2019-07-17 16:52:10 -0700 | [diff] [blame] | 137 | reflect.TypeOf(EnumProto2(0)), depReg, |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 138 | ), |
| 139 | mustMakeExtensionType( |
| 140 | `package:"fizz.buzz" dependency:["legacy.proto", "enum-messages.proto"]`, |
| 141 | `name:"optional_message_v2" number:10009 label:LABEL_OPTIONAL type:TYPE_MESSAGE type_name:".EnumMessages" extendee:".LegacyTestMessage"`, |
Damien Neil | 954bd92 | 2019-07-17 16:52:10 -0700 | [diff] [blame] | 142 | reflect.TypeOf((*EnumMessages)(nil)), depReg, |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 143 | ), |
| 144 | mustMakeExtensionType( |
| 145 | `package:"fizz.buzz" dependency:"legacy.proto"`, |
| 146 | `name:"repeated_bool" number:10010 label:LABEL_REPEATED type:TYPE_BOOL extendee:".LegacyTestMessage"`, |
Joe Tsai | fd4c605 | 2019-09-16 13:30:15 -0700 | [diff] [blame] | 147 | reflect.TypeOf([]bool(nil)), depReg, |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 148 | ), |
| 149 | mustMakeExtensionType( |
| 150 | `package:"fizz.buzz" dependency:"legacy.proto"`, |
| 151 | `name:"repeated_int32" number:10011 label:LABEL_REPEATED type:TYPE_INT32 extendee:".LegacyTestMessage"`, |
Joe Tsai | fd4c605 | 2019-09-16 13:30:15 -0700 | [diff] [blame] | 152 | reflect.TypeOf([]int32(nil)), depReg, |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 153 | ), |
| 154 | mustMakeExtensionType( |
| 155 | `package:"fizz.buzz" dependency:"legacy.proto"`, |
| 156 | `name:"repeated_uint32" number:10012 label:LABEL_REPEATED type:TYPE_UINT32 extendee:".LegacyTestMessage"`, |
Joe Tsai | fd4c605 | 2019-09-16 13:30:15 -0700 | [diff] [blame] | 157 | reflect.TypeOf([]uint32(nil)), depReg, |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 158 | ), |
| 159 | mustMakeExtensionType( |
| 160 | `package:"fizz.buzz" dependency:"legacy.proto"`, |
| 161 | `name:"repeated_float" number:10013 label:LABEL_REPEATED type:TYPE_FLOAT extendee:".LegacyTestMessage"`, |
Joe Tsai | fd4c605 | 2019-09-16 13:30:15 -0700 | [diff] [blame] | 162 | reflect.TypeOf([]float32(nil)), depReg, |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 163 | ), |
| 164 | mustMakeExtensionType( |
| 165 | `package:"fizz.buzz" dependency:"legacy.proto"`, |
| 166 | `name:"repeated_string" number:10014 label:LABEL_REPEATED type:TYPE_STRING extendee:".LegacyTestMessage"`, |
Joe Tsai | fd4c605 | 2019-09-16 13:30:15 -0700 | [diff] [blame] | 167 | reflect.TypeOf([]string(nil)), depReg, |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 168 | ), |
| 169 | mustMakeExtensionType( |
| 170 | `package:"fizz.buzz" dependency:"legacy.proto"`, |
| 171 | `name:"repeated_bytes" number:10015 label:LABEL_REPEATED type:TYPE_BYTES extendee:".LegacyTestMessage"`, |
Joe Tsai | fd4c605 | 2019-09-16 13:30:15 -0700 | [diff] [blame] | 172 | reflect.TypeOf([][]byte(nil)), depReg, |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 173 | ), |
| 174 | mustMakeExtensionType( |
Joe Tsai | 55f1825 | 2020-01-11 00:25:01 -0800 | [diff] [blame] | 175 | `package:"fizz.buzz" dependency:["legacy.proto", "proto2_20180125_92554152/test.proto"]`, |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 176 | `name:"repeated_enum_v1" number:10016 label:LABEL_REPEATED type:TYPE_ENUM type_name:".google.golang.org.proto2_20180125.Message.ChildEnum" extendee:".LegacyTestMessage"`, |
Joe Tsai | fd4c605 | 2019-09-16 13:30:15 -0700 | [diff] [blame] | 177 | reflect.TypeOf([]proto2_20180125.Message_ChildEnum(nil)), depReg, |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 178 | ), |
| 179 | mustMakeExtensionType( |
Joe Tsai | 55f1825 | 2020-01-11 00:25:01 -0800 | [diff] [blame] | 180 | `package:"fizz.buzz" dependency:["legacy.proto", "proto2_20180125_92554152/test.proto"]`, |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 181 | `name:"repeated_message_v1" number:10017 label:LABEL_REPEATED type:TYPE_MESSAGE type_name:".google.golang.org.proto2_20180125.Message.ChildMessage" extendee:".LegacyTestMessage"`, |
Joe Tsai | fd4c605 | 2019-09-16 13:30:15 -0700 | [diff] [blame] | 182 | reflect.TypeOf([]*proto2_20180125.Message_ChildMessage(nil)), depReg, |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 183 | ), |
| 184 | mustMakeExtensionType( |
| 185 | `package:"fizz.buzz" dependency:["legacy.proto", "enum2.proto"]`, |
| 186 | `name:"repeated_enum_v2" number:10018 label:LABEL_REPEATED type:TYPE_ENUM type_name:".EnumProto2" extendee:".LegacyTestMessage"`, |
Joe Tsai | fd4c605 | 2019-09-16 13:30:15 -0700 | [diff] [blame] | 187 | reflect.TypeOf([]EnumProto2(nil)), depReg, |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 188 | ), |
| 189 | mustMakeExtensionType( |
| 190 | `package:"fizz.buzz" dependency:["legacy.proto", "enum-messages.proto"]`, |
| 191 | `name:"repeated_message_v2" number:10019 label:LABEL_REPEATED type:TYPE_MESSAGE type_name:".EnumMessages" extendee:".LegacyTestMessage"`, |
Joe Tsai | fd4c605 | 2019-09-16 13:30:15 -0700 | [diff] [blame] | 192 | reflect.TypeOf([]*EnumMessages(nil)), depReg, |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 193 | ), |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 194 | } |
| 195 | |
Damien Neil | f1e905b | 2019-08-08 15:45:59 -0700 | [diff] [blame] | 196 | extensionDescs = []*pimpl.ExtensionInfo{{ |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 197 | ExtendedType: (*LegacyTestMessage)(nil), |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 198 | ExtensionType: (*bool)(nil), |
| 199 | Field: 10000, |
| 200 | Name: "fizz.buzz.optional_bool", |
| 201 | Tag: "varint,10000,opt,name=optional_bool,def=1", |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 202 | Filename: "test.proto", |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 203 | }, { |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 204 | ExtendedType: (*LegacyTestMessage)(nil), |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 205 | ExtensionType: (*int32)(nil), |
| 206 | Field: 10001, |
| 207 | Name: "fizz.buzz.optional_int32", |
| 208 | Tag: "varint,10001,opt,name=optional_int32,def=-12345", |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 209 | Filename: "test.proto", |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 210 | }, { |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 211 | ExtendedType: (*LegacyTestMessage)(nil), |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 212 | ExtensionType: (*uint32)(nil), |
| 213 | Field: 10002, |
| 214 | Name: "fizz.buzz.optional_uint32", |
| 215 | Tag: "varint,10002,opt,name=optional_uint32,def=3200", |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 216 | Filename: "test.proto", |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 217 | }, { |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 218 | ExtendedType: (*LegacyTestMessage)(nil), |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 219 | ExtensionType: (*float32)(nil), |
| 220 | Field: 10003, |
| 221 | Name: "fizz.buzz.optional_float", |
| 222 | Tag: "fixed32,10003,opt,name=optional_float,def=3.14159", |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 223 | Filename: "test.proto", |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 224 | }, { |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 225 | ExtendedType: (*LegacyTestMessage)(nil), |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 226 | ExtensionType: (*string)(nil), |
| 227 | Field: 10004, |
| 228 | Name: "fizz.buzz.optional_string", |
| 229 | Tag: "bytes,10004,opt,name=optional_string,def=hello, \"world!\"\n", |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 230 | Filename: "test.proto", |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 231 | }, { |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 232 | ExtendedType: (*LegacyTestMessage)(nil), |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 233 | ExtensionType: ([]byte)(nil), |
| 234 | Field: 10005, |
| 235 | Name: "fizz.buzz.optional_bytes", |
| 236 | Tag: "bytes,10005,opt,name=optional_bytes,def=dead\\336\\255\\276\\357beef", |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 237 | Filename: "test.proto", |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 238 | }, { |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 239 | ExtendedType: (*LegacyTestMessage)(nil), |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 240 | ExtensionType: (*proto2_20180125.Message_ChildEnum)(nil), |
| 241 | Field: 10006, |
| 242 | Name: "fizz.buzz.optional_enum_v1", |
| 243 | Tag: "varint,10006,opt,name=optional_enum_v1,enum=google.golang.org.proto2_20180125.Message_ChildEnum,def=0", |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 244 | Filename: "test.proto", |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 245 | }, { |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 246 | ExtendedType: (*LegacyTestMessage)(nil), |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 247 | ExtensionType: (*proto2_20180125.Message_ChildMessage)(nil), |
| 248 | Field: 10007, |
| 249 | Name: "fizz.buzz.optional_message_v1", |
| 250 | Tag: "bytes,10007,opt,name=optional_message_v1", |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 251 | Filename: "test.proto", |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 252 | }, { |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 253 | ExtendedType: (*LegacyTestMessage)(nil), |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 254 | ExtensionType: (*EnumProto2)(nil), |
| 255 | Field: 10008, |
| 256 | Name: "fizz.buzz.optional_enum_v2", |
| 257 | Tag: "varint,10008,opt,name=optional_enum_v2,enum=EnumProto2,def=57005", |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 258 | Filename: "test.proto", |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 259 | }, { |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 260 | ExtendedType: (*LegacyTestMessage)(nil), |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 261 | ExtensionType: (*EnumMessages)(nil), |
| 262 | Field: 10009, |
| 263 | Name: "fizz.buzz.optional_message_v2", |
| 264 | Tag: "bytes,10009,opt,name=optional_message_v2", |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 265 | Filename: "test.proto", |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 266 | }, { |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 267 | ExtendedType: (*LegacyTestMessage)(nil), |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 268 | ExtensionType: ([]bool)(nil), |
| 269 | Field: 10010, |
| 270 | Name: "fizz.buzz.repeated_bool", |
| 271 | Tag: "varint,10010,rep,name=repeated_bool", |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 272 | Filename: "test.proto", |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 273 | }, { |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 274 | ExtendedType: (*LegacyTestMessage)(nil), |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 275 | ExtensionType: ([]int32)(nil), |
| 276 | Field: 10011, |
| 277 | Name: "fizz.buzz.repeated_int32", |
| 278 | Tag: "varint,10011,rep,name=repeated_int32", |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 279 | Filename: "test.proto", |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 280 | }, { |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 281 | ExtendedType: (*LegacyTestMessage)(nil), |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 282 | ExtensionType: ([]uint32)(nil), |
| 283 | Field: 10012, |
| 284 | Name: "fizz.buzz.repeated_uint32", |
| 285 | Tag: "varint,10012,rep,name=repeated_uint32", |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 286 | Filename: "test.proto", |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 287 | }, { |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 288 | ExtendedType: (*LegacyTestMessage)(nil), |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 289 | ExtensionType: ([]float32)(nil), |
| 290 | Field: 10013, |
| 291 | Name: "fizz.buzz.repeated_float", |
| 292 | Tag: "fixed32,10013,rep,name=repeated_float", |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 293 | Filename: "test.proto", |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 294 | }, { |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 295 | ExtendedType: (*LegacyTestMessage)(nil), |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 296 | ExtensionType: ([]string)(nil), |
| 297 | Field: 10014, |
| 298 | Name: "fizz.buzz.repeated_string", |
| 299 | Tag: "bytes,10014,rep,name=repeated_string", |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 300 | Filename: "test.proto", |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 301 | }, { |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 302 | ExtendedType: (*LegacyTestMessage)(nil), |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 303 | ExtensionType: ([][]byte)(nil), |
| 304 | Field: 10015, |
| 305 | Name: "fizz.buzz.repeated_bytes", |
| 306 | Tag: "bytes,10015,rep,name=repeated_bytes", |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 307 | Filename: "test.proto", |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 308 | }, { |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 309 | ExtendedType: (*LegacyTestMessage)(nil), |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 310 | ExtensionType: ([]proto2_20180125.Message_ChildEnum)(nil), |
| 311 | Field: 10016, |
| 312 | Name: "fizz.buzz.repeated_enum_v1", |
| 313 | Tag: "varint,10016,rep,name=repeated_enum_v1,enum=google.golang.org.proto2_20180125.Message_ChildEnum", |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 314 | Filename: "test.proto", |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 315 | }, { |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 316 | ExtendedType: (*LegacyTestMessage)(nil), |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 317 | ExtensionType: ([]*proto2_20180125.Message_ChildMessage)(nil), |
| 318 | Field: 10017, |
| 319 | Name: "fizz.buzz.repeated_message_v1", |
| 320 | Tag: "bytes,10017,rep,name=repeated_message_v1", |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 321 | Filename: "test.proto", |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 322 | }, { |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 323 | ExtendedType: (*LegacyTestMessage)(nil), |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 324 | ExtensionType: ([]EnumProto2)(nil), |
| 325 | Field: 10018, |
| 326 | Name: "fizz.buzz.repeated_enum_v2", |
| 327 | Tag: "varint,10018,rep,name=repeated_enum_v2,enum=EnumProto2", |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 328 | Filename: "test.proto", |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 329 | }, { |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 330 | ExtendedType: (*LegacyTestMessage)(nil), |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 331 | ExtensionType: ([]*EnumMessages)(nil), |
| 332 | Field: 10019, |
| 333 | Name: "fizz.buzz.repeated_message_v2", |
| 334 | Tag: "bytes,10019,rep,name=repeated_message_v2", |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 335 | Filename: "test.proto", |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 336 | }} |
| 337 | ) |
| 338 | |
| 339 | func TestLegacyExtensions(t *testing.T) { |
Joe Tsai | f0c01e4 | 2018-11-06 13:05:20 -0800 | [diff] [blame] | 340 | opts := cmp.Options{cmp.Comparer(func(x, y *proto2_20180125.Message_ChildMessage) bool { |
| 341 | return x == y // pointer compare messages for object identity |
| 342 | })} |
| 343 | |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 344 | m := pimpl.Export{}.MessageOf(new(LegacyTestMessage)) |
Joe Tsai | f0c01e4 | 2018-11-06 13:05:20 -0800 | [diff] [blame] | 345 | |
Joe Tsai | f0c01e4 | 2018-11-06 13:05:20 -0800 | [diff] [blame] | 346 | // Check that getting the zero value returns the default value for scalars, |
Joe Tsai | 4b7aff6 | 2018-11-14 14:05:19 -0800 | [diff] [blame] | 347 | // nil for singular messages, and an empty list for repeated fields. |
Joe Tsai | 378c132 | 2019-04-25 23:48:08 -0700 | [diff] [blame] | 348 | defaultValues := map[int]interface{}{ |
| 349 | 0: bool(true), |
| 350 | 1: int32(-12345), |
| 351 | 2: uint32(3200), |
| 352 | 3: float32(3.14159), |
| 353 | 4: string("hello, \"world!\"\n"), |
| 354 | 5: []byte("dead\xde\xad\xbe\xefbeef"), |
| 355 | 6: proto2_20180125.Message_ALPHA, |
| 356 | 7: nil, |
| 357 | 8: EnumProto2(0xdead), |
| 358 | 9: nil, |
Joe Tsai | f0c01e4 | 2018-11-06 13:05:20 -0800 | [diff] [blame] | 359 | } |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 360 | for i, xt := range extensionTypes { |
Joe Tsai | f0c01e4 | 2018-11-06 13:05:20 -0800 | [diff] [blame] | 361 | var got interface{} |
Damien Neil | 79bfdbe | 2019-08-28 11:08:22 -0700 | [diff] [blame] | 362 | xd := xt.TypeDescriptor() |
Damien Neil | 92f7618 | 2019-08-02 16:58:08 -0700 | [diff] [blame] | 363 | if !(xd.IsList() || xd.IsMap() || xd.Message() != nil) { |
| 364 | got = xt.InterfaceOf(m.Get(xd)) |
Joe Tsai | f0c01e4 | 2018-11-06 13:05:20 -0800 | [diff] [blame] | 365 | } |
| 366 | want := defaultValues[i] |
| 367 | if diff := cmp.Diff(want, got, opts); diff != "" { |
Damien Neil | 92f7618 | 2019-08-02 16:58:08 -0700 | [diff] [blame] | 368 | t.Errorf("Message.Get(%d) mismatch (-want +got):\n%v", xd.Number(), diff) |
Joe Tsai | f0c01e4 | 2018-11-06 13:05:20 -0800 | [diff] [blame] | 369 | } |
| 370 | } |
| 371 | |
| 372 | // All fields should be unpopulated. |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 373 | for _, xt := range extensionTypes { |
Damien Neil | 79bfdbe | 2019-08-28 11:08:22 -0700 | [diff] [blame] | 374 | xd := xt.TypeDescriptor() |
Damien Neil | 92f7618 | 2019-08-02 16:58:08 -0700 | [diff] [blame] | 375 | if m.Has(xd) { |
| 376 | t.Errorf("Message.Has(%d) = true, want false", xd.Number()) |
Joe Tsai | f0c01e4 | 2018-11-06 13:05:20 -0800 | [diff] [blame] | 377 | } |
| 378 | } |
| 379 | |
Joe Tsai | 4b7aff6 | 2018-11-14 14:05:19 -0800 | [diff] [blame] | 380 | // Set some values and append to values to the lists. |
Damien Neil | a8a2cea | 2019-07-10 16:17:16 -0700 | [diff] [blame] | 381 | m1a := &proto2_20180125.Message_ChildMessage{F1: proto.String("m1a")} |
| 382 | m1b := &proto2_20180125.Message_ChildMessage{F1: proto.String("m2b")} |
Joe Tsai | 87b955b | 2018-11-14 21:59:49 -0800 | [diff] [blame] | 383 | m2a := &EnumMessages{EnumP2: EnumProto2(0x1b).Enum()} |
| 384 | m2b := &EnumMessages{EnumP2: EnumProto2(0x2b).Enum()} |
Joe Tsai | 378c132 | 2019-04-25 23:48:08 -0700 | [diff] [blame] | 385 | setValues := map[int]interface{}{ |
| 386 | 0: bool(false), |
| 387 | 1: int32(-54321), |
| 388 | 2: uint32(6400), |
| 389 | 3: float32(2.71828), |
| 390 | 4: string("goodbye, \"world!\"\n"), |
| 391 | 5: []byte("live\xde\xad\xbe\xefchicken"), |
| 392 | 6: proto2_20180125.Message_CHARLIE, |
| 393 | 7: m1a, |
| 394 | 8: EnumProto2(0xbeef), |
| 395 | 9: m2a, |
Damien Neil | 293dc76 | 2019-08-29 11:42:57 -0700 | [diff] [blame] | 396 | 10: []bool{true}, |
| 397 | 11: []int32{-1000}, |
| 398 | 12: []uint32{1280}, |
| 399 | 13: []float32{1.6180}, |
| 400 | 14: []string{"zero"}, |
| 401 | 15: [][]byte{[]byte("zero")}, |
| 402 | 16: []proto2_20180125.Message_ChildEnum{proto2_20180125.Message_BRAVO}, |
| 403 | 17: []*proto2_20180125.Message_ChildMessage{m1b}, |
| 404 | 18: []EnumProto2{0xdead}, |
| 405 | 19: []*EnumMessages{m2b}, |
Joe Tsai | f0c01e4 | 2018-11-06 13:05:20 -0800 | [diff] [blame] | 406 | } |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 407 | for i, xt := range extensionTypes { |
Damien Neil | 79bfdbe | 2019-08-28 11:08:22 -0700 | [diff] [blame] | 408 | m.Set(xt.TypeDescriptor(), xt.ValueOf(setValues[i])) |
Joe Tsai | f0c01e4 | 2018-11-06 13:05:20 -0800 | [diff] [blame] | 409 | } |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 410 | for i, xt := range extensionTypes[len(extensionTypes)/2:] { |
| 411 | v := extensionTypes[i].ValueOf(setValues[i]) |
Damien Neil | 79bfdbe | 2019-08-28 11:08:22 -0700 | [diff] [blame] | 412 | m.Get(xt.TypeDescriptor()).List().Append(v) |
Joe Tsai | f0c01e4 | 2018-11-06 13:05:20 -0800 | [diff] [blame] | 413 | } |
| 414 | |
| 415 | // Get the values and check for equality. |
Joe Tsai | 378c132 | 2019-04-25 23:48:08 -0700 | [diff] [blame] | 416 | getValues := map[int]interface{}{ |
| 417 | 0: bool(false), |
| 418 | 1: int32(-54321), |
| 419 | 2: uint32(6400), |
| 420 | 3: float32(2.71828), |
| 421 | 4: string("goodbye, \"world!\"\n"), |
| 422 | 5: []byte("live\xde\xad\xbe\xefchicken"), |
| 423 | 6: proto2_20180125.Message_ChildEnum(proto2_20180125.Message_CHARLIE), |
| 424 | 7: m1a, |
| 425 | 8: EnumProto2(0xbeef), |
| 426 | 9: m2a, |
Damien Neil | 293dc76 | 2019-08-29 11:42:57 -0700 | [diff] [blame] | 427 | 10: []bool{true, false}, |
| 428 | 11: []int32{-1000, -54321}, |
| 429 | 12: []uint32{1280, 6400}, |
| 430 | 13: []float32{1.6180, 2.71828}, |
| 431 | 14: []string{"zero", "goodbye, \"world!\"\n"}, |
| 432 | 15: [][]byte{[]byte("zero"), []byte("live\xde\xad\xbe\xefchicken")}, |
| 433 | 16: []proto2_20180125.Message_ChildEnum{proto2_20180125.Message_BRAVO, proto2_20180125.Message_CHARLIE}, |
| 434 | 17: []*proto2_20180125.Message_ChildMessage{m1b, m1a}, |
| 435 | 18: []EnumProto2{0xdead, 0xbeef}, |
| 436 | 19: []*EnumMessages{m2b, m2a}, |
Joe Tsai | f0c01e4 | 2018-11-06 13:05:20 -0800 | [diff] [blame] | 437 | } |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 438 | for i, xt := range extensionTypes { |
Damien Neil | 79bfdbe | 2019-08-28 11:08:22 -0700 | [diff] [blame] | 439 | xd := xt.TypeDescriptor() |
Damien Neil | 92f7618 | 2019-08-02 16:58:08 -0700 | [diff] [blame] | 440 | got := xt.InterfaceOf(m.Get(xd)) |
Joe Tsai | f0c01e4 | 2018-11-06 13:05:20 -0800 | [diff] [blame] | 441 | want := getValues[i] |
| 442 | if diff := cmp.Diff(want, got, opts); diff != "" { |
Damien Neil | 92f7618 | 2019-08-02 16:58:08 -0700 | [diff] [blame] | 443 | t.Errorf("Message.Get(%d) mismatch (-want +got):\n%v", xd.Number(), diff) |
Joe Tsai | f0c01e4 | 2018-11-06 13:05:20 -0800 | [diff] [blame] | 444 | } |
| 445 | } |
| 446 | |
Joe Tsai | 378c132 | 2019-04-25 23:48:08 -0700 | [diff] [blame] | 447 | // Clear all singular fields and truncate all repeated fields. |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 448 | for _, xt := range extensionTypes[:len(extensionTypes)/2] { |
Damien Neil | 79bfdbe | 2019-08-28 11:08:22 -0700 | [diff] [blame] | 449 | m.Clear(xt.TypeDescriptor()) |
Joe Tsai | f0c01e4 | 2018-11-06 13:05:20 -0800 | [diff] [blame] | 450 | } |
Joe Tsai | 378c132 | 2019-04-25 23:48:08 -0700 | [diff] [blame] | 451 | for _, xt := range extensionTypes[len(extensionTypes)/2:] { |
Damien Neil | 79bfdbe | 2019-08-28 11:08:22 -0700 | [diff] [blame] | 452 | m.Get(xt.TypeDescriptor()).List().Truncate(0) |
Joe Tsai | f6d4a42 | 2018-11-19 14:26:06 -0800 | [diff] [blame] | 453 | } |
Joe Tsai | f0c01e4 | 2018-11-06 13:05:20 -0800 | [diff] [blame] | 454 | |
Joe Tsai | 378c132 | 2019-04-25 23:48:08 -0700 | [diff] [blame] | 455 | // Clear all repeated fields. |
| 456 | for _, xt := range extensionTypes[len(extensionTypes)/2:] { |
Damien Neil | 79bfdbe | 2019-08-28 11:08:22 -0700 | [diff] [blame] | 457 | m.Clear(xt.TypeDescriptor()) |
Joe Tsai | f0c01e4 | 2018-11-06 13:05:20 -0800 | [diff] [blame] | 458 | } |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 459 | } |
Joe Tsai | f0c01e4 | 2018-11-06 13:05:20 -0800 | [diff] [blame] | 460 | |
Joe Tsai | fd4c605 | 2019-09-16 13:30:15 -0700 | [diff] [blame] | 461 | func TestLegacyExtensionConvert(t *testing.T) { |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 462 | for i := range extensionTypes { |
| 463 | i := i |
| 464 | t.Run("", func(t *testing.T) { |
| 465 | t.Parallel() |
| 466 | |
| 467 | wantType := extensionTypes[i] |
| 468 | wantDesc := extensionDescs[i] |
Damien Neil | f1e905b | 2019-08-08 15:45:59 -0700 | [diff] [blame] | 469 | gotType := (pref.ExtensionType)(wantDesc) |
Joe Tsai | fd4c605 | 2019-09-16 13:30:15 -0700 | [diff] [blame] | 470 | gotDesc := wantType.(*pimpl.ExtensionInfo) |
| 471 | |
| 472 | // Concurrently call accessors to trigger possible races. |
| 473 | for _, xt := range []pref.ExtensionType{wantType, wantDesc} { |
| 474 | xt := xt |
| 475 | go func() { xt.New() }() |
| 476 | go func() { xt.Zero() }() |
Joe Tsai | fd4c605 | 2019-09-16 13:30:15 -0700 | [diff] [blame] | 477 | go func() { xt.TypeDescriptor() }() |
| 478 | } |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 479 | |
| 480 | // TODO: We need a test package to compare descriptors. |
| 481 | type list interface { |
| 482 | Len() int |
| 483 | pragma.DoNotImplement |
| 484 | } |
| 485 | opts := cmp.Options{ |
| 486 | cmp.Comparer(func(x, y reflect.Type) bool { |
| 487 | return x == y |
| 488 | }), |
| 489 | cmp.Transformer("", func(x list) []interface{} { |
| 490 | out := make([]interface{}, x.Len()) |
| 491 | v := reflect.ValueOf(x) |
| 492 | for i := 0; i < x.Len(); i++ { |
| 493 | m := v.MethodByName("Get") |
| 494 | out[i] = m.Call([]reflect.Value{reflect.ValueOf(i)})[0].Interface() |
| 495 | } |
| 496 | return out |
| 497 | }), |
| 498 | cmp.Transformer("", func(x pref.Descriptor) map[string]interface{} { |
| 499 | out := make(map[string]interface{}) |
| 500 | v := reflect.ValueOf(x) |
| 501 | for i := 0; i < v.NumMethod(); i++ { |
| 502 | name := v.Type().Method(i).Name |
| 503 | if m := v.Method(i); m.Type().NumIn() == 0 && m.Type().NumOut() == 1 { |
| 504 | switch name { |
Joe Tsai | a93fdf5 | 2019-05-08 18:50:41 -0700 | [diff] [blame] | 505 | case "ParentFile", "Parent": |
| 506 | // Ignore parents to avoid recursive cycle. |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 507 | case "Options": |
| 508 | // Ignore descriptor options since protos are not cmperable. |
Joe Tsai | ac31a35 | 2019-05-13 14:32:56 -0700 | [diff] [blame] | 509 | case "ContainingOneof", "ContainingMessage", "Enum", "Message": |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 510 | // Avoid descending into a dependency to avoid a cycle. |
| 511 | // Just record the full name if available. |
| 512 | // |
| 513 | // TODO: Cycle support in cmp would be useful here. |
| 514 | v := m.Call(nil)[0] |
| 515 | if !v.IsNil() { |
| 516 | out[name] = v.Interface().(pref.Descriptor).FullName() |
| 517 | } |
Damien Neil | 92f7618 | 2019-08-02 16:58:08 -0700 | [diff] [blame] | 518 | case "Type": |
| 519 | // Ignore ExtensionTypeDescriptor.Type method to avoid cycle. |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 520 | default: |
| 521 | out[name] = m.Call(nil)[0].Interface() |
| 522 | } |
| 523 | } |
| 524 | } |
| 525 | return out |
| 526 | }), |
Damien Neil | 92f7618 | 2019-08-02 16:58:08 -0700 | [diff] [blame] | 527 | cmp.Transformer("", func(xt pref.ExtensionType) map[string]interface{} { |
| 528 | return map[string]interface{}{ |
Damien Neil | 79bfdbe | 2019-08-28 11:08:22 -0700 | [diff] [blame] | 529 | "Descriptor": xt.TypeDescriptor(), |
Damien Neil | 92f7618 | 2019-08-02 16:58:08 -0700 | [diff] [blame] | 530 | } |
| 531 | }), |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 532 | cmp.Transformer("", func(v pref.Value) interface{} { |
| 533 | return v.Interface() |
| 534 | }), |
| 535 | } |
| 536 | if diff := cmp.Diff(&wantType, &gotType, opts); diff != "" { |
| 537 | t.Errorf("ExtensionType mismatch (-want, +got):\n%v", diff) |
| 538 | } |
| 539 | |
| 540 | opts = cmp.Options{ |
Damien Neil | f1e905b | 2019-08-08 15:45:59 -0700 | [diff] [blame] | 541 | cmpopts.IgnoreFields(pimpl.ExtensionInfo{}, "ExtensionType"), |
| 542 | cmpopts.IgnoreUnexported(pimpl.ExtensionInfo{}), |
Joe Tsai | 08e0030 | 2018-11-26 22:32:06 -0800 | [diff] [blame] | 543 | } |
| 544 | if diff := cmp.Diff(wantDesc, gotDesc, opts); diff != "" { |
| 545 | t.Errorf("ExtensionDesc mismatch (-want, +got):\n%v", diff) |
| 546 | } |
| 547 | }) |
| 548 | } |
Joe Tsai | f0c01e4 | 2018-11-06 13:05:20 -0800 | [diff] [blame] | 549 | } |
Joe Tsai | 21ade49 | 2019-05-22 13:42:54 -0400 | [diff] [blame] | 550 | |
| 551 | type ( |
| 552 | MessageA struct { |
| 553 | A1 *MessageA `protobuf:"bytes,1,req,name=a1"` |
| 554 | A2 *MessageB `protobuf:"bytes,2,req,name=a2"` |
| 555 | A3 Enum `protobuf:"varint,3,opt,name=a3,enum=legacy.Enum"` |
| 556 | } |
| 557 | MessageB struct { |
| 558 | B1 *MessageA `protobuf:"bytes,1,req,name=b1"` |
| 559 | B2 *MessageB `protobuf:"bytes,2,req,name=b2"` |
| 560 | B3 Enum `protobuf:"varint,3,opt,name=b3,enum=legacy.Enum"` |
| 561 | } |
| 562 | Enum int32 |
| 563 | ) |
| 564 | |
Joe Tsai | 6663f3a | 2019-09-03 15:33:00 -0700 | [diff] [blame] | 565 | func (*MessageA) Reset() { panic("not implemented") } |
| 566 | func (*MessageA) String() string { panic("not implemented") } |
| 567 | func (*MessageA) ProtoMessage() { panic("not implemented") } |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 568 | func (*MessageA) Descriptor() ([]byte, []int) { return concurrentFD, []int{0} } |
Joe Tsai | 6663f3a | 2019-09-03 15:33:00 -0700 | [diff] [blame] | 569 | |
| 570 | func (*MessageB) Reset() { panic("not implemented") } |
| 571 | func (*MessageB) String() string { panic("not implemented") } |
| 572 | func (*MessageB) ProtoMessage() { panic("not implemented") } |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 573 | func (*MessageB) Descriptor() ([]byte, []int) { return concurrentFD, []int{1} } |
Joe Tsai | 6663f3a | 2019-09-03 15:33:00 -0700 | [diff] [blame] | 574 | |
| 575 | func (Enum) EnumDescriptor() ([]byte, []int) { return concurrentFD, []int{0} } |
Joe Tsai | d888139 | 2019-06-06 13:01:53 -0700 | [diff] [blame] | 576 | |
| 577 | var concurrentFD = func() []byte { |
| 578 | b, _ := proto.Marshal(pdesc.ToFileDescriptorProto(mustMakeFileDesc(` |
| 579 | name: "concurrent.proto" |
| 580 | syntax: "proto2" |
| 581 | package: "legacy" |
| 582 | message_type: [{ |
| 583 | name: "MessageA" |
| 584 | field: [ |
| 585 | {name:"a1" number:1 label:LABEL_REQUIRED type:TYPE_MESSAGE type_name:".legacy.MessageA"}, |
| 586 | {name:"a2" number:2 label:LABEL_REQUIRED type:TYPE_MESSAGE type_name:".legacy.MessageB"}, |
| 587 | {name:"a3" number:3 label:LABEL_OPTIONAL type:TYPE_ENUM type_name:".legacy.Enum"} |
| 588 | ] |
| 589 | }, { |
| 590 | name: "MessageB" |
| 591 | field: [ |
| 592 | {name:"a1" number:1 label:LABEL_REQUIRED type:TYPE_MESSAGE type_name:".legacy.MessageA"}, |
| 593 | {name:"a2" number:2 label:LABEL_REQUIRED type:TYPE_MESSAGE type_name:".legacy.MessageB"}, |
| 594 | {name:"a3" number:3 label:LABEL_OPTIONAL type:TYPE_ENUM type_name:".legacy.Enum"} |
| 595 | ] |
| 596 | }] |
| 597 | enum_type: [{ |
| 598 | name: "Enum" |
| 599 | value: [{name:"FOO" number:500}] |
| 600 | }] |
| 601 | `, nil))) |
| 602 | return pimpl.Export{}.CompressGZIP(b) |
| 603 | }() |
| 604 | |
Joe Tsai | fd4c605 | 2019-09-16 13:30:15 -0700 | [diff] [blame] | 605 | // TestLegacyConcurrentInit tests that concurrent wrapping of multiple legacy types |
Joe Tsai | 21ade49 | 2019-05-22 13:42:54 -0400 | [diff] [blame] | 606 | // results in the exact same descriptor being created. |
Joe Tsai | fd4c605 | 2019-09-16 13:30:15 -0700 | [diff] [blame] | 607 | func TestLegacyConcurrentInit(t *testing.T) { |
Joe Tsai | 21ade49 | 2019-05-22 13:42:54 -0400 | [diff] [blame] | 608 | const numParallel = 5 |
| 609 | var messageATypes [numParallel]pref.MessageType |
| 610 | var messageBTypes [numParallel]pref.MessageType |
| 611 | var enumDescs [numParallel]pref.EnumDescriptor |
| 612 | |
| 613 | // Concurrently load message and enum types. |
| 614 | var wg sync.WaitGroup |
| 615 | for i := 0; i < numParallel; i++ { |
| 616 | i := i |
| 617 | wg.Add(3) |
| 618 | go func() { |
| 619 | defer wg.Done() |
| 620 | messageATypes[i] = pimpl.Export{}.MessageTypeOf((*MessageA)(nil)) |
| 621 | }() |
| 622 | go func() { |
| 623 | defer wg.Done() |
| 624 | messageBTypes[i] = pimpl.Export{}.MessageTypeOf((*MessageB)(nil)) |
| 625 | }() |
| 626 | go func() { |
| 627 | defer wg.Done() |
| 628 | enumDescs[i] = pimpl.Export{}.EnumDescriptorOf(Enum(0)) |
| 629 | }() |
| 630 | } |
| 631 | wg.Wait() |
| 632 | |
| 633 | var ( |
| 634 | wantMTA = messageATypes[0] |
Damien Neil | 92f7618 | 2019-08-02 16:58:08 -0700 | [diff] [blame] | 635 | wantMDA = messageATypes[0].Descriptor().Fields().ByNumber(1).Message() |
Joe Tsai | 21ade49 | 2019-05-22 13:42:54 -0400 | [diff] [blame] | 636 | wantMTB = messageBTypes[0] |
Damien Neil | 92f7618 | 2019-08-02 16:58:08 -0700 | [diff] [blame] | 637 | wantMDB = messageBTypes[0].Descriptor().Fields().ByNumber(2).Message() |
| 638 | wantED = messageATypes[0].Descriptor().Fields().ByNumber(3).Enum() |
Joe Tsai | 21ade49 | 2019-05-22 13:42:54 -0400 | [diff] [blame] | 639 | ) |
| 640 | |
| 641 | for _, gotMT := range messageATypes[1:] { |
| 642 | if gotMT != wantMTA { |
| 643 | t.Error("MessageType(MessageA) mismatch") |
| 644 | } |
Damien Neil | 92f7618 | 2019-08-02 16:58:08 -0700 | [diff] [blame] | 645 | if gotMDA := gotMT.Descriptor().Fields().ByNumber(1).Message(); gotMDA != wantMDA { |
Joe Tsai | 21ade49 | 2019-05-22 13:42:54 -0400 | [diff] [blame] | 646 | t.Error("MessageDescriptor(MessageA) mismatch") |
| 647 | } |
Damien Neil | 92f7618 | 2019-08-02 16:58:08 -0700 | [diff] [blame] | 648 | if gotMDB := gotMT.Descriptor().Fields().ByNumber(2).Message(); gotMDB != wantMDB { |
Joe Tsai | 21ade49 | 2019-05-22 13:42:54 -0400 | [diff] [blame] | 649 | t.Error("MessageDescriptor(MessageB) mismatch") |
| 650 | } |
Damien Neil | 92f7618 | 2019-08-02 16:58:08 -0700 | [diff] [blame] | 651 | if gotED := gotMT.Descriptor().Fields().ByNumber(3).Enum(); gotED != wantED { |
Joe Tsai | 21ade49 | 2019-05-22 13:42:54 -0400 | [diff] [blame] | 652 | t.Error("EnumDescriptor(Enum) mismatch") |
| 653 | } |
| 654 | } |
| 655 | for _, gotMT := range messageBTypes[1:] { |
| 656 | if gotMT != wantMTB { |
| 657 | t.Error("MessageType(MessageB) mismatch") |
| 658 | } |
Damien Neil | 92f7618 | 2019-08-02 16:58:08 -0700 | [diff] [blame] | 659 | if gotMDA := gotMT.Descriptor().Fields().ByNumber(1).Message(); gotMDA != wantMDA { |
Joe Tsai | 21ade49 | 2019-05-22 13:42:54 -0400 | [diff] [blame] | 660 | t.Error("MessageDescriptor(MessageA) mismatch") |
| 661 | } |
Damien Neil | 92f7618 | 2019-08-02 16:58:08 -0700 | [diff] [blame] | 662 | if gotMDB := gotMT.Descriptor().Fields().ByNumber(2).Message(); gotMDB != wantMDB { |
Joe Tsai | 21ade49 | 2019-05-22 13:42:54 -0400 | [diff] [blame] | 663 | t.Error("MessageDescriptor(MessageB) mismatch") |
| 664 | } |
Damien Neil | 92f7618 | 2019-08-02 16:58:08 -0700 | [diff] [blame] | 665 | if gotED := gotMT.Descriptor().Fields().ByNumber(3).Enum(); gotED != wantED { |
Joe Tsai | 21ade49 | 2019-05-22 13:42:54 -0400 | [diff] [blame] | 666 | t.Error("EnumDescriptor(Enum) mismatch") |
| 667 | } |
| 668 | } |
| 669 | for _, gotED := range enumDescs[1:] { |
| 670 | if gotED != wantED { |
| 671 | t.Error("EnumType(Enum) mismatch") |
| 672 | } |
| 673 | } |
| 674 | } |
Joe Tsai | ea5ada1 | 2019-09-04 22:41:40 -0700 | [diff] [blame] | 675 | |
| 676 | type LegacyTestMessageName1 struct{} |
| 677 | |
| 678 | func (*LegacyTestMessageName1) Reset() { panic("not implemented") } |
| 679 | func (*LegacyTestMessageName1) String() string { panic("not implemented") } |
| 680 | func (*LegacyTestMessageName1) ProtoMessage() { panic("not implemented") } |
| 681 | |
| 682 | type LegacyTestMessageName2 struct{} |
| 683 | |
| 684 | func (*LegacyTestMessageName2) Reset() { panic("not implemented") } |
| 685 | func (*LegacyTestMessageName2) String() string { panic("not implemented") } |
| 686 | func (*LegacyTestMessageName2) ProtoMessage() { panic("not implemented") } |
| 687 | func (*LegacyTestMessageName2) XXX_MessageName() string { |
| 688 | return "google.golang.org.LegacyTestMessageName2" |
| 689 | } |
| 690 | |
| 691 | func TestLegacyMessageName(t *testing.T) { |
| 692 | tests := []struct { |
| 693 | in piface.MessageV1 |
| 694 | suggestName pref.FullName |
| 695 | wantName pref.FullName |
| 696 | }{ |
| 697 | {new(LegacyTestMessageName1), "google.golang.org.LegacyTestMessageName1", "google.golang.org.LegacyTestMessageName1"}, |
| 698 | {new(LegacyTestMessageName2), "", "google.golang.org.LegacyTestMessageName2"}, |
| 699 | } |
| 700 | |
| 701 | for _, tt := range tests { |
| 702 | mt := pimpl.Export{}.LegacyMessageTypeOf(tt.in, tt.suggestName) |
| 703 | if got := mt.Descriptor().FullName(); got != tt.wantName { |
| 704 | t.Errorf("type: %T, name mismatch: got %v, want %v", tt.in, got, tt.wantName) |
| 705 | } |
| 706 | } |
| 707 | } |