blob: 3be830a73aac0d245ab74a585e573ddb4e331365 [file] [log] [blame]
Jon Skeet0aac0e42009-09-09 18:48:02 +01001#region Copyright notice and license
Jon Skeetad748532009-06-25 16:55:58 +01002// Protocol Buffers - Google's data interchange format
3// Copyright 2008 Google Inc. All rights reserved.
4// http://github.com/jskeet/dotnet-protobufs/
5// Original C++/Java/Python code:
6// http://code.google.com/p/protobuf/
7//
8// Redistribution and use in source and binary forms, with or without
9// modification, are permitted provided that the following conditions are
10// met:
11//
12// * Redistributions of source code must retain the above copyright
13// notice, this list of conditions and the following disclaimer.
14// * Redistributions in binary form must reproduce the above
15// copyright notice, this list of conditions and the following disclaimer
16// in the documentation and/or other materials provided with the
17// distribution.
18// * Neither the name of Google Inc. nor the names of its
19// contributors may be used to endorse or promote products derived from
20// this software without specific prior written permission.
21//
22// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
23// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
24// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
25// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
26// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
27// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
28// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
29// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
30// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
31// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
32// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
Jon Skeet0aac0e42009-09-09 18:48:02 +010033#endregion
34
Jon Skeet60c059b2008-10-23 21:17:56 +010035using System.IO;
Jon Skeet68036862008-10-22 13:30:34 +010036using NUnit.Framework;
37using NestedMessage = Google.ProtocolBuffers.TestProtos.TestAllTypes.Types.NestedMessage;
38
39namespace Google.ProtocolBuffers {
40 [TestFixture]
41 public class MessageStreamWriterTest {
42
43 internal static readonly byte[] ThreeMessageData = new byte[] {
44 (1 << 3) | 2, 2, // Field 1, 2 bytes long (first message)
45 (1 << 3) | 0, 5, // Field 1, value 5
46 (1 << 3) | 2, 3, // Field 1, 3 bytes long (second message)
47 (1 << 3) | 0, (1500 & 0x7f) | 0x80, 1500 >> 7, // Field 1, value 1500
48 (1 << 3) | 2, 0, // Field 1, no data (third message)
49 };
50
51 [Test]
52 public void ThreeMessages() {
53 NestedMessage message1 = new NestedMessage.Builder { Bb = 5 }.Build();
54 NestedMessage message2 = new NestedMessage.Builder { Bb = 1500 }.Build();
55 NestedMessage message3 = new NestedMessage.Builder().Build();
56
57 byte[] data;
58 using (MemoryStream stream = new MemoryStream()) {
59 MessageStreamWriter<NestedMessage> writer = new MessageStreamWriter<NestedMessage>(stream);
60 writer.Write(message1);
61 writer.Write(message2);
62 writer.Write(message3);
63 writer.Flush();
64 data = stream.ToArray();
65 }
66
67 TestUtil.AssertEqualBytes(ThreeMessageData, data);
68 }
69 }
70}