| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953 |
- // 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
- import (
- "bytes"
- "math"
- "reflect"
- "testing"
- protoV1 "github.com/golang/protobuf/proto"
- pack "github.com/golang/protobuf/v2/internal/encoding/pack"
- pragma "github.com/golang/protobuf/v2/internal/pragma"
- scalar "github.com/golang/protobuf/v2/internal/scalar"
- pref "github.com/golang/protobuf/v2/reflect/protoreflect"
- ptype "github.com/golang/protobuf/v2/reflect/prototype"
- cmp "github.com/google/go-cmp/cmp"
- proto2_20160225 "github.com/golang/protobuf/v2/internal/testprotos/legacy/proto2.v0.0.0-20160225-2fc053c5"
- proto2_20160519 "github.com/golang/protobuf/v2/internal/testprotos/legacy/proto2.v0.0.0-20160519-a4ab9ec5"
- proto2_20180125 "github.com/golang/protobuf/v2/internal/testprotos/legacy/proto2.v1.0.0-20180125-92554152"
- proto2_20180430 "github.com/golang/protobuf/v2/internal/testprotos/legacy/proto2.v1.1.0-20180430-b4deda09"
- proto2_20180814 "github.com/golang/protobuf/v2/internal/testprotos/legacy/proto2.v1.2.0-20180814-aa810b61"
- proto3_20160225 "github.com/golang/protobuf/v2/internal/testprotos/legacy/proto3.v0.0.0-20160225-2fc053c5"
- proto3_20160519 "github.com/golang/protobuf/v2/internal/testprotos/legacy/proto3.v0.0.0-20160519-a4ab9ec5"
- proto3_20180125 "github.com/golang/protobuf/v2/internal/testprotos/legacy/proto3.v1.0.0-20180125-92554152"
- proto3_20180430 "github.com/golang/protobuf/v2/internal/testprotos/legacy/proto3.v1.1.0-20180430-b4deda09"
- proto3_20180814 "github.com/golang/protobuf/v2/internal/testprotos/legacy/proto3.v1.2.0-20180814-aa810b61"
- )
- func mustLoadFileDesc(b []byte, _ []int) pref.FileDescriptor {
- fd, err := ptype.NewFileFromDescriptorProto(legacyLoadFileDesc(b), nil)
- if err != nil {
- panic(err)
- }
- return fd
- }
- func TestLegacyDescriptor(t *testing.T) {
- var tests []struct{ got, want pref.Descriptor }
- fileDescP2_20160225 := mustLoadFileDesc(new(proto2_20160225.Message).Descriptor())
- tests = append(tests, []struct{ got, want pref.Descriptor }{{
- got: legacyLoadEnumDesc(reflect.TypeOf(proto2_20160225.SiblingEnum(0))),
- want: fileDescP2_20160225.Enums().ByName("SiblingEnum"),
- }, {
- got: legacyLoadEnumDesc(reflect.TypeOf(proto2_20160225.Message_ChildEnum(0))),
- want: fileDescP2_20160225.Messages().ByName("Message").Enums().ByName("ChildEnum"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto2_20160225.SiblingMessage))),
- want: fileDescP2_20160225.Messages().ByName("SiblingMessage"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto2_20160225.Message_ChildMessage))),
- want: fileDescP2_20160225.Messages().ByName("Message").Messages().ByName("ChildMessage"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto2_20160225.Message))),
- want: fileDescP2_20160225.Messages().ByName("Message"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto2_20160225.Message_NamedGroup))),
- want: fileDescP2_20160225.Messages().ByName("Message").Messages().ByName("NamedGroup"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto2_20160225.Message_OptionalGroup))),
- want: fileDescP2_20160225.Messages().ByName("Message").Messages().ByName("OptionalGroup"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto2_20160225.Message_RequiredGroup))),
- want: fileDescP2_20160225.Messages().ByName("Message").Messages().ByName("RequiredGroup"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto2_20160225.Message_RepeatedGroup))),
- want: fileDescP2_20160225.Messages().ByName("Message").Messages().ByName("RepeatedGroup"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto2_20160225.Message_OneofGroup))),
- want: fileDescP2_20160225.Messages().ByName("Message").Messages().ByName("OneofGroup"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto2_20160225.Message_ExtensionOptionalGroup))),
- want: fileDescP2_20160225.Messages().ByName("Message").Messages().ByName("ExtensionOptionalGroup"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto2_20160225.Message_ExtensionRepeatedGroup))),
- want: fileDescP2_20160225.Messages().ByName("Message").Messages().ByName("ExtensionRepeatedGroup"),
- }}...)
- fileDescP3_20160225 := mustLoadFileDesc(new(proto3_20160225.Message).Descriptor())
- tests = append(tests, []struct{ got, want pref.Descriptor }{{
- got: legacyLoadEnumDesc(reflect.TypeOf(proto3_20160225.SiblingEnum(0))),
- want: fileDescP3_20160225.Enums().ByName("SiblingEnum"),
- }, {
- got: legacyLoadEnumDesc(reflect.TypeOf(proto3_20160225.Message_ChildEnum(0))),
- want: fileDescP3_20160225.Messages().ByName("Message").Enums().ByName("ChildEnum"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto3_20160225.SiblingMessage))),
- want: fileDescP3_20160225.Messages().ByName("SiblingMessage"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto3_20160225.Message_ChildMessage))),
- want: fileDescP3_20160225.Messages().ByName("Message").Messages().ByName("ChildMessage"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto3_20160225.Message))),
- want: fileDescP3_20160225.Messages().ByName("Message"),
- }}...)
- fileDescP2_20160519 := mustLoadFileDesc(new(proto2_20160519.Message).Descriptor())
- tests = append(tests, []struct{ got, want pref.Descriptor }{{
- got: legacyLoadEnumDesc(reflect.TypeOf(proto2_20160519.SiblingEnum(0))),
- want: fileDescP2_20160519.Enums().ByName("SiblingEnum"),
- }, {
- got: legacyLoadEnumDesc(reflect.TypeOf(proto2_20160519.Message_ChildEnum(0))),
- want: fileDescP2_20160519.Messages().ByName("Message").Enums().ByName("ChildEnum"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto2_20160519.SiblingMessage))),
- want: fileDescP2_20160519.Messages().ByName("SiblingMessage"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto2_20160519.Message_ChildMessage))),
- want: fileDescP2_20160519.Messages().ByName("Message").Messages().ByName("ChildMessage"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto2_20160519.Message))),
- want: fileDescP2_20160519.Messages().ByName("Message"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto2_20160519.Message_NamedGroup))),
- want: fileDescP2_20160519.Messages().ByName("Message").Messages().ByName("NamedGroup"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto2_20160519.Message_OptionalGroup))),
- want: fileDescP2_20160519.Messages().ByName("Message").Messages().ByName("OptionalGroup"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto2_20160519.Message_RequiredGroup))),
- want: fileDescP2_20160519.Messages().ByName("Message").Messages().ByName("RequiredGroup"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto2_20160519.Message_RepeatedGroup))),
- want: fileDescP2_20160519.Messages().ByName("Message").Messages().ByName("RepeatedGroup"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto2_20160519.Message_OneofGroup))),
- want: fileDescP2_20160519.Messages().ByName("Message").Messages().ByName("OneofGroup"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto2_20160519.Message_ExtensionOptionalGroup))),
- want: fileDescP2_20160519.Messages().ByName("Message").Messages().ByName("ExtensionOptionalGroup"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto2_20160519.Message_ExtensionRepeatedGroup))),
- want: fileDescP2_20160519.Messages().ByName("Message").Messages().ByName("ExtensionRepeatedGroup"),
- }}...)
- fileDescP3_20160519 := mustLoadFileDesc(new(proto3_20160519.Message).Descriptor())
- tests = append(tests, []struct{ got, want pref.Descriptor }{{
- got: legacyLoadEnumDesc(reflect.TypeOf(proto3_20160519.SiblingEnum(0))),
- want: fileDescP3_20160519.Enums().ByName("SiblingEnum"),
- }, {
- got: legacyLoadEnumDesc(reflect.TypeOf(proto3_20160519.Message_ChildEnum(0))),
- want: fileDescP3_20160519.Messages().ByName("Message").Enums().ByName("ChildEnum"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto3_20160519.SiblingMessage))),
- want: fileDescP3_20160519.Messages().ByName("SiblingMessage"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto3_20160519.Message_ChildMessage))),
- want: fileDescP3_20160519.Messages().ByName("Message").Messages().ByName("ChildMessage"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto3_20160519.Message))),
- want: fileDescP3_20160519.Messages().ByName("Message"),
- }}...)
- fileDescP2_20180125 := mustLoadFileDesc(new(proto2_20180125.Message).Descriptor())
- tests = append(tests, []struct{ got, want pref.Descriptor }{{
- got: legacyLoadEnumDesc(reflect.TypeOf(proto2_20180125.SiblingEnum(0))),
- want: fileDescP2_20180125.Enums().ByName("SiblingEnum"),
- }, {
- got: legacyLoadEnumDesc(reflect.TypeOf(proto2_20180125.Message_ChildEnum(0))),
- want: fileDescP2_20180125.Messages().ByName("Message").Enums().ByName("ChildEnum"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto2_20180125.SiblingMessage))),
- want: fileDescP2_20180125.Messages().ByName("SiblingMessage"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto2_20180125.Message_ChildMessage))),
- want: fileDescP2_20180125.Messages().ByName("Message").Messages().ByName("ChildMessage"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto2_20180125.Message))),
- want: fileDescP2_20180125.Messages().ByName("Message"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto2_20180125.Message_NamedGroup))),
- want: fileDescP2_20180125.Messages().ByName("Message").Messages().ByName("NamedGroup"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto2_20180125.Message_OptionalGroup))),
- want: fileDescP2_20180125.Messages().ByName("Message").Messages().ByName("OptionalGroup"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto2_20180125.Message_RequiredGroup))),
- want: fileDescP2_20180125.Messages().ByName("Message").Messages().ByName("RequiredGroup"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto2_20180125.Message_RepeatedGroup))),
- want: fileDescP2_20180125.Messages().ByName("Message").Messages().ByName("RepeatedGroup"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto2_20180125.Message_OneofGroup))),
- want: fileDescP2_20180125.Messages().ByName("Message").Messages().ByName("OneofGroup"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto2_20180125.Message_ExtensionOptionalGroup))),
- want: fileDescP2_20180125.Messages().ByName("Message").Messages().ByName("ExtensionOptionalGroup"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto2_20180125.Message_ExtensionRepeatedGroup))),
- want: fileDescP2_20180125.Messages().ByName("Message").Messages().ByName("ExtensionRepeatedGroup"),
- }}...)
- fileDescP3_20180125 := mustLoadFileDesc(new(proto3_20180125.Message).Descriptor())
- tests = append(tests, []struct{ got, want pref.Descriptor }{{
- got: legacyLoadEnumDesc(reflect.TypeOf(proto3_20180125.SiblingEnum(0))),
- want: fileDescP3_20180125.Enums().ByName("SiblingEnum"),
- }, {
- got: legacyLoadEnumDesc(reflect.TypeOf(proto3_20180125.Message_ChildEnum(0))),
- want: fileDescP3_20180125.Messages().ByName("Message").Enums().ByName("ChildEnum"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto3_20180125.SiblingMessage))),
- want: fileDescP3_20180125.Messages().ByName("SiblingMessage"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto3_20180125.Message_ChildMessage))),
- want: fileDescP3_20180125.Messages().ByName("Message").Messages().ByName("ChildMessage"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto3_20180125.Message))),
- want: fileDescP3_20180125.Messages().ByName("Message"),
- }}...)
- fileDescP2_20180430 := mustLoadFileDesc(new(proto2_20180430.Message).Descriptor())
- tests = append(tests, []struct{ got, want pref.Descriptor }{{
- got: legacyLoadEnumDesc(reflect.TypeOf(proto2_20180430.SiblingEnum(0))),
- want: fileDescP2_20180430.Enums().ByName("SiblingEnum"),
- }, {
- got: legacyLoadEnumDesc(reflect.TypeOf(proto2_20180430.Message_ChildEnum(0))),
- want: fileDescP2_20180430.Messages().ByName("Message").Enums().ByName("ChildEnum"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto2_20180430.SiblingMessage))),
- want: fileDescP2_20180430.Messages().ByName("SiblingMessage"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto2_20180430.Message_ChildMessage))),
- want: fileDescP2_20180430.Messages().ByName("Message").Messages().ByName("ChildMessage"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto2_20180430.Message))),
- want: fileDescP2_20180430.Messages().ByName("Message"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto2_20180430.Message_NamedGroup))),
- want: fileDescP2_20180430.Messages().ByName("Message").Messages().ByName("NamedGroup"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto2_20180430.Message_OptionalGroup))),
- want: fileDescP2_20180430.Messages().ByName("Message").Messages().ByName("OptionalGroup"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto2_20180430.Message_RequiredGroup))),
- want: fileDescP2_20180430.Messages().ByName("Message").Messages().ByName("RequiredGroup"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto2_20180430.Message_RepeatedGroup))),
- want: fileDescP2_20180430.Messages().ByName("Message").Messages().ByName("RepeatedGroup"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto2_20180430.Message_OneofGroup))),
- want: fileDescP2_20180430.Messages().ByName("Message").Messages().ByName("OneofGroup"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto2_20180430.Message_ExtensionOptionalGroup))),
- want: fileDescP2_20180430.Messages().ByName("Message").Messages().ByName("ExtensionOptionalGroup"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto2_20180430.Message_ExtensionRepeatedGroup))),
- want: fileDescP2_20180430.Messages().ByName("Message").Messages().ByName("ExtensionRepeatedGroup"),
- }}...)
- fileDescP3_20180430 := mustLoadFileDesc(new(proto3_20180430.Message).Descriptor())
- tests = append(tests, []struct{ got, want pref.Descriptor }{{
- got: legacyLoadEnumDesc(reflect.TypeOf(proto3_20180430.SiblingEnum(0))),
- want: fileDescP3_20180430.Enums().ByName("SiblingEnum"),
- }, {
- got: legacyLoadEnumDesc(reflect.TypeOf(proto3_20180430.Message_ChildEnum(0))),
- want: fileDescP3_20180430.Messages().ByName("Message").Enums().ByName("ChildEnum"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto3_20180430.SiblingMessage))),
- want: fileDescP3_20180430.Messages().ByName("SiblingMessage"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto3_20180430.Message_ChildMessage))),
- want: fileDescP3_20180430.Messages().ByName("Message").Messages().ByName("ChildMessage"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto3_20180430.Message))),
- want: fileDescP3_20180430.Messages().ByName("Message"),
- }}...)
- fileDescP2_20180814 := mustLoadFileDesc(new(proto2_20180814.Message).Descriptor())
- tests = append(tests, []struct{ got, want pref.Descriptor }{{
- got: legacyLoadEnumDesc(reflect.TypeOf(proto2_20180814.SiblingEnum(0))),
- want: fileDescP2_20180814.Enums().ByName("SiblingEnum"),
- }, {
- got: legacyLoadEnumDesc(reflect.TypeOf(proto2_20180814.Message_ChildEnum(0))),
- want: fileDescP2_20180814.Messages().ByName("Message").Enums().ByName("ChildEnum"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto2_20180814.SiblingMessage))),
- want: fileDescP2_20180814.Messages().ByName("SiblingMessage"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto2_20180814.Message_ChildMessage))),
- want: fileDescP2_20180814.Messages().ByName("Message").Messages().ByName("ChildMessage"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto2_20180814.Message))),
- want: fileDescP2_20180814.Messages().ByName("Message"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto2_20180814.Message_NamedGroup))),
- want: fileDescP2_20180814.Messages().ByName("Message").Messages().ByName("NamedGroup"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto2_20180814.Message_OptionalGroup))),
- want: fileDescP2_20180814.Messages().ByName("Message").Messages().ByName("OptionalGroup"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto2_20180814.Message_RequiredGroup))),
- want: fileDescP2_20180814.Messages().ByName("Message").Messages().ByName("RequiredGroup"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto2_20180814.Message_RepeatedGroup))),
- want: fileDescP2_20180814.Messages().ByName("Message").Messages().ByName("RepeatedGroup"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto2_20180814.Message_OneofGroup))),
- want: fileDescP2_20180814.Messages().ByName("Message").Messages().ByName("OneofGroup"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto2_20180814.Message_ExtensionOptionalGroup))),
- want: fileDescP2_20180814.Messages().ByName("Message").Messages().ByName("ExtensionOptionalGroup"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto2_20180814.Message_ExtensionRepeatedGroup))),
- want: fileDescP2_20180814.Messages().ByName("Message").Messages().ByName("ExtensionRepeatedGroup"),
- }}...)
- fileDescP3_20180814 := mustLoadFileDesc(new(proto3_20180814.Message).Descriptor())
- tests = append(tests, []struct{ got, want pref.Descriptor }{{
- got: legacyLoadEnumDesc(reflect.TypeOf(proto3_20180814.SiblingEnum(0))),
- want: fileDescP3_20180814.Enums().ByName("SiblingEnum"),
- }, {
- got: legacyLoadEnumDesc(reflect.TypeOf(proto3_20180814.Message_ChildEnum(0))),
- want: fileDescP3_20180814.Messages().ByName("Message").Enums().ByName("ChildEnum"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto3_20180814.SiblingMessage))),
- want: fileDescP3_20180814.Messages().ByName("SiblingMessage"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto3_20180814.Message_ChildMessage))),
- want: fileDescP3_20180814.Messages().ByName("Message").Messages().ByName("ChildMessage"),
- }, {
- got: legacyLoadMessageDesc(reflect.TypeOf(new(proto3_20180814.Message))),
- want: fileDescP3_20180814.Messages().ByName("Message"),
- }}...)
- type list interface {
- Len() int
- pragma.DoNotImplement
- }
- opts := cmp.Options{
- cmp.Transformer("", func(x list) []interface{} {
- out := make([]interface{}, x.Len())
- v := reflect.ValueOf(x)
- for i := 0; i < x.Len(); i++ {
- m := v.MethodByName("Get")
- out[i] = m.Call([]reflect.Value{reflect.ValueOf(i)})[0].Interface()
- }
- return out
- }),
- cmp.Transformer("", func(x pref.Descriptor) map[string]interface{} {
- out := make(map[string]interface{})
- v := reflect.ValueOf(x)
- for i := 0; i < v.NumMethod(); i++ {
- name := v.Type().Method(i).Name
- if m := v.Method(i); m.Type().NumIn() == 0 && m.Type().NumOut() == 1 {
- switch name {
- case "Index":
- // Ignore index since legacy descriptors have no parent.
- case "Options":
- // Ignore descriptor options since protos are not cmperable.
- case "Enums", "Messages", "Extensions":
- // Ignore nested message and enum declarations since
- // legacy descriptors are all created standalone.
- case "OneofType", "ExtendedType", "EnumType", "MessageType":
- // Avoid descending into a dependency to avoid a cycle.
- // Just record the full name if available.
- //
- // TODO: Cycle support in cmp would be useful here.
- v := m.Call(nil)[0]
- if !v.IsNil() {
- out[name] = v.Interface().(pref.Descriptor).FullName()
- }
- default:
- out[name] = m.Call(nil)[0].Interface()
- }
- }
- }
- return out
- }),
- cmp.Transformer("", func(v pref.Value) interface{} {
- return v.Interface()
- }),
- }
- for _, tt := range tests {
- t.Run(string(tt.want.FullName()), func(t *testing.T) {
- if diff := cmp.Diff(&tt.want, &tt.got, opts); diff != "" {
- t.Errorf("descriptor mismatch (-want, +got):\n%s", diff)
- }
- })
- }
- }
- type legacyTestMessage struct {
- XXX_unrecognized []byte
- protoV1.XXX_InternalExtensions
- }
- func (*legacyTestMessage) Reset() {}
- func (*legacyTestMessage) String() string { return "" }
- func (*legacyTestMessage) ProtoMessage() {}
- func (*legacyTestMessage) ExtensionRangeArray() []protoV1.ExtensionRange {
- return []protoV1.ExtensionRange{{Start: 10, End: 20}, {Start: 40, End: 80}, {Start: 10000, End: 20000}}
- }
- func TestLegacyUnknown(t *testing.T) {
- rawOf := func(toks ...pack.Token) pref.RawFields {
- return pref.RawFields(pack.Message(toks).Marshal())
- }
- raw1a := rawOf(pack.Tag{1, pack.VarintType}, pack.Svarint(-4321)) // 08c143
- raw1b := rawOf(pack.Tag{1, pack.Fixed32Type}, pack.Uint32(0xdeadbeef)) // 0defbeadde
- raw1c := rawOf(pack.Tag{1, pack.Fixed64Type}, pack.Float64(math.Pi)) // 09182d4454fb210940
- raw2a := rawOf(pack.Tag{2, pack.BytesType}, pack.String("hello, world!")) // 120d68656c6c6f2c20776f726c6421
- raw2b := rawOf(pack.Tag{2, pack.VarintType}, pack.Uvarint(1234)) // 10d209
- raw3a := rawOf(pack.Tag{3, pack.StartGroupType}, pack.Tag{3, pack.EndGroupType}) // 1b1c
- raw3b := rawOf(pack.Tag{3, pack.BytesType}, pack.Bytes("\xde\xad\xbe\xef")) // 1a04deadbeef
- raw1 := rawOf(pack.Tag{1, pack.BytesType}, pack.Bytes("1")) // 0a0131
- raw3 := rawOf(pack.Tag{3, pack.BytesType}, pack.Bytes("3")) // 1a0133
- raw10 := rawOf(pack.Tag{10, pack.BytesType}, pack.Bytes("10")) // 52023130 - extension
- raw15 := rawOf(pack.Tag{15, pack.BytesType}, pack.Bytes("15")) // 7a023135 - extension
- raw26 := rawOf(pack.Tag{26, pack.BytesType}, pack.Bytes("26")) // d201023236
- raw32 := rawOf(pack.Tag{32, pack.BytesType}, pack.Bytes("32")) // 8202023332
- raw45 := rawOf(pack.Tag{45, pack.BytesType}, pack.Bytes("45")) // ea02023435 - extension
- raw46 := rawOf(pack.Tag{45, pack.BytesType}, pack.Bytes("46")) // ea02023436 - extension
- raw47 := rawOf(pack.Tag{45, pack.BytesType}, pack.Bytes("47")) // ea02023437 - extension
- raw99 := rawOf(pack.Tag{99, pack.BytesType}, pack.Bytes("99")) // 9a06023939
- joinRaw := func(bs ...pref.RawFields) (out []byte) {
- for _, b := range bs {
- out = append(out, b...)
- }
- return out
- }
- m := new(legacyTestMessage)
- fs := MessageOf(m).UnknownFields()
- if got, want := fs.Len(), 0; got != want {
- t.Errorf("Len() = %d, want %d", got, want)
- }
- if got, want := m.XXX_unrecognized, joinRaw(); !bytes.Equal(got, want) {
- t.Errorf("data mismatch:\ngot: %x\nwant: %x", got, want)
- }
- fs.Set(1, raw1a)
- fs.Set(1, append(fs.Get(1), raw1b...))
- fs.Set(1, append(fs.Get(1), raw1c...))
- if got, want := fs.Len(), 1; got != want {
- t.Errorf("Len() = %d, want %d", got, want)
- }
- if got, want := m.XXX_unrecognized, joinRaw(raw1a, raw1b, raw1c); !bytes.Equal(got, want) {
- t.Errorf("data mismatch:\ngot: %x\nwant: %x", got, want)
- }
- fs.Set(2, raw2a)
- if got, want := fs.Len(), 2; got != want {
- t.Errorf("Len() = %d, want %d", got, want)
- }
- if got, want := m.XXX_unrecognized, joinRaw(raw1a, raw1b, raw1c, raw2a); !bytes.Equal(got, want) {
- t.Errorf("data mismatch:\ngot: %x\nwant: %x", got, want)
- }
- if got, want := fs.Get(1), joinRaw(raw1a, raw1b, raw1c); !bytes.Equal(got, want) {
- t.Errorf("Get(%d) = %x, want %x", 1, got, want)
- }
- if got, want := fs.Get(2), joinRaw(raw2a); !bytes.Equal(got, want) {
- t.Errorf("Get(%d) = %x, want %x", 2, got, want)
- }
- if got, want := fs.Get(3), joinRaw(); !bytes.Equal(got, want) {
- t.Errorf("Get(%d) = %x, want %x", 3, got, want)
- }
- fs.Set(1, nil) // remove field 1
- if got, want := fs.Len(), 1; got != want {
- t.Errorf("Len() = %d, want %d", got, want)
- }
- if got, want := m.XXX_unrecognized, joinRaw(raw2a); !bytes.Equal(got, want) {
- t.Errorf("data mismatch:\ngot: %x\nwant: %x", got, want)
- }
- // Simulate manual appending of raw field data.
- m.XXX_unrecognized = append(m.XXX_unrecognized, joinRaw(raw3a, raw1a, raw1b, raw2b, raw3b, raw1c)...)
- if got, want := fs.Len(), 3; got != want {
- t.Errorf("Len() = %d, want %d", got, want)
- }
- // Verify range iteration order.
- var i int
- want := []struct {
- num pref.FieldNumber
- raw pref.RawFields
- }{
- {2, joinRaw(raw2a, raw2b)},
- {3, joinRaw(raw3a, raw3b)},
- {1, joinRaw(raw1a, raw1b, raw1c)},
- }
- fs.Range(func(num pref.FieldNumber, raw pref.RawFields) bool {
- if i < len(want) {
- if num != want[i].num || !bytes.Equal(raw, want[i].raw) {
- t.Errorf("Range(%d) = (%d, %x), want (%d, %x)", i, num, raw, want[i].num, want[i].raw)
- }
- } else {
- t.Errorf("unexpected Range iteration: %d", i)
- }
- i++
- return true
- })
- fs.Set(2, fs.Get(2)) // moves field 2 to the end
- if got, want := fs.Len(), 3; got != want {
- t.Errorf("Len() = %d, want %d", got, want)
- }
- if got, want := m.XXX_unrecognized, joinRaw(raw3a, raw1a, raw1b, raw3b, raw1c, raw2a, raw2b); !bytes.Equal(got, want) {
- t.Errorf("data mismatch:\ngot: %x\nwant: %x", got, want)
- }
- fs.Set(1, nil) // remove field 1
- if got, want := fs.Len(), 2; got != want {
- t.Errorf("Len() = %d, want %d", got, want)
- }
- if got, want := m.XXX_unrecognized, joinRaw(raw3a, raw3b, raw2a, raw2b); !bytes.Equal(got, want) {
- t.Errorf("data mismatch:\ngot: %x\nwant: %x", got, want)
- }
- // Remove all fields.
- fs.Range(func(n pref.FieldNumber, b pref.RawFields) bool {
- fs.Set(n, nil)
- return true
- })
- if got, want := fs.Len(), 0; got != want {
- t.Errorf("Len() = %d, want %d", got, want)
- }
- if got, want := m.XXX_unrecognized, joinRaw(); !bytes.Equal(got, want) {
- t.Errorf("data mismatch:\ngot: %x\nwant: %x", got, want)
- }
- fs.Set(1, raw1)
- if got, want := fs.Len(), 1; got != want {
- t.Errorf("Len() = %d, want %d", got, want)
- }
- if got, want := m.XXX_unrecognized, joinRaw(raw1); !bytes.Equal(got, want) {
- t.Errorf("data mismatch:\ngot: %x\nwant: %x", got, want)
- }
- fs.Set(45, raw45)
- fs.Set(10, raw10) // extension
- fs.Set(32, raw32)
- fs.Set(1, nil) // deletion
- fs.Set(26, raw26)
- fs.Set(47, raw47) // extension
- fs.Set(46, raw46) // extension
- if got, want := fs.Len(), 6; got != want {
- t.Errorf("Len() = %d, want %d", got, want)
- }
- if got, want := m.XXX_unrecognized, joinRaw(raw32, raw26); !bytes.Equal(got, want) {
- t.Errorf("data mismatch:\ngot: %x\nwant: %x", got, want)
- }
- // Verify iteration order.
- i = 0
- want = []struct {
- num pref.FieldNumber
- raw pref.RawFields
- }{
- {32, raw32},
- {26, raw26},
- {10, raw10}, // extension
- {45, raw45}, // extension
- {46, raw46}, // extension
- {47, raw47}, // extension
- }
- fs.Range(func(num pref.FieldNumber, raw pref.RawFields) bool {
- if i < len(want) {
- if num != want[i].num || !bytes.Equal(raw, want[i].raw) {
- t.Errorf("Range(%d) = (%d, %x), want (%d, %x)", i, num, raw, want[i].num, want[i].raw)
- }
- } else {
- t.Errorf("unexpected Range iteration: %d", i)
- }
- i++
- return true
- })
- // Perform partial deletion while iterating.
- i = 0
- fs.Range(func(num pref.FieldNumber, raw pref.RawFields) bool {
- if i%2 == 0 {
- fs.Set(num, nil)
- }
- i++
- return true
- })
- if got, want := fs.Len(), 3; got != want {
- t.Errorf("Len() = %d, want %d", got, want)
- }
- if got, want := m.XXX_unrecognized, joinRaw(raw26); !bytes.Equal(got, want) {
- t.Errorf("data mismatch:\ngot: %x\nwant: %x", got, want)
- }
- fs.Set(15, raw15) // extension
- fs.Set(3, raw3)
- fs.Set(99, raw99)
- if got, want := fs.Len(), 6; got != want {
- t.Errorf("Len() = %d, want %d", got, want)
- }
- if got, want := m.XXX_unrecognized, joinRaw(raw26, raw3, raw99); !bytes.Equal(got, want) {
- t.Errorf("data mismatch:\ngot: %x\nwant: %x", got, want)
- }
- // Perform partial iteration.
- i = 0
- want = []struct {
- num pref.FieldNumber
- raw pref.RawFields
- }{
- {26, raw26},
- {3, raw3},
- }
- fs.Range(func(num pref.FieldNumber, raw pref.RawFields) bool {
- if i < len(want) {
- if num != want[i].num || !bytes.Equal(raw, want[i].raw) {
- t.Errorf("Range(%d) = (%d, %x), want (%d, %x)", i, num, raw, want[i].num, want[i].raw)
- }
- } else {
- t.Errorf("unexpected Range iteration: %d", i)
- }
- i++
- return i < 2
- })
- }
- func TestLegactExtensions(t *testing.T) {
- extensions := []pref.ExtensionType{
- legacyExtensionTypeOf(&protoV1.ExtensionDesc{
- ExtendedType: (*legacyTestMessage)(nil),
- ExtensionType: (*bool)(nil),
- Field: 10000,
- Name: "fizz.buzz.optional_bool",
- Tag: "varint,10000,opt,name=optional_bool,json=optionalBool,def=1",
- Filename: "fizz/buzz/test.proto",
- }),
- legacyExtensionTypeOf(&protoV1.ExtensionDesc{
- ExtendedType: (*legacyTestMessage)(nil),
- ExtensionType: (*int32)(nil),
- Field: 10001,
- Name: "fizz.buzz.optional_int32",
- Tag: "varint,10001,opt,name=optional_int32,json=optionalInt32,def=-12345",
- Filename: "fizz/buzz/test.proto",
- }),
- legacyExtensionTypeOf(&protoV1.ExtensionDesc{
- ExtendedType: (*legacyTestMessage)(nil),
- ExtensionType: (*uint32)(nil),
- Field: 10002,
- Name: "fizz.buzz.optional_uint32",
- Tag: "varint,10002,opt,name=optional_uint32,json=optionalUint32,def=3200",
- Filename: "fizz/buzz/test.proto",
- }),
- legacyExtensionTypeOf(&protoV1.ExtensionDesc{
- ExtendedType: (*legacyTestMessage)(nil),
- ExtensionType: (*float32)(nil),
- Field: 10003,
- Name: "fizz.buzz.optional_float",
- Tag: "fixed32,10003,opt,name=optional_float,json=optionalFloat,def=3.14159",
- Filename: "fizz/buzz/test.proto",
- }),
- legacyExtensionTypeOf(&protoV1.ExtensionDesc{
- ExtendedType: (*legacyTestMessage)(nil),
- ExtensionType: (*string)(nil),
- Field: 10004,
- Name: "fizz.buzz.optional_string",
- Tag: "bytes,10004,opt,name=optional_string,json=optionalString,def=hello, \"world!\"\n",
- Filename: "fizz/buzz/test.proto",
- }),
- legacyExtensionTypeOf(&protoV1.ExtensionDesc{
- ExtendedType: (*legacyTestMessage)(nil),
- ExtensionType: ([]byte)(nil),
- Field: 10005,
- Name: "fizz.buzz.optional_bytes",
- Tag: "bytes,10005,opt,name=optional_bytes,json=optionalBytes,def=dead\\336\\255\\276\\357beef",
- Filename: "fizz/buzz/test.proto",
- }),
- legacyExtensionTypeOf(&protoV1.ExtensionDesc{
- ExtendedType: (*legacyTestMessage)(nil),
- ExtensionType: (*proto2_20180125.Message_ChildEnum)(nil),
- Field: 10006,
- Name: "fizz.buzz.optional_enum_v1",
- Tag: "varint,10006,opt,name=optional_enum_v1,json=optionalEnumV1,enum=google.golang.org.proto2_20180125.Message_ChildEnum,def=0",
- Filename: "fizz/buzz/test.proto",
- }),
- legacyExtensionTypeOf(&protoV1.ExtensionDesc{
- ExtendedType: (*legacyTestMessage)(nil),
- ExtensionType: (*proto2_20180125.Message_ChildMessage)(nil),
- Field: 10007,
- Name: "fizz.buzz.optional_message_v1",
- Tag: "bytes,10007,opt,name=optional_message_v1,json=optionalMessageV1",
- Filename: "fizz/buzz/test.proto",
- }),
- legacyExtensionTypeOf(&protoV1.ExtensionDesc{
- ExtendedType: (*legacyTestMessage)(nil),
- ExtensionType: (*EnumProto2)(nil),
- Field: 10008,
- Name: "fizz.buzz.optional_enum_v2",
- Tag: "varint,10008,opt,name=optional_enum_v2,json=optionalEnumV2,enum=EnumProto2,def=57005",
- Filename: "fizz/buzz/test.proto",
- }),
- legacyExtensionTypeOf(&protoV1.ExtensionDesc{
- ExtendedType: (*legacyTestMessage)(nil),
- ExtensionType: (*EnumMessages)(nil),
- Field: 10009,
- Name: "fizz.buzz.optional_message_v2",
- Tag: "bytes,10009,opt,name=optional_message_v2,json=optionalMessageV2",
- Filename: "fizz/buzz/test.proto",
- }),
- legacyExtensionTypeOf(&protoV1.ExtensionDesc{
- ExtendedType: (*legacyTestMessage)(nil),
- ExtensionType: ([]bool)(nil),
- Field: 10010,
- Name: "fizz.buzz.repeated_bool",
- Tag: "varint,10010,rep,name=repeated_bool,json=repeatedBool",
- Filename: "fizz/buzz/test.proto",
- }),
- legacyExtensionTypeOf(&protoV1.ExtensionDesc{
- ExtendedType: (*legacyTestMessage)(nil),
- ExtensionType: ([]int32)(nil),
- Field: 10011,
- Name: "fizz.buzz.repeated_int32",
- Tag: "varint,10011,rep,name=repeated_int32,json=repeatedInt32",
- Filename: "fizz/buzz/test.proto",
- }),
- legacyExtensionTypeOf(&protoV1.ExtensionDesc{
- ExtendedType: (*legacyTestMessage)(nil),
- ExtensionType: ([]uint32)(nil),
- Field: 10012,
- Name: "fizz.buzz.repeated_uint32",
- Tag: "varint,10012,rep,name=repeated_uint32,json=repeatedUint32",
- Filename: "fizz/buzz/test.proto",
- }),
- legacyExtensionTypeOf(&protoV1.ExtensionDesc{
- ExtendedType: (*legacyTestMessage)(nil),
- ExtensionType: ([]float32)(nil),
- Field: 10013,
- Name: "fizz.buzz.repeated_float",
- Tag: "fixed32,10013,rep,name=repeated_float,json=repeatedFloat",
- Filename: "fizz/buzz/test.proto",
- }),
- legacyExtensionTypeOf(&protoV1.ExtensionDesc{
- ExtendedType: (*legacyTestMessage)(nil),
- ExtensionType: ([]string)(nil),
- Field: 10014,
- Name: "fizz.buzz.repeated_string",
- Tag: "bytes,10014,rep,name=repeated_string,json=repeatedString",
- Filename: "fizz/buzz/test.proto",
- }),
- legacyExtensionTypeOf(&protoV1.ExtensionDesc{
- ExtendedType: (*legacyTestMessage)(nil),
- ExtensionType: ([][]byte)(nil),
- Field: 10015,
- Name: "fizz.buzz.repeated_bytes",
- Tag: "bytes,10015,rep,name=repeated_bytes,json=repeatedBytes",
- Filename: "fizz/buzz/test.proto",
- }),
- legacyExtensionTypeOf(&protoV1.ExtensionDesc{
- ExtendedType: (*legacyTestMessage)(nil),
- ExtensionType: ([]proto2_20180125.Message_ChildEnum)(nil),
- Field: 10016,
- Name: "fizz.buzz.repeated_enum_v1",
- Tag: "varint,10016,rep,name=repeated_enum_v1,json=repeatedEnumV1,enum=google.golang.org.proto2_20180125.Message_ChildEnum",
- Filename: "fizz/buzz/test.proto",
- }),
- legacyExtensionTypeOf(&protoV1.ExtensionDesc{
- ExtendedType: (*legacyTestMessage)(nil),
- ExtensionType: ([]*proto2_20180125.Message_ChildMessage)(nil),
- Field: 10017,
- Name: "fizz.buzz.repeated_message_v1",
- Tag: "bytes,10017,rep,name=repeated_message_v1,json=repeatedMessageV1",
- Filename: "fizz/buzz/test.proto",
- }),
- legacyExtensionTypeOf(&protoV1.ExtensionDesc{
- ExtendedType: (*legacyTestMessage)(nil),
- ExtensionType: ([]EnumProto2)(nil),
- Field: 10018,
- Name: "fizz.buzz.repeated_enum_v2",
- Tag: "varint,10018,rep,name=repeated_enum_v2,json=repeatedEnumV2,enum=EnumProto2",
- Filename: "fizz/buzz/test.proto",
- }),
- legacyExtensionTypeOf(&protoV1.ExtensionDesc{
- ExtendedType: (*legacyTestMessage)(nil),
- ExtensionType: ([]*EnumMessages)(nil),
- Field: 10019,
- Name: "fizz.buzz.repeated_message_v2",
- Tag: "bytes,10019,rep,name=repeated_message_v2,json=repeatedMessageV2",
- Filename: "fizz/buzz/test.proto",
- }),
- }
- opts := cmp.Options{cmp.Comparer(func(x, y *proto2_20180125.Message_ChildMessage) bool {
- return x == y // pointer compare messages for object identity
- })}
- m := new(legacyTestMessage)
- fs := MessageOf(m).KnownFields()
- ts := fs.ExtensionTypes()
- if n := fs.Len(); n != 0 {
- t.Errorf("KnownFields.Len() = %v, want 0", n)
- }
- if n := ts.Len(); n != 0 {
- t.Errorf("ExtensionFieldTypes.Len() = %v, want 0", n)
- }
- // Register all the extension types.
- for _, xt := range extensions {
- ts.Register(xt)
- }
- // Check that getting the zero value returns the default value for scalars,
- // nil for singular messages, and an empty list for repeated fields.
- defaultValues := []interface{}{
- bool(true),
- int32(-12345),
- uint32(3200),
- float32(3.14159),
- string("hello, \"world!\"\n"),
- []byte("dead\xde\xad\xbe\xefbeef"),
- proto2_20180125.Message_ALPHA,
- nil,
- EnumProto2(0xdead),
- nil,
- new([]bool),
- new([]int32),
- new([]uint32),
- new([]float32),
- new([]string),
- new([][]byte),
- new([]proto2_20180125.Message_ChildEnum),
- new([]*proto2_20180125.Message_ChildMessage),
- new([]EnumProto2),
- new([]*EnumMessages),
- }
- for i, xt := range extensions {
- var got interface{}
- if v := fs.Get(xt.Number()); v.IsValid() {
- got = xt.InterfaceOf(v)
- }
- want := defaultValues[i]
- if diff := cmp.Diff(want, got, opts); diff != "" {
- t.Errorf("KnownFields.Get(%d) mismatch (-want +got):\n%v", xt.Number(), diff)
- }
- }
- // All fields should be unpopulated.
- for _, xt := range extensions {
- if fs.Has(xt.Number()) {
- t.Errorf("KnownFields.Has(%d) = true, want false", xt.Number())
- }
- }
- // Set some values and append to values to the lists.
- m1a := &proto2_20180125.Message_ChildMessage{F1: scalar.String("m1a")}
- m1b := &proto2_20180125.Message_ChildMessage{F1: scalar.String("m2b")}
- m2a := &EnumMessages{EnumP2: EnumProto2(0x1b).Enum()}
- m2b := &EnumMessages{EnumP2: EnumProto2(0x2b).Enum()}
- setValues := []interface{}{
- bool(false),
- int32(-54321),
- uint32(6400),
- float32(2.71828),
- string("goodbye, \"world!\"\n"),
- []byte("live\xde\xad\xbe\xefchicken"),
- proto2_20180125.Message_CHARLIE,
- m1a,
- EnumProto2(0xbeef),
- m2a,
- &[]bool{true},
- &[]int32{-1000},
- &[]uint32{1280},
- &[]float32{1.6180},
- &[]string{"zero"},
- &[][]byte{[]byte("zero")},
- &[]proto2_20180125.Message_ChildEnum{proto2_20180125.Message_BRAVO},
- &[]*proto2_20180125.Message_ChildMessage{m1b},
- &[]EnumProto2{0xdead},
- &[]*EnumMessages{m2b},
- }
- for i, xt := range extensions {
- fs.Set(xt.Number(), xt.ValueOf(setValues[i]))
- }
- for i, xt := range extensions[len(extensions)/2:] {
- v := extensions[i].ValueOf(setValues[i])
- fs.Get(xt.Number()).List().Append(v)
- }
- // Get the values and check for equality.
- getValues := []interface{}{
- bool(false),
- int32(-54321),
- uint32(6400),
- float32(2.71828),
- string("goodbye, \"world!\"\n"),
- []byte("live\xde\xad\xbe\xefchicken"),
- proto2_20180125.Message_ChildEnum(proto2_20180125.Message_CHARLIE),
- m1a,
- EnumProto2(0xbeef),
- m2a,
- &[]bool{true, false},
- &[]int32{-1000, -54321},
- &[]uint32{1280, 6400},
- &[]float32{1.6180, 2.71828},
- &[]string{"zero", "goodbye, \"world!\"\n"},
- &[][]byte{[]byte("zero"), []byte("live\xde\xad\xbe\xefchicken")},
- &[]proto2_20180125.Message_ChildEnum{proto2_20180125.Message_BRAVO, proto2_20180125.Message_CHARLIE},
- &[]*proto2_20180125.Message_ChildMessage{m1b, m1a},
- &[]EnumProto2{0xdead, 0xbeef},
- &[]*EnumMessages{m2b, m2a},
- }
- for i, xt := range extensions {
- got := xt.InterfaceOf(fs.Get(xt.Number()))
- want := getValues[i]
- if diff := cmp.Diff(want, got, opts); diff != "" {
- t.Errorf("KnownFields.Get(%d) mismatch (-want +got):\n%v", xt.Number(), diff)
- }
- }
- if n := fs.Len(); n != 20 {
- t.Errorf("KnownFields.Len() = %v, want 0", n)
- }
- if n := ts.Len(); n != 20 {
- t.Errorf("ExtensionFieldTypes.Len() = %v, want 20", n)
- }
- // Clear the field for all extension types.
- for _, xt := range extensions[:len(extensions)/2] {
- fs.Clear(xt.Number())
- }
- for i, xt := range extensions[len(extensions)/2:] {
- if i%2 == 0 {
- fs.Clear(xt.Number())
- } else {
- fs.Get(xt.Number()).List().Truncate(0)
- }
- }
- if n := fs.Len(); n != 0 {
- t.Errorf("KnownFields.Len() = %v, want 0", n)
- }
- if n := ts.Len(); n != 20 {
- t.Errorf("ExtensionFieldTypes.Len() = %v, want 20", n)
- }
- // De-register all extension types.
- for _, xt := range extensions {
- ts.Remove(xt)
- }
- if n := fs.Len(); n != 0 {
- t.Errorf("KnownFields.Len() = %v, want 0", n)
- }
- if n := ts.Len(); n != 0 {
- t.Errorf("ExtensionFieldTypes.Len() = %v, want 0", n)
- }
- }
|