blob: 9cedb34229fa031fae69e462aa6929def069e5f7 [file] [log] [blame]
Brian Silverman9c614bc2016-02-15 20:20:02 -05001// Protocol Buffers - Google's data interchange format
2// Copyright 2008 Google Inc. All rights reserved.
3// https://developers.google.com/protocol-buffers/
4//
5// Redistribution and use in source and binary forms, with or without
6// modification, are permitted provided that the following conditions are
7// met:
8//
9// * Redistributions of source code must retain the above copyright
10// notice, this list of conditions and the following disclaimer.
11// * Redistributions in binary form must reproduce the above
12// copyright notice, this list of conditions and the following disclaimer
13// in the documentation and/or other materials provided with the
14// distribution.
15// * Neither the name of Google Inc. nor the names of its
16// contributors may be used to endorse or promote products derived from
17// this software without specific prior written permission.
18//
19// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
20// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
21// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
22// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
23// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
24// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
25// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
26// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
27// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
28// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
29// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
30
31// Author: kenton@google.com (Kenton Varda)
32// Based on original Protocol Buffers design by
33// Sanjay Ghemawat, Jeff Dean, and others.
34
35#include <google/protobuf/reflection_ops.h>
36#include <google/protobuf/descriptor.h>
37#include <google/protobuf/unittest.pb.h>
38#include <google/protobuf/test_util.h>
39
40#include <google/protobuf/stubs/logging.h>
41#include <google/protobuf/stubs/common.h>
42#include <google/protobuf/testing/googletest.h>
43#include <gtest/gtest.h>
Austin Schuh40c16522018-10-28 20:27:54 -070044
Brian Silverman9c614bc2016-02-15 20:20:02 -050045#include <google/protobuf/stubs/strutil.h>
46
47namespace google {
48namespace protobuf {
49namespace internal {
50namespace {
51
52TEST(ReflectionOpsTest, SanityCheck) {
53 unittest::TestAllTypes message;
54
55 TestUtil::SetAllFields(&message);
56 TestUtil::ExpectAllFieldsSet(message);
57}
58
59TEST(ReflectionOpsTest, Copy) {
60 unittest::TestAllTypes message, message2;
61
62 TestUtil::SetAllFields(&message);
63
64 ReflectionOps::Copy(message, &message2);
65
66 TestUtil::ExpectAllFieldsSet(message2);
67
68 // Copying from self should be a no-op.
69 ReflectionOps::Copy(message2, &message2);
70 TestUtil::ExpectAllFieldsSet(message2);
71}
72
73TEST(ReflectionOpsTest, CopyExtensions) {
74 unittest::TestAllExtensions message, message2;
75
76 TestUtil::SetAllExtensions(&message);
77
78 ReflectionOps::Copy(message, &message2);
79
80 TestUtil::ExpectAllExtensionsSet(message2);
81}
82
83TEST(ReflectionOpsTest, CopyOneof) {
84 unittest::TestOneof2 message, message2;
85 TestUtil::SetOneof1(&message);
86 ReflectionOps::Copy(message, &message2);
87 TestUtil::ExpectOneofSet1(message2);
88
89 TestUtil::SetOneof2(&message);
90 TestUtil::ExpectOneofSet2(message);
91 ReflectionOps::Copy(message, &message2);
92 TestUtil::ExpectOneofSet2(message2);
93}
94
95TEST(ReflectionOpsTest, Merge) {
96 // Note: Copy is implemented in terms of Merge() so technically the Copy
97 // test already tested most of this.
98
99 unittest::TestAllTypes message, message2;
100
101 TestUtil::SetAllFields(&message);
102
103 // This field will test merging into an empty spot.
104 message2.set_optional_int32(message.optional_int32());
105 message.clear_optional_int32();
106
107 // This tests overwriting.
108 message2.set_optional_string(message.optional_string());
109 message.set_optional_string("something else");
110
111 // This tests concatenating.
112 message2.add_repeated_int32(message.repeated_int32(1));
113 int32 i = message.repeated_int32(0);
114 message.clear_repeated_int32();
115 message.add_repeated_int32(i);
116
117 ReflectionOps::Merge(message2, &message);
118
119 TestUtil::ExpectAllFieldsSet(message);
120}
121
122TEST(ReflectionOpsTest, MergeExtensions) {
123 // Note: Copy is implemented in terms of Merge() so technically the Copy
124 // test already tested most of this.
125
126 unittest::TestAllExtensions message, message2;
127
128 TestUtil::SetAllExtensions(&message);
129
130 // This field will test merging into an empty spot.
131 message2.SetExtension(unittest::optional_int32_extension,
132 message.GetExtension(unittest::optional_int32_extension));
133 message.ClearExtension(unittest::optional_int32_extension);
134
135 // This tests overwriting.
136 message2.SetExtension(unittest::optional_string_extension,
137 message.GetExtension(unittest::optional_string_extension));
138 message.SetExtension(unittest::optional_string_extension, "something else");
139
140 // This tests concatenating.
141 message2.AddExtension(unittest::repeated_int32_extension,
142 message.GetExtension(unittest::repeated_int32_extension, 1));
143 int32 i = message.GetExtension(unittest::repeated_int32_extension, 0);
144 message.ClearExtension(unittest::repeated_int32_extension);
145 message.AddExtension(unittest::repeated_int32_extension, i);
146
147 ReflectionOps::Merge(message2, &message);
148
149 TestUtil::ExpectAllExtensionsSet(message);
150}
151
152TEST(ReflectionOpsTest, MergeUnknown) {
153 // Test that the messages' UnknownFieldSets are correctly merged.
154 unittest::TestEmptyMessage message1, message2;
155 message1.mutable_unknown_fields()->AddVarint(1234, 1);
156 message2.mutable_unknown_fields()->AddVarint(1234, 2);
157
158 ReflectionOps::Merge(message2, &message1);
159
160 ASSERT_EQ(2, message1.unknown_fields().field_count());
161 ASSERT_EQ(UnknownField::TYPE_VARINT,
162 message1.unknown_fields().field(0).type());
163 EXPECT_EQ(1, message1.unknown_fields().field(0).varint());
164 ASSERT_EQ(UnknownField::TYPE_VARINT,
165 message1.unknown_fields().field(1).type());
166 EXPECT_EQ(2, message1.unknown_fields().field(1).varint());
167}
168
169TEST(ReflectionOpsTest, MergeOneof) {
170 unittest::TestOneof2 message1, message2;
171 TestUtil::SetOneof1(&message1);
172
173 // Merge to empty message
174 ReflectionOps::Merge(message1, &message2);
175 TestUtil::ExpectOneofSet1(message2);
176
177 // Merge with the same oneof fields
178 ReflectionOps::Merge(message1, &message2);
179 TestUtil::ExpectOneofSet1(message2);
180
181 // Merge with different oneof fields
182 TestUtil::SetOneof2(&message1);
183 ReflectionOps::Merge(message1, &message2);
184 TestUtil::ExpectOneofSet2(message2);
185}
186
187#ifdef PROTOBUF_HAS_DEATH_TEST
188
189TEST(ReflectionOpsTest, MergeFromSelf) {
190 // Note: Copy is implemented in terms of Merge() so technically the Copy
191 // test already tested most of this.
192
193 unittest::TestAllTypes message;
194
195 EXPECT_DEATH(
196 ReflectionOps::Merge(message, &message),
197 "&from");
198}
199
200#endif // PROTOBUF_HAS_DEATH_TEST
201
202TEST(ReflectionOpsTest, Clear) {
203 unittest::TestAllTypes message;
204
205 TestUtil::SetAllFields(&message);
206
207 ReflectionOps::Clear(&message);
208
209 TestUtil::ExpectClear(message);
210
211 // Check that getting embedded messages returns the objects created during
212 // SetAllFields() rather than default instances.
213 EXPECT_NE(&unittest::TestAllTypes::OptionalGroup::default_instance(),
214 &message.optionalgroup());
215 EXPECT_NE(&unittest::TestAllTypes::NestedMessage::default_instance(),
216 &message.optional_nested_message());
217 EXPECT_NE(&unittest::ForeignMessage::default_instance(),
218 &message.optional_foreign_message());
219 EXPECT_NE(&unittest_import::ImportMessage::default_instance(),
220 &message.optional_import_message());
221}
222
223TEST(ReflectionOpsTest, ClearExtensions) {
224 unittest::TestAllExtensions message;
225
226 TestUtil::SetAllExtensions(&message);
227
228 ReflectionOps::Clear(&message);
229
230 TestUtil::ExpectExtensionsClear(message);
231
232 // Check that getting embedded messages returns the objects created during
233 // SetAllExtensions() rather than default instances.
234 EXPECT_NE(&unittest::OptionalGroup_extension::default_instance(),
235 &message.GetExtension(unittest::optionalgroup_extension));
236 EXPECT_NE(&unittest::TestAllTypes::NestedMessage::default_instance(),
237 &message.GetExtension(unittest::optional_nested_message_extension));
238 EXPECT_NE(&unittest::ForeignMessage::default_instance(),
239 &message.GetExtension(
240 unittest::optional_foreign_message_extension));
241 EXPECT_NE(&unittest_import::ImportMessage::default_instance(),
242 &message.GetExtension(unittest::optional_import_message_extension));
243}
244
245TEST(ReflectionOpsTest, ClearUnknown) {
246 // Test that the message's UnknownFieldSet is correctly cleared.
247 unittest::TestEmptyMessage message;
248 message.mutable_unknown_fields()->AddVarint(1234, 1);
249
250 ReflectionOps::Clear(&message);
251
252 EXPECT_EQ(0, message.unknown_fields().field_count());
253}
254
255TEST(ReflectionOpsTest, ClearOneof) {
256 unittest::TestOneof2 message;
257
258 TestUtil::ExpectOneofClear(message);
259 TestUtil::SetOneof1(&message);
260 TestUtil::ExpectOneofSet1(message);
261 ReflectionOps::Clear(&message);
262 TestUtil::ExpectOneofClear(message);
263
264 TestUtil::SetOneof1(&message);
265 TestUtil::ExpectOneofSet1(message);
266 TestUtil::SetOneof2(&message);
267 TestUtil::ExpectOneofSet2(message);
268 ReflectionOps::Clear(&message);
269 TestUtil::ExpectOneofClear(message);
270}
271
272TEST(ReflectionOpsTest, DiscardUnknownFields) {
273 unittest::TestAllTypes message;
274 TestUtil::SetAllFields(&message);
275
276 // Set some unknown fields in message.
277 message.mutable_unknown_fields()
278 ->AddVarint(123456, 654321);
279 message.mutable_optional_nested_message()
280 ->mutable_unknown_fields()
281 ->AddVarint(123456, 654321);
282 message.mutable_repeated_nested_message(0)
283 ->mutable_unknown_fields()
284 ->AddVarint(123456, 654321);
285
286 EXPECT_EQ(1, message.unknown_fields().field_count());
287 EXPECT_EQ(1, message.optional_nested_message()
288 .unknown_fields().field_count());
289 EXPECT_EQ(1, message.repeated_nested_message(0)
290 .unknown_fields().field_count());
291
292 // Discard them.
293 ReflectionOps::DiscardUnknownFields(&message);
294 TestUtil::ExpectAllFieldsSet(message);
295
296 EXPECT_EQ(0, message.unknown_fields().field_count());
297 EXPECT_EQ(0, message.optional_nested_message()
298 .unknown_fields().field_count());
299 EXPECT_EQ(0, message.repeated_nested_message(0)
300 .unknown_fields().field_count());
301}
302
303TEST(ReflectionOpsTest, DiscardUnknownExtensions) {
304 unittest::TestAllExtensions message;
305 TestUtil::SetAllExtensions(&message);
306
307 // Set some unknown fields.
308 message.mutable_unknown_fields()
309 ->AddVarint(123456, 654321);
310 message.MutableExtension(unittest::optional_nested_message_extension)
311 ->mutable_unknown_fields()
312 ->AddVarint(123456, 654321);
313 message.MutableExtension(unittest::repeated_nested_message_extension, 0)
314 ->mutable_unknown_fields()
315 ->AddVarint(123456, 654321);
316
317 EXPECT_EQ(1, message.unknown_fields().field_count());
318 EXPECT_EQ(1,
319 message.GetExtension(unittest::optional_nested_message_extension)
320 .unknown_fields().field_count());
321 EXPECT_EQ(1,
322 message.GetExtension(unittest::repeated_nested_message_extension, 0)
323 .unknown_fields().field_count());
324
325 // Discard them.
326 ReflectionOps::DiscardUnknownFields(&message);
327 TestUtil::ExpectAllExtensionsSet(message);
328
329 EXPECT_EQ(0, message.unknown_fields().field_count());
330 EXPECT_EQ(0,
331 message.GetExtension(unittest::optional_nested_message_extension)
332 .unknown_fields().field_count());
333 EXPECT_EQ(0,
334 message.GetExtension(unittest::repeated_nested_message_extension, 0)
335 .unknown_fields().field_count());
336}
337
338TEST(ReflectionOpsTest, IsInitialized) {
339 unittest::TestRequired message;
340
341 EXPECT_FALSE(ReflectionOps::IsInitialized(message));
342 message.set_a(1);
343 EXPECT_FALSE(ReflectionOps::IsInitialized(message));
344 message.set_b(2);
345 EXPECT_FALSE(ReflectionOps::IsInitialized(message));
346 message.set_c(3);
347 EXPECT_TRUE(ReflectionOps::IsInitialized(message));
348}
349
350TEST(ReflectionOpsTest, ForeignIsInitialized) {
351 unittest::TestRequiredForeign message;
352
353 // Starts out initialized because the foreign message is itself an optional
354 // field.
355 EXPECT_TRUE(ReflectionOps::IsInitialized(message));
356
357 // Once we create that field, the message is no longer initialized.
358 message.mutable_optional_message();
359 EXPECT_FALSE(ReflectionOps::IsInitialized(message));
360
361 // Initialize it. Now we're initialized.
362 message.mutable_optional_message()->set_a(1);
363 message.mutable_optional_message()->set_b(2);
364 message.mutable_optional_message()->set_c(3);
365 EXPECT_TRUE(ReflectionOps::IsInitialized(message));
366
367 // Add a repeated version of the message. No longer initialized.
368 unittest::TestRequired* sub_message = message.add_repeated_message();
369 EXPECT_FALSE(ReflectionOps::IsInitialized(message));
370
371 // Initialize that repeated version.
372 sub_message->set_a(1);
373 sub_message->set_b(2);
374 sub_message->set_c(3);
375 EXPECT_TRUE(ReflectionOps::IsInitialized(message));
376}
377
378TEST(ReflectionOpsTest, ExtensionIsInitialized) {
379 unittest::TestAllExtensions message;
380
381 // Starts out initialized because the foreign message is itself an optional
382 // field.
383 EXPECT_TRUE(ReflectionOps::IsInitialized(message));
384
385 // Once we create that field, the message is no longer initialized.
386 message.MutableExtension(unittest::TestRequired::single);
387 EXPECT_FALSE(ReflectionOps::IsInitialized(message));
388
389 // Initialize it. Now we're initialized.
390 message.MutableExtension(unittest::TestRequired::single)->set_a(1);
391 message.MutableExtension(unittest::TestRequired::single)->set_b(2);
392 message.MutableExtension(unittest::TestRequired::single)->set_c(3);
393 EXPECT_TRUE(ReflectionOps::IsInitialized(message));
394
395 // Add a repeated version of the message. No longer initialized.
396 message.AddExtension(unittest::TestRequired::multi);
397 EXPECT_FALSE(ReflectionOps::IsInitialized(message));
398
399 // Initialize that repeated version.
400 message.MutableExtension(unittest::TestRequired::multi, 0)->set_a(1);
401 message.MutableExtension(unittest::TestRequired::multi, 0)->set_b(2);
402 message.MutableExtension(unittest::TestRequired::multi, 0)->set_c(3);
403 EXPECT_TRUE(ReflectionOps::IsInitialized(message));
404}
405
406TEST(ReflectionOpsTest, OneofIsInitialized) {
407 unittest::TestRequiredOneof message;
408 EXPECT_TRUE(ReflectionOps::IsInitialized(message));
409
410 message.mutable_foo_message();
411 EXPECT_FALSE(ReflectionOps::IsInitialized(message));
412
413 message.set_foo_int(1);
414 EXPECT_TRUE(ReflectionOps::IsInitialized(message));
415
416 message.mutable_foo_message();
417 EXPECT_FALSE(ReflectionOps::IsInitialized(message));
418 message.mutable_foo_message()->set_required_double(0.1);
419 EXPECT_TRUE(ReflectionOps::IsInitialized(message));
420}
421
422static string FindInitializationErrors(const Message& message) {
Austin Schuh40c16522018-10-28 20:27:54 -0700423 std::vector<string> errors;
Brian Silverman9c614bc2016-02-15 20:20:02 -0500424 ReflectionOps::FindInitializationErrors(message, "", &errors);
425 return Join(errors, ",");
426}
427
428TEST(ReflectionOpsTest, FindInitializationErrors) {
429 unittest::TestRequired message;
430 EXPECT_EQ("a,b,c", FindInitializationErrors(message));
431}
432
433TEST(ReflectionOpsTest, FindForeignInitializationErrors) {
434 unittest::TestRequiredForeign message;
435 message.mutable_optional_message();
436 message.add_repeated_message();
437 message.add_repeated_message();
438 EXPECT_EQ("optional_message.a,"
439 "optional_message.b,"
440 "optional_message.c,"
441 "repeated_message[0].a,"
442 "repeated_message[0].b,"
443 "repeated_message[0].c,"
444 "repeated_message[1].a,"
445 "repeated_message[1].b,"
446 "repeated_message[1].c",
447 FindInitializationErrors(message));
448}
449
450TEST(ReflectionOpsTest, FindExtensionInitializationErrors) {
451 unittest::TestAllExtensions message;
452 message.MutableExtension(unittest::TestRequired::single);
453 message.AddExtension(unittest::TestRequired::multi);
454 message.AddExtension(unittest::TestRequired::multi);
455 EXPECT_EQ("(protobuf_unittest.TestRequired.single).a,"
456 "(protobuf_unittest.TestRequired.single).b,"
457 "(protobuf_unittest.TestRequired.single).c,"
458 "(protobuf_unittest.TestRequired.multi)[0].a,"
459 "(protobuf_unittest.TestRequired.multi)[0].b,"
460 "(protobuf_unittest.TestRequired.multi)[0].c,"
461 "(protobuf_unittest.TestRequired.multi)[1].a,"
462 "(protobuf_unittest.TestRequired.multi)[1].b,"
463 "(protobuf_unittest.TestRequired.multi)[1].c",
464 FindInitializationErrors(message));
465}
466
467TEST(ReflectionOpsTest, FindOneofInitializationErrors) {
468 unittest::TestRequiredOneof message;
469 message.mutable_foo_message();
470 EXPECT_EQ("foo_message.required_double",
471 FindInitializationErrors(message));
472}
473
474} // namespace
475} // namespace internal
476} // namespace protobuf
477} // namespace google