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
c298c892
Commit
c298c892
authored
May 30, 2009
by
Jon Skeet
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
New tests, double build errors, and a few miscellaneous fixes
parent
a6afb7cd
Show whitespace changes
Inline
Side-by-side
Showing
8 changed files
with
123 additions
and
14 deletions
+123
-14
CodedInputStreamTest.cs
src/ProtocolBuffers.Test/CodedInputStreamTest.cs
+65
-1
DynamicMessageTest.cs
src/ProtocolBuffers.Test/DynamicMessageTest.cs
+13
-0
GeneratedMessageTest.cs
src/ProtocolBuffers.Test/GeneratedMessageTest.cs
+13
-1
AbstractBuilder.cs
src/ProtocolBuffers/AbstractBuilder.cs
+1
-1
CodedInputStream.cs
src/ProtocolBuffers/CodedInputStream.cs
+24
-7
DescriptorPool.cs
src/ProtocolBuffers/Descriptors/DescriptorPool.cs
+1
-2
DynamicMessage.cs
src/ProtocolBuffers/DynamicMessage.cs
+4
-1
GeneratedBuilder.cs
src/ProtocolBuffers/GeneratedBuilder.cs
+2
-1
No files found.
src/ProtocolBuffers.Test/CodedInputStreamTest.cs
View file @
c298c892
...
...
@@ -61,6 +61,7 @@ namespace Google.ProtocolBuffers {
input
=
CodedInputStream
.
CreateInstance
(
data
);
Assert
.
AreEqual
(
value
,
input
.
ReadRawVarint64
());
Assert
.
IsTrue
(
input
.
IsAtEnd
);
// Try different block sizes.
for
(
int
bufferSize
=
1
;
bufferSize
<=
16
;
bufferSize
*=
2
)
{
...
...
@@ -69,7 +70,18 @@ namespace Google.ProtocolBuffers {
input
=
CodedInputStream
.
CreateInstance
(
new
SmallBlockInputStream
(
data
,
bufferSize
));
Assert
.
AreEqual
(
value
,
input
.
ReadRawVarint64
());
Assert
.
IsTrue
(
input
.
IsAtEnd
);
}
// Try reading directly from a MemoryStream. We want to verify that it
// doesn't read past the end of the input, so write an extra byte - this
// lets us test the position at the end.
MemoryStream
memoryStream
=
new
MemoryStream
();
memoryStream
.
Write
(
data
,
0
,
data
.
Length
);
memoryStream
.
WriteByte
(
0
);
memoryStream
.
Position
=
0
;
Assert
.
AreEqual
((
uint
)
value
,
CodedInputStream
.
ReadRawVarint32
(
memoryStream
));
Assert
.
AreEqual
(
data
.
Length
,
memoryStream
.
Position
);
}
/// <summary>
...
...
@@ -77,7 +89,7 @@ namespace Google.ProtocolBuffers {
/// expects them to fail with an InvalidProtocolBufferException whose
/// description matches the given one.
/// </summary>
private
void
AssertReadVarintFailure
(
InvalidProtocolBufferException
expected
,
byte
[]
data
)
{
private
static
void
AssertReadVarintFailure
(
InvalidProtocolBufferException
expected
,
byte
[]
data
)
{
CodedInputStream
input
=
CodedInputStream
.
CreateInstance
(
data
);
try
{
input
.
ReadRawVarint32
();
...
...
@@ -93,6 +105,14 @@ namespace Google.ProtocolBuffers {
}
catch
(
InvalidProtocolBufferException
e
)
{
Assert
.
AreEqual
(
expected
.
Message
,
e
.
Message
);
}
// Make sure we get the same error when reading directly from a Stream.
try
{
CodedInputStream
.
ReadRawVarint32
(
new
MemoryStream
(
data
));
Assert
.
Fail
(
"Should have thrown an exception."
);
}
catch
(
InvalidProtocolBufferException
e
)
{
Assert
.
AreEqual
(
expected
.
Message
,
e
.
Message
);
}
}
[
Test
]
...
...
@@ -139,12 +159,14 @@ namespace Google.ProtocolBuffers {
private
static
void
AssertReadLittleEndian32
(
byte
[]
data
,
uint
value
)
{
CodedInputStream
input
=
CodedInputStream
.
CreateInstance
(
data
);
Assert
.
AreEqual
(
value
,
input
.
ReadRawLittleEndian32
());
Assert
.
IsTrue
(
input
.
IsAtEnd
);
// Try different block sizes.
for
(
int
blockSize
=
1
;
blockSize
<=
16
;
blockSize
*=
2
)
{
input
=
CodedInputStream
.
CreateInstance
(
new
SmallBlockInputStream
(
data
,
blockSize
));
Assert
.
AreEqual
(
value
,
input
.
ReadRawLittleEndian32
());
Assert
.
IsTrue
(
input
.
IsAtEnd
);
}
}
...
...
@@ -155,12 +177,14 @@ namespace Google.ProtocolBuffers {
private
static
void
AssertReadLittleEndian64
(
byte
[]
data
,
ulong
value
)
{
CodedInputStream
input
=
CodedInputStream
.
CreateInstance
(
data
);
Assert
.
AreEqual
(
value
,
input
.
ReadRawLittleEndian64
());
Assert
.
IsTrue
(
input
.
IsAtEnd
);
// Try different block sizes.
for
(
int
blockSize
=
1
;
blockSize
<=
16
;
blockSize
*=
2
)
{
input
=
CodedInputStream
.
CreateInstance
(
new
SmallBlockInputStream
(
data
,
blockSize
));
Assert
.
AreEqual
(
value
,
input
.
ReadRawLittleEndian64
());
Assert
.
IsTrue
(
input
.
IsAtEnd
);
}
}
...
...
@@ -239,6 +263,21 @@ namespace Google.ProtocolBuffers {
}
}
/// <summary>
/// Test that a bug in SkipRawBytes has been fixed: if the skip
/// skips exactly up to a limit, this should bnot break things
/// </summary>
[
Test
]
public
void
SkipRawBytesBug
()
{
byte
[]
rawBytes
=
new
byte
[]
{
1
,
2
};
CodedInputStream
input
=
CodedInputStream
.
CreateInstance
(
rawBytes
);
int
limit
=
input
.
PushLimit
(
1
);
input
.
SkipRawBytes
(
1
);
input
.
PopLimit
(
limit
);
Assert
.
AreEqual
(
2
,
input
.
ReadRawByte
());
}
public
void
ReadHugeBlob
()
{
// Allocate and initialize a 1MB blob.
byte
[]
blob
=
new
byte
[
1
<<
20
];
...
...
@@ -348,6 +387,31 @@ namespace Google.ProtocolBuffers {
}
}
[
Test
]
public
void
ResetSizeCounter
()
{
CodedInputStream
input
=
CodedInputStream
.
CreateInstance
(
new
SmallBlockInputStream
(
new
byte
[
256
],
8
));
input
.
SetSizeLimit
(
16
);
input
.
ReadRawBytes
(
16
);
try
{
input
.
ReadRawByte
();
Assert
.
Fail
(
"Should have thrown an exception!"
);
}
catch
(
InvalidProtocolBufferException
e
)
{
// Success.
}
input
.
ResetSizeCounter
();
input
.
ReadRawByte
();
// No exception thrown.
try
{
input
.
ReadRawBytes
(
16
);
// Hits limit again.
Assert
.
Fail
(
"Should have thrown an exception!"
);
}
catch
(
InvalidProtocolBufferException
e
)
{
// Success.
}
}
/// <summary>
/// Tests that if we read an string that contains invalid UTF-8, no exception
/// is thrown. Instead, the invalid bytes are replaced with the Unicode
...
...
src/ProtocolBuffers.Test/DynamicMessageTest.cs
View file @
c298c892
...
...
@@ -32,6 +32,7 @@ using Google.ProtocolBuffers.TestProtos;
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
using
NUnit.Framework
;
using
System
;
namespace
Google.ProtocolBuffers
{
[
TestFixture
]
...
...
@@ -56,6 +57,18 @@ namespace Google.ProtocolBuffers {
reflectionTester
.
AssertAllFieldsSetViaReflection
(
message
);
}
[
Test
]
public
void
DoubleBuildError
()
{
DynamicMessage
.
Builder
builder
=
DynamicMessage
.
CreateBuilder
(
TestAllTypes
.
Descriptor
);
builder
.
Build
();
try
{
builder
.
Build
();
Assert
.
Fail
(
"Should have thrown exception."
);
}
catch
(
InvalidOperationException
e
)
{
// Success.
}
}
[
Test
]
public
void
DynamicMessageSettersRejectNull
()
{
IBuilder
builder
=
DynamicMessage
.
CreateBuilder
(
TestAllTypes
.
Descriptor
);
...
...
src/ProtocolBuffers.Test/GeneratedMessageTest.cs
View file @
c298c892
...
...
@@ -90,6 +90,18 @@ namespace Google.ProtocolBuffers {
}
}
[
Test
]
public
void
DoubleBuildError
()
{
TestAllTypes
.
Builder
builder
=
new
TestAllTypes
.
Builder
();
builder
.
Build
();
try
{
builder
.
Build
();
Assert
.
Fail
(
"Should have thrown exception."
);
}
catch
(
InvalidOperationException
e
)
{
// Success.
}
}
[
Test
]
public
void
DefaultInstance
()
{
Assert
.
AreSame
(
TestAllTypes
.
DefaultInstance
,
TestAllTypes
.
DefaultInstance
.
DefaultInstanceForType
);
...
...
@@ -367,7 +379,7 @@ namespace Google.ProtocolBuffers {
}
[
Test
]
public
void
Test
OptimizedForSizeMergeUsesAllFieldsFromTarget
()
{
public
void
OptimizedForSizeMergeUsesAllFieldsFromTarget
()
{
TestOptimizedForSize
withFieldSet
=
new
TestOptimizedForSize
.
Builder
{
I
=
10
}.
Build
();
TestOptimizedForSize
.
Builder
builder
=
new
TestOptimizedForSize
.
Builder
();
builder
.
MergeFrom
(
withFieldSet
);
...
...
src/ProtocolBuffers/AbstractBuilder.cs
View file @
c298c892
...
...
@@ -226,7 +226,7 @@ namespace Google.ProtocolBuffers {
}
public
TBuilder
MergeDelimitedFrom
(
Stream
input
,
ExtensionRegistry
extensionRegistry
)
{
int
size
=
CodedInputStream
.
ReadRawVarint32
(
input
);
int
size
=
(
int
)
CodedInputStream
.
ReadRawVarint32
(
input
);
Stream
limitedStream
=
new
LimitedInputStream
(
input
,
size
);
return
MergeFrom
(
limitedStream
,
extensionRegistry
);
}
...
...
src/ProtocolBuffers/CodedInputStream.cs
View file @
c298c892
...
...
@@ -466,7 +466,7 @@ namespace Google.ProtocolBuffers {
/// </summary>
/// <param name="input"></param>
/// <returns></returns>
internal
static
int
ReadRawVarint32
(
Stream
input
)
{
internal
static
u
int
ReadRawVarint32
(
Stream
input
)
{
int
result
=
0
;
int
offset
=
0
;
for
(;
offset
<
32
;
offset
+=
7
)
{
...
...
@@ -476,7 +476,7 @@ namespace Google.ProtocolBuffers {
}
result
|=
(
b
&
0x7f
)
<<
offset
;
if
((
b
&
0x80
)
==
0
)
{
return
result
;
return
(
uint
)
result
;
}
}
// Keep reading up to 64 bits.
...
...
@@ -486,7 +486,7 @@ namespace Google.ProtocolBuffers {
throw
InvalidProtocolBufferException
.
TruncatedMessage
();
}
if
((
b
&
0x80
)
==
0
)
{
return
result
;
return
(
uint
)
result
;
}
}
throw
InvalidProtocolBufferException
.
MalformedVarint
();
...
...
@@ -918,16 +918,33 @@ namespace Google.ProtocolBuffers {
// Then skip directly from the InputStream for the rest.
if
(
pos
<
size
)
{
// TODO(jonskeet): Java implementation uses skip(). Not sure whether this is really equivalent...
if
(
input
==
null
)
{
throw
InvalidProtocolBufferException
.
TruncatedMessage
();
}
SkipImpl
(
size
-
pos
);
totalBytesRetired
+=
size
-
pos
;
}
}
}
/// <summary>
/// Abstraction of skipping to cope with streams which can't really skip.
/// </summary>
private
void
SkipImpl
(
int
amountToSkip
)
{
if
(
input
.
CanSeek
)
{
long
previousPosition
=
input
.
Position
;
input
.
Position
+=
size
-
pos
;
if
(
input
.
Position
!=
previousPosition
+
size
-
pos
)
{
input
.
Position
+=
amountToSkip
;
if
(
input
.
Position
!=
previousPosition
+
amountToSkip
)
{
throw
InvalidProtocolBufferException
.
TruncatedMessage
();
}
totalBytesRetired
+=
size
-
pos
;
}
else
{
byte
[]
skipBuffer
=
new
byte
[
1024
];
while
(
amountToSkip
>
0
)
{
int
bytesRead
=
input
.
Read
(
skipBuffer
,
0
,
skipBuffer
.
Length
);
if
(
bytesRead
<=
0
)
{
throw
InvalidProtocolBufferException
.
TruncatedMessage
();
}
amountToSkip
-=
bytesRead
;
}
}
}
...
...
src/ProtocolBuffers/Descriptors/DescriptorPool.cs
View file @
c298c892
...
...
@@ -109,8 +109,7 @@ namespace Google.ProtocolBuffers.Descriptors {
"package) in file \""
+
old
.
File
.
Name
+
"\"."
);
}
}
// TODO(jonskeet): Check issue 25 wrt the ordering of these parameters
descriptorsByName
[
fullName
]
=
new
PackageDescriptor
(
fullName
,
name
,
file
);
descriptorsByName
[
fullName
]
=
new
PackageDescriptor
(
name
,
fullName
,
file
);
}
/// <summary>
...
...
src/ProtocolBuffers/DynamicMessage.cs
View file @
c298c892
...
...
@@ -296,7 +296,7 @@ namespace Google.ProtocolBuffers {
}
public
override
DynamicMessage
Build
()
{
if
(
!
IsInitialized
)
{
if
(
fields
!=
null
&&
!
IsInitialized
)
{
throw
new
UninitializedMessageException
(
new
DynamicMessage
(
type
,
fields
,
unknownFields
));
}
return
BuildPartial
();
...
...
@@ -315,6 +315,9 @@ namespace Google.ProtocolBuffers {
}
public
override
DynamicMessage
BuildPartial
()
{
if
(
fields
==
null
)
{
throw
new
InvalidOperationException
(
"Build() has already been called on this Builder."
);
}
fields
.
MakeImmutable
();
DynamicMessage
result
=
new
DynamicMessage
(
type
,
fields
,
unknownFields
);
fields
=
null
;
...
...
src/ProtocolBuffers/GeneratedBuilder.cs
View file @
c298c892
...
...
@@ -187,7 +187,8 @@ namespace Google.ProtocolBuffers {
/// Implementation of <see cref="IBuilder{TMessage, TBuilder}.Build" />.
/// </summary>
public
override
TMessage
Build
()
{
if
(!
IsInitialized
)
{
// If the message is null, we'll throw a more appropriate exception in BuildPartial.
if
(
MessageBeingBuilt
!=
null
&&
!
IsInitialized
)
{
throw
new
UninitializedMessageException
(
MessageBeingBuilt
);
}
return
BuildPartial
();
...
...
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