Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
P
protobuf
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
submodule
protobuf
Commits
d1f5acaa
Commit
d1f5acaa
authored
Apr 29, 2015
by
Jie Luo
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Change the package for field_presence_test.proto
parent
c5c9c6a7
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
25 additions
and
25 deletions
+25
-25
field_presence_test.proto
csharp/protos/google/protobuf/field_presence_test.proto
+1
-1
FieldPResenceTest.cs
csharp/src/ProtocolBuffers.Test/FieldPResenceTest.cs
+24
-24
FieldPresense.cs
csharp/src/ProtocolBuffers.Test/TestProtos/FieldPresense.cs
+0
-0
No files found.
csharp/protos/google/protobuf/field_presence_test.proto
View file @
d1f5acaa
syntax
=
"proto3"
;
package
field_presence_test
;
package
Google
.
ProtocolBuffers.TestProtos.FieldPresence
;
option
java_package
=
"com.google.protobuf"
;
option
java_outer_classname
=
"FieldPresenceTestProto"
;
...
...
csharp/src/ProtocolBuffers.Test/FieldPResenceTest.cs
View file @
d1f5acaa
...
...
@@ -56,22 +56,22 @@ namespace Google.ProtocolBuffers
{
// Optional non-message fields don't have HasFoo method generated
Type
proto2Type
=
typeof
(
TestAllTypes
);
Type
proto3Type
=
typeof
(
field_presence_test
.
TestAllTypes
);
Type
proto3Type
=
typeof
(
FieldPresence
.
TestAllTypes
);
CheckHasMethodRemoved
(
proto2Type
,
proto3Type
,
"OptionalInt32"
);
CheckHasMethodRemoved
(
proto2Type
,
proto3Type
,
"OptionalString"
);
CheckHasMethodRemoved
(
proto2Type
,
proto3Type
,
"OptionalBytes"
);
CheckHasMethodRemoved
(
proto2Type
,
proto3Type
,
"OptionalNestedEnum"
);
proto2Type
=
typeof
(
TestAllTypes
.
Builder
);
proto3Type
=
typeof
(
field_presence_test
.
TestAllTypes
.
Builder
);
proto3Type
=
typeof
(
FieldPresence
.
TestAllTypes
.
Builder
);
CheckHasMethodRemoved
(
proto2Type
,
proto3Type
,
"OptionalInt32"
);
CheckHasMethodRemoved
(
proto2Type
,
proto3Type
,
"OptionalString"
);
CheckHasMethodRemoved
(
proto2Type
,
proto3Type
,
"OptionalBytes"
);
CheckHasMethodRemoved
(
proto2Type
,
proto3Type
,
"OptionalNestedEnum"
);
// message fields still have the HasFoo method generated
Assert
.
False
(
field_presence_test
.
TestAllTypes
.
CreateBuilder
().
Build
().
HasOptionalNestedMessage
);
Assert
.
False
(
field_presence_test
.
TestAllTypes
.
CreateBuilder
().
HasOptionalNestedMessage
);
Assert
.
False
(
FieldPresence
.
TestAllTypes
.
CreateBuilder
().
Build
().
HasOptionalNestedMessage
);
Assert
.
False
(
FieldPresence
.
TestAllTypes
.
CreateBuilder
().
HasOptionalNestedMessage
);
}
[
TestMethod
]
...
...
@@ -81,29 +81,29 @@ namespace Google.ProtocolBuffers
// way as not set.
// Serialization will ignore such fields.
field_presence_test
.
TestAllTypes
.
Builder
builder
=
field_presence_test
.
TestAllTypes
.
CreateBuilder
();
FieldPresence
.
TestAllTypes
.
Builder
builder
=
FieldPresence
.
TestAllTypes
.
CreateBuilder
();
builder
.
SetOptionalInt32
(
0
);
builder
.
SetOptionalString
(
""
);
builder
.
SetOptionalBytes
(
ByteString
.
Empty
);
builder
.
SetOptionalNestedEnum
(
field_presence_test
.
TestAllTypes
.
Types
.
NestedEnum
.
FOO
);
field_presence_test
.
TestAllTypes
message
=
builder
.
Build
();
builder
.
SetOptionalNestedEnum
(
FieldPresence
.
TestAllTypes
.
Types
.
NestedEnum
.
FOO
);
FieldPresence
.
TestAllTypes
message
=
builder
.
Build
();
Assert
.
AreEqual
(
0
,
message
.
SerializedSize
);
// Test merge
field_presence_test
.
TestAllTypes
.
Builder
a
=
field_presence_test
.
TestAllTypes
.
CreateBuilder
();
FieldPresence
.
TestAllTypes
.
Builder
a
=
FieldPresence
.
TestAllTypes
.
CreateBuilder
();
a
.
SetOptionalInt32
(
1
);
a
.
SetOptionalString
(
"x"
);
a
.
SetOptionalBytes
(
ByteString
.
CopyFromUtf8
(
"y"
));
a
.
SetOptionalNestedEnum
(
field_presence_test
.
TestAllTypes
.
Types
.
NestedEnum
.
BAR
);
a
.
SetOptionalNestedEnum
(
FieldPresence
.
TestAllTypes
.
Types
.
NestedEnum
.
BAR
);
a
.
MergeFrom
(
message
);
field_presence_test
.
TestAllTypes
messageA
=
a
.
Build
();
FieldPresence
.
TestAllTypes
messageA
=
a
.
Build
();
Assert
.
AreEqual
(
1
,
messageA
.
OptionalInt32
);
Assert
.
AreEqual
(
"x"
,
messageA
.
OptionalString
);
Assert
.
AreEqual
(
ByteString
.
CopyFromUtf8
(
"y"
),
messageA
.
OptionalBytes
);
Assert
.
AreEqual
(
field_presence_test
.
TestAllTypes
.
Types
.
NestedEnum
.
BAR
,
messageA
.
OptionalNestedEnum
);
Assert
.
AreEqual
(
FieldPresence
.
TestAllTypes
.
Types
.
NestedEnum
.
BAR
,
messageA
.
OptionalNestedEnum
);
// equals/hashCode should produce the same results
field_presence_test
.
TestAllTypes
empty
=
field_presence_test
.
TestAllTypes
.
CreateBuilder
().
Build
();
FieldPresence
.
TestAllTypes
empty
=
FieldPresence
.
TestAllTypes
.
CreateBuilder
().
Build
();
Assert
.
True
(
empty
.
Equals
(
message
));
Assert
.
True
(
message
.
Equals
(
empty
));
Assert
.
AreEqual
(
empty
.
GetHashCode
(),
message
.
GetHashCode
());
...
...
@@ -112,24 +112,24 @@ namespace Google.ProtocolBuffers
[
TestMethod
]
public
void
TestFieldPresenceReflection
()
{
MessageDescriptor
descriptor
=
field_presence_test
.
TestAllTypes
.
Descriptor
;
MessageDescriptor
descriptor
=
FieldPresence
.
TestAllTypes
.
Descriptor
;
FieldDescriptor
optionalInt32Field
=
descriptor
.
FindFieldByName
(
"optional_int32"
);
FieldDescriptor
optionalStringField
=
descriptor
.
FindFieldByName
(
"optional_string"
);
FieldDescriptor
optionalBytesField
=
descriptor
.
FindFieldByName
(
"optional_bytes"
);
FieldDescriptor
optionalNestedEnumField
=
descriptor
.
FindFieldByName
(
"optional_nested_enum"
);
field_presence_test
.
TestAllTypes
message
=
field_presence_test
.
TestAllTypes
.
CreateBuilder
().
Build
();
FieldPresence
.
TestAllTypes
message
=
FieldPresence
.
TestAllTypes
.
CreateBuilder
().
Build
();
Assert
.
False
(
message
.
HasField
(
optionalInt32Field
));
Assert
.
False
(
message
.
HasField
(
optionalStringField
));
Assert
.
False
(
message
.
HasField
(
optionalBytesField
));
Assert
.
False
(
message
.
HasField
(
optionalNestedEnumField
));
// Set to default value is seen as not present
message
=
field_presence_test
.
TestAllTypes
.
CreateBuilder
()
message
=
FieldPresence
.
TestAllTypes
.
CreateBuilder
()
.
SetOptionalInt32
(
0
)
.
SetOptionalString
(
""
)
.
SetOptionalBytes
(
ByteString
.
Empty
)
.
SetOptionalNestedEnum
(
field_presence_test
.
TestAllTypes
.
Types
.
NestedEnum
.
FOO
)
.
SetOptionalNestedEnum
(
FieldPresence
.
TestAllTypes
.
Types
.
NestedEnum
.
FOO
)
.
Build
();
Assert
.
False
(
message
.
HasField
(
optionalInt32Field
));
Assert
.
False
(
message
.
HasField
(
optionalStringField
));
...
...
@@ -138,11 +138,11 @@ namespace Google.ProtocolBuffers
Assert
.
AreEqual
(
0
,
message
.
AllFields
.
Count
);
// Set t0 non-defalut value is seen as present
message
=
field_presence_test
.
TestAllTypes
.
CreateBuilder
()
message
=
FieldPresence
.
TestAllTypes
.
CreateBuilder
()
.
SetOptionalInt32
(
1
)
.
SetOptionalString
(
"x"
)
.
SetOptionalBytes
(
ByteString
.
CopyFromUtf8
(
"y"
))
.
SetOptionalNestedEnum
(
field_presence_test
.
TestAllTypes
.
Types
.
NestedEnum
.
BAR
)
.
SetOptionalNestedEnum
(
FieldPresence
.
TestAllTypes
.
Types
.
NestedEnum
.
BAR
)
.
Build
();
Assert
.
True
(
message
.
HasField
(
optionalInt32Field
));
Assert
.
True
(
message
.
HasField
(
optionalStringField
));
...
...
@@ -154,13 +154,13 @@ namespace Google.ProtocolBuffers
[
TestMethod
]
public
void
TestMessageField
()
{
field_presence_test
.
TestAllTypes
.
Builder
builder
=
field_presence_test
.
TestAllTypes
.
CreateBuilder
();
FieldPresence
.
TestAllTypes
.
Builder
builder
=
FieldPresence
.
TestAllTypes
.
CreateBuilder
();
Assert
.
False
(
builder
.
HasOptionalNestedMessage
);
Assert
.
False
(
builder
.
Build
().
HasOptionalNestedMessage
);
// Unlike non-message fields, if we set default value to message field, the field
// shoule be seem as present.
builder
.
SetOptionalNestedMessage
(
field_presence_test
.
TestAllTypes
.
Types
.
NestedMessage
.
DefaultInstance
);
builder
.
SetOptionalNestedMessage
(
FieldPresence
.
TestAllTypes
.
Types
.
NestedMessage
.
DefaultInstance
);
Assert
.
True
(
builder
.
HasOptionalNestedMessage
);
Assert
.
True
(
builder
.
Build
().
HasOptionalNestedMessage
);
...
...
@@ -169,17 +169,17 @@ namespace Google.ProtocolBuffers
[
TestMethod
]
public
void
TestSeralizeAndParese
()
{
field_presence_test
.
TestAllTypes
.
Builder
builder
=
field_presence_test
.
TestAllTypes
.
CreateBuilder
();
FieldPresence
.
TestAllTypes
.
Builder
builder
=
FieldPresence
.
TestAllTypes
.
CreateBuilder
();
builder
.
SetOptionalInt32
(
1234
);
builder
.
SetOptionalString
(
"hello"
);
builder
.
SetOptionalNestedMessage
(
field_presence_test
.
TestAllTypes
.
Types
.
NestedMessage
.
DefaultInstance
);
builder
.
SetOptionalNestedMessage
(
FieldPresence
.
TestAllTypes
.
Types
.
NestedMessage
.
DefaultInstance
);
ByteString
data
=
builder
.
Build
().
ToByteString
();
field_presence_test
.
TestAllTypes
message
=
field_presence_test
.
TestAllTypes
.
ParseFrom
(
data
);
FieldPresence
.
TestAllTypes
message
=
FieldPresence
.
TestAllTypes
.
ParseFrom
(
data
);
Assert
.
AreEqual
(
1234
,
message
.
OptionalInt32
);
Assert
.
AreEqual
(
"hello"
,
message
.
OptionalString
);
Assert
.
AreEqual
(
ByteString
.
Empty
,
message
.
OptionalBytes
);
Assert
.
AreEqual
(
field_presence_test
.
TestAllTypes
.
Types
.
NestedEnum
.
FOO
,
message
.
OptionalNestedEnum
);
Assert
.
AreEqual
(
FieldPresence
.
TestAllTypes
.
Types
.
NestedEnum
.
FOO
,
message
.
OptionalNestedEnum
);
Assert
.
True
(
message
.
HasOptionalNestedMessage
);
Assert
.
AreEqual
(
0
,
message
.
OptionalNestedMessage
.
Value
);
}
...
...
csharp/src/ProtocolBuffers.Test/TestProtos/FieldPresense.cs
View file @
d1f5acaa
This diff is collapsed.
Click to expand it.
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment