| Index: third_party/protobuf/csharp/protos/unittest_issues.proto
|
| diff --git a/third_party/protobuf/csharp/protos/unittest_issues.proto b/third_party/protobuf/csharp/protos/unittest_issues.proto
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..989b3dc426e9c678bef641b3251f9b125765f74a
|
| --- /dev/null
|
| +++ b/third_party/protobuf/csharp/protos/unittest_issues.proto
|
| @@ -0,0 +1,119 @@
|
| +syntax = "proto3";
|
| +
|
| +// These proto descriptors have at one time been reported as an issue or defect.
|
| +// They are kept here to replicate the issue, and continue to verify the fix.
|
| +
|
| +// Issue: Non-"Google.Protobuffers" namespace will ensure that protobuffer library types are qualified
|
| +option csharp_namespace = "UnitTest.Issues.TestProtos";
|
| +
|
| +package unittest_issues;
|
| +option optimize_for = SPEED;
|
| +
|
| +// Issue 307: when generating doubly-nested types, any references
|
| +// should be of the form A.Types.B.Types.C.
|
| +message Issue307 {
|
| + message NestedOnce {
|
| + message NestedTwice {
|
| + }
|
| + }
|
| +}
|
| +
|
| +// Old issue 13: http://code.google.com/p/protobuf-csharp-port/issues/detail?id=13
|
| +// New issue 309: https://github.com/google/protobuf/issues/309
|
| +
|
| +// message A {
|
| +// optional int32 _A = 1;
|
| +// }
|
| +
|
| +// message B {
|
| +// optional int32 B_ = 1;
|
| +// }
|
| +
|
| +//message AB {
|
| +// optional int32 a_b = 1;
|
| +//}
|
| +
|
| +// Similar issue with numeric names
|
| +// Java code failed too, so probably best for this to be a restriction.
|
| +// See https://github.com/google/protobuf/issues/308
|
| +// message NumberField {
|
| +// optional int32 _01 = 1;
|
| +// }
|
| +
|
| +// issue 19 - negative enum values
|
| +
|
| +enum NegativeEnum {
|
| + NEGATIVE_ENUM_ZERO = 0;
|
| + FiveBelow = -5;
|
| + MinusOne = -1;
|
| +}
|
| +
|
| +message NegativeEnumMessage {
|
| + NegativeEnum value = 1;
|
| + repeated NegativeEnum values = 2 [packed = false];
|
| + repeated NegativeEnum packed_values = 3 [packed=true];
|
| +}
|
| +
|
| +// Issue 21: http://code.google.com/p/protobuf-csharp-port/issues/detail?id=21
|
| +// Decorate fields with [deprecated=true] as [System.Obsolete]
|
| +
|
| +message DeprecatedChild {
|
| +}
|
| +
|
| +enum DeprecatedEnum {
|
| + DEPRECATED_ZERO = 0;
|
| + one = 1;
|
| +}
|
| +
|
| +message DeprecatedFieldsMessage {
|
| + int32 PrimitiveValue = 1 [deprecated = true];
|
| + repeated int32 PrimitiveArray = 2 [deprecated = true];
|
| +
|
| + DeprecatedChild MessageValue = 3 [deprecated = true];
|
| + repeated DeprecatedChild MessageArray = 4 [deprecated = true];
|
| +
|
| + DeprecatedEnum EnumValue = 5 [deprecated = true];
|
| + repeated DeprecatedEnum EnumArray = 6 [deprecated = true];
|
| +}
|
| +
|
| +// Issue 45: http://code.google.com/p/protobuf-csharp-port/issues/detail?id=45
|
| +message ItemField {
|
| + int32 item = 1;
|
| +}
|
| +
|
| +message ReservedNames {
|
| + // Force a nested type called Types
|
| + message SomeNestedType {
|
| + }
|
| +
|
| + int32 types = 1;
|
| + int32 descriptor = 2;
|
| +}
|
| +
|
| +message TestJsonFieldOrdering {
|
| + // These fields are deliberately not declared in numeric
|
| + // order, and the oneof fields aren't contiguous either.
|
| + // This allows for reasonably robust tests of JSON output
|
| + // ordering.
|
| + // TestFieldOrderings in unittest_proto3.proto is similar,
|
| + // but doesn't include oneofs.
|
| + // TODO: Consider adding oneofs to TestFieldOrderings, although
|
| + // that will require fixing other tests in multiple platforms.
|
| + // Alternatively, consider just adding this to
|
| + // unittest_proto3.proto if multiple platforms want it.
|
| +
|
| + int32 plain_int32 = 4;
|
| +
|
| + oneof o1 {
|
| + string o1_string = 2;
|
| + int32 o1_int32 = 5;
|
| + }
|
| +
|
| + string plain_string = 1;
|
| +
|
| + oneof o2 {
|
| + int32 o2_int32 = 6;
|
| + string o2_string = 3;
|
| + }
|
| +
|
| +}
|
|
|