1 /******************************************************************************
2 
3  This source file is part of the Avogadro project.
4 
5  Copyright 2013 Kitware, Inc.
6 
7  This source code is released under the New BSD License, (the "License").
8 
9  Unless required by applicable law or agreed to in writing, software
10  distributed under the License is distributed on an "AS IS" BASIS,
11  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12  See the License for the specific language governing permissions and
13  limitations under the License.
14 
15  ******************************************************************************/
16 
17 #include "matrixserialization.h"
18 
19 #include <avogadro/core/vector.h>
20 #include <gtest/gtest.h>
21 
TEST(MatrixSerializationTest,vector2)22 TEST(MatrixSerializationTest, vector2)
23 {
24   Avogadro::Vector2 vec2;
25   vec2[0] = 1;
26   vec2[1] = 2;
27 
28   size_t size = Avogadro::ProtoCall::MatrixSerialization::sizeOf(vec2);
29   unsigned char* data = new unsigned char[size];
30 
31   bool success =
32     Avogadro::ProtoCall::MatrixSerialization::serialize(vec2, data, size);
33   EXPECT_TRUE(success);
34 
35   Avogadro::Vector2 afterRoundTrip;
36   success =
37     Avogadro::ProtoCall::MatrixSerialization::deserialize(afterRoundTrip, data);
38 
39   EXPECT_TRUE(success);
40 
41   delete[] data;
42 
43   for (int row = 0; row < 2; row++)
44     EXPECT_EQ(vec2[row], afterRoundTrip[row]);
45 }
46 
TEST(MatrixSerializationTest,vector3)47 TEST(MatrixSerializationTest, vector3)
48 {
49   Avogadro::Vector3 vec3;
50   vec3[0] = 1;
51   vec3[1] = 2;
52   vec3[2] = 3;
53 
54   size_t size = Avogadro::ProtoCall::MatrixSerialization::sizeOf(vec3);
55   unsigned char* data = new unsigned char[size];
56 
57   bool success =
58     Avogadro::ProtoCall::MatrixSerialization::serialize(vec3, data, size);
59 
60   EXPECT_TRUE(success);
61 
62   Avogadro::Vector3 afterRoundTrip;
63   success =
64     Avogadro::ProtoCall::MatrixSerialization::deserialize(afterRoundTrip, data);
65 
66   EXPECT_TRUE(success);
67 
68   delete[] data;
69 
70   for (int row = 0; row < 3; row++)
71     EXPECT_EQ(vec3[row], afterRoundTrip[row]);
72 }
73 
TEST(MatrixSerializationTest,matrixX)74 TEST(MatrixSerializationTest, matrixX)
75 {
76   Avogadro::MatrixX matrix(100, 100);
77 
78   for (int row = 0; row < 100; row++) {
79     for (int col = 0; col < 100; col++) {
80       matrix(row, col) = row * col;
81     }
82   }
83 
84   size_t size = Avogadro::ProtoCall::MatrixSerialization::sizeOf(matrix);
85 
86   unsigned char* data = new unsigned char[size];
87 
88   bool success =
89     Avogadro::ProtoCall::MatrixSerialization::serialize(matrix, data, size);
90 
91   EXPECT_TRUE(success);
92 
93   Avogadro::MatrixX afterRoundTrip(100, 100);
94   success = Avogadro::ProtoCall::MatrixSerialization::deserialize(
95     afterRoundTrip, data, size);
96 
97   EXPECT_TRUE(success);
98 
99   delete[] data;
100 
101   for (int row = 0; row < 100; row++) {
102     for (int col = 0; col < 100; col++)
103       EXPECT_EQ(matrix(row, col), afterRoundTrip(row, col));
104   }
105 }
106