1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20 package org.apache.mina.codec.delimited.serialization;
21
22 import static org.junit.Assert.assertEquals;
23
24 import java.util.LinkedList;
25 import java.util.List;
26
27 import org.apache.mina.codec.IoBuffer;
28 import org.apache.mina.codec.delimited.ByteBufferEncoder;
29 import org.apache.mina.codec.delimited.IoBufferDecoder;
30 import org.apache.mina.codec.delimited.serialization.ProtobufDynamicMessageDecoder.ProtobufSerializedMessage;
31 import org.apache.mina.generated.protoc.AddressBookProtos.Person;
32 import org.junit.Test;
33
34
35
36
37
38
39 public class ProtobufTest extends GenericSerializerTest<Person> {
40
41 @Override
42 public List<Person> getObjects() {
43 List<Person> list = new LinkedList<Person>();
44
45 list.add(Person.newBuilder().setId(1).setName("Jean Dupond")
46 .setEmail("john.white@bigcorp.com").build());
47 list.add(Person.newBuilder().setId(2).setName("Marie Blanc")
48 .setEmail("marie.blanc@bigcorp.com").build());
49
50 return list;
51 }
52
53 @Override
54 public IoBufferDecoder<Person> getDecoder() throws Exception {
55 return ProtobufMessageDecoder.newInstance(Person.class);
56 }
57
58 @Override
59 public ByteBufferEncoder<Person> getEncoder() throws Exception {
60 return new ProtobufMessageEncoder<Person>();
61 }
62
63 @Test
64 public void testDynamic() throws Exception {
65 ByteBufferEncoder<Person> encoder = getEncoder();
66 ProtobufDynamicMessageDecoder decoder = new ProtobufDynamicMessageDecoder();
67
68 for (Person object : getObjects()) {
69 ProtobufSerializedMessage message = decoder.decode(IoBuffer
70 .wrap(encoder.encode(object)));
71 assertEquals(object, message.get(Person.class));
72 }
73 }
74 }