msg_test.cc
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2009-2021, Google LLC
3  * All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions are met:
7  * * Redistributions of source code must retain the above copyright
8  * notice, this list of conditions and the following disclaimer.
9  * * Redistributions in binary form must reproduce the above copyright
10  * notice, this list of conditions and the following disclaimer in the
11  * documentation and/or other materials provided with the distribution.
12  * * Neither the name of Google LLC nor the
13  * names of its contributors may be used to endorse or promote products
14  * derived from this software without specific prior written permission.
15  *
16  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
17  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
18  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
19  * ARE DISCLAIMED. IN NO EVENT SHALL Google LLC BE LIABLE FOR ANY DIRECT,
20  * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
21  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
22  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
23  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
24  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
25  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26  */
27 
28 #include "gmock/gmock.h"
29 #include "gtest/gtest.h"
30 #include "src/google/protobuf/test_messages_proto3.upb.h"
31 #include "upb/def.hpp"
32 #include "upb/json_decode.h"
33 #include "upb/json_encode.h"
34 #include "upb/msg_test.upb.h"
35 #include "upb/msg_test.upbdefs.h"
36 #include "upb/upb.hpp"
37 
38 void VerifyMessage(const upb_test_TestExtensions* ext_msg) {
39  EXPECT_TRUE(upb_test_TestExtensions_has_optional_int32_ext(ext_msg));
40  // EXPECT_FALSE(upb_test_TestExtensions_Nested_has_optional_int32_ext(ext_msg));
41  EXPECT_TRUE(upb_test_has_optional_msg_ext(ext_msg));
42 
43  EXPECT_EQ(123, upb_test_TestExtensions_optional_int32_ext(ext_msg));
44  const protobuf_test_messages_proto3_TestAllTypesProto3* ext_submsg =
45  upb_test_optional_msg_ext(ext_msg);
46  EXPECT_TRUE(ext_submsg != nullptr);
47  EXPECT_EQ(456,
48  protobuf_test_messages_proto3_TestAllTypesProto3_optional_int32(
49  ext_submsg));
50 }
51 
52 TEST(MessageTest, Extensions) {
54  upb_test_TestExtensions* ext_msg = upb_test_TestExtensions_new(arena.ptr());
55 
56  EXPECT_FALSE(upb_test_TestExtensions_has_optional_int32_ext(ext_msg));
57  // EXPECT_FALSE(upb_test_TestExtensions_Nested_has_optional_int32_ext(ext_msg));
58  EXPECT_FALSE(upb_test_has_optional_msg_ext(ext_msg));
59 
61  upb::MessageDefPtr m(upb_test_TestExtensions_getmsgdef(symtab.ptr()));
62  EXPECT_TRUE(m.ptr() != nullptr);
63 
64  std::string json = R"json(
65  {
66  "[upb_test.TestExtensions.optional_int32_ext]": 123,
67  "[upb_test.TestExtensions.Nested.repeated_int32_ext]": [2, 4, 6],
68  "[upb_test.optional_msg_ext]": {"optional_int32": 456}
69  }
70  )json";
72  EXPECT_TRUE(upb_JsonDecode(json.data(), json.size(), ext_msg, m.ptr(),
73  symtab.ptr(), 0, arena.ptr(), status.ptr()))
74  << status.error_message();
75 
76  VerifyMessage(ext_msg);
77 
78  // Test round-trip through binary format.
79  size_t size;
80  char* serialized =
81  upb_test_TestExtensions_serialize(ext_msg, arena.ptr(), &size);
82  ASSERT_TRUE(serialized != nullptr);
83  ASSERT_GE(size, 0);
84 
85  upb_test_TestExtensions* ext_msg2 = upb_test_TestExtensions_parse_ex(
86  serialized, size, upb_DefPool_ExtensionRegistry(symtab.ptr()), 0,
87  arena.ptr());
88  VerifyMessage(ext_msg2);
89 
90  // Test round-trip through JSON format.
91  size_t json_size =
92  upb_JsonEncode(ext_msg, m.ptr(), symtab.ptr(), 0, NULL, 0, status.ptr());
93  char* json_buf =
94  static_cast<char*>(upb_Arena_Malloc(arena.ptr(), json_size + 1));
95  upb_JsonEncode(ext_msg, m.ptr(), symtab.ptr(), 0, json_buf, json_size + 1,
96  status.ptr());
97  upb_test_TestExtensions* ext_msg3 = upb_test_TestExtensions_new(arena.ptr());
98  EXPECT_TRUE(upb_JsonDecode(json_buf, json_size, ext_msg3, m.ptr(),
99  symtab.ptr(), 0, arena.ptr(), status.ptr()))
100  << status.error_message();
101  VerifyMessage(ext_msg3);
102 }
103 
104 void VerifyMessageSet(const upb_test_TestMessageSet* mset_msg) {
105  bool has = upb_test_MessageSetMember_has_message_set_extension(mset_msg);
106  EXPECT_TRUE(has);
107  if (!has) return;
108  const upb_test_MessageSetMember* member =
109  upb_test_MessageSetMember_message_set_extension(mset_msg);
110  EXPECT_TRUE(member != nullptr);
111  EXPECT_TRUE(upb_test_MessageSetMember_has_optional_int32(member));
112  EXPECT_EQ(234, upb_test_MessageSetMember_optional_int32(member));
113 }
114 
115 TEST(MessageTest, MessageSet) {
117  upb_test_TestMessageSet* ext_msg = upb_test_TestMessageSet_new(arena.ptr());
118 
119  EXPECT_FALSE(upb_test_MessageSetMember_has_message_set_extension(ext_msg));
120 
122  upb::MessageDefPtr m(upb_test_TestMessageSet_getmsgdef(symtab.ptr()));
123  EXPECT_TRUE(m.ptr() != nullptr);
124 
125  std::string json = R"json(
126  {
127  "[upb_test.MessageSetMember]": {"optional_int32": 234}
128  }
129  )json";
131  EXPECT_TRUE(upb_JsonDecode(json.data(), json.size(), ext_msg, m.ptr(),
132  symtab.ptr(), 0, arena.ptr(), status.ptr()))
133  << status.error_message();
134 
135  VerifyMessageSet(ext_msg);
136 
137  // Test round-trip through binary format.
138  size_t size;
139  char* serialized =
140  upb_test_TestMessageSet_serialize(ext_msg, arena.ptr(), &size);
141  ASSERT_TRUE(serialized != nullptr);
142  ASSERT_GE(size, 0);
143 
144  upb_test_TestMessageSet* ext_msg2 = upb_test_TestMessageSet_parse_ex(
145  serialized, size, upb_DefPool_ExtensionRegistry(symtab.ptr()), 0,
146  arena.ptr());
147  VerifyMessageSet(ext_msg2);
148 
149  // Test round-trip through JSON format.
150  size_t json_size =
151  upb_JsonEncode(ext_msg, m.ptr(), symtab.ptr(), 0, NULL, 0, status.ptr());
152  char* json_buf =
153  static_cast<char*>(upb_Arena_Malloc(arena.ptr(), json_size + 1));
154  upb_JsonEncode(ext_msg, m.ptr(), symtab.ptr(), 0, json_buf, json_size + 1,
155  status.ptr());
156  upb_test_TestMessageSet* ext_msg3 = upb_test_TestMessageSet_new(arena.ptr());
157  EXPECT_TRUE(upb_JsonDecode(json_buf, json_size, ext_msg3, m.ptr(),
158  symtab.ptr(), 0, arena.ptr(), status.ptr()))
159  << status.error_message();
160  VerifyMessageSet(ext_msg3);
161 }
162 
163 TEST(MessageTest, Proto2Enum) {
165  upb_test_Proto2FakeEnumMessage* fake_msg =
166  upb_test_Proto2FakeEnumMessage_new(arena.ptr());
167 
168  upb_test_Proto2FakeEnumMessage_set_optional_enum(fake_msg, 999);
169 
170  int32_t* vals = upb_test_Proto2FakeEnumMessage_resize_repeated_enum(
171  fake_msg, 6, arena.ptr());
172  vals[0] = upb_test_Proto2EnumMessage_ZERO;
173  vals[1] = 7; // Unknown small.
174  vals[2] = upb_test_Proto2EnumMessage_SMALL;
175  vals[3] = 888; // Unknown large.
176  vals[4] = upb_test_Proto2EnumMessage_LARGE;
177  vals[5] = upb_test_Proto2EnumMessage_NEGATIVE;
178 
179  vals = upb_test_Proto2FakeEnumMessage_resize_packed_enum(fake_msg, 6,
180  arena.ptr());
181  vals[0] = upb_test_Proto2EnumMessage_ZERO;
182  vals[1] = 7; // Unknown small.
183  vals[2] = upb_test_Proto2EnumMessage_SMALL;
184  vals[3] = 888; // Unknown large.
185  vals[4] = upb_test_Proto2EnumMessage_LARGE;
186  vals[5] = upb_test_Proto2EnumMessage_NEGATIVE;
187 
188  size_t size;
189  char* pb =
190  upb_test_Proto2FakeEnumMessage_serialize(fake_msg, arena.ptr(), &size);
191 
192  // Parsing as enums puts unknown values into unknown fields.
193  upb_test_Proto2EnumMessage* enum_msg =
194  upb_test_Proto2EnumMessage_parse(pb, size, arena.ptr());
195  ASSERT_TRUE(enum_msg != nullptr);
196 
197  EXPECT_EQ(false, upb_test_Proto2EnumMessage_has_optional_enum(enum_msg));
198  const int32_t* vals_const =
199  upb_test_Proto2EnumMessage_repeated_enum(enum_msg, &size);
200  EXPECT_EQ(4, size); // Two unknown values moved to the unknown field set.
201 
202  // Parsing back into the fake message shows the original data, except the
203  // repeated enum is rearranged.
204  pb = upb_test_Proto2EnumMessage_serialize(enum_msg, arena.ptr(), &size);
205  upb_test_Proto2FakeEnumMessage* fake_msg2 =
206  upb_test_Proto2FakeEnumMessage_parse(pb, size, arena.ptr());
207 
208  EXPECT_EQ(true, upb_test_Proto2FakeEnumMessage_has_optional_enum(fake_msg2));
209  EXPECT_EQ(999, upb_test_Proto2FakeEnumMessage_optional_enum(fake_msg2));
210 
211  int32_t expected[] = {
212  upb_test_Proto2EnumMessage_ZERO,
213  upb_test_Proto2EnumMessage_SMALL,
214  upb_test_Proto2EnumMessage_LARGE,
215  upb_test_Proto2EnumMessage_NEGATIVE,
216  7,
217  888,
218  };
219 
220  vals_const = upb_test_Proto2FakeEnumMessage_repeated_enum(fake_msg2, &size);
221  EXPECT_EQ(6, size);
222  EXPECT_THAT(std::vector<int32_t>(vals_const, vals_const + size),
223  ::testing::ElementsAreArray(expected));
224 
225  vals_const = upb_test_Proto2FakeEnumMessage_packed_enum(fake_msg2, &size);
226  EXPECT_EQ(6, size);
227  EXPECT_THAT(std::vector<int32_t>(vals_const, vals_const + size),
228  ::testing::ElementsAreArray(expected));
229 }
230 
231 TEST(MessageTest, TestBadUTF8) {
233  std::string serialized("r\x03\xed\xa0\x81");
234  EXPECT_EQ(nullptr, protobuf_test_messages_proto3_TestAllTypesProto3_parse(
235  serialized.data(), serialized.size(), arena.ptr()));
236 }
237 
238 TEST(MessageTest, DecodeRequiredFieldsTopLevelMessage) {
240  upb_test_TestRequiredFields* test_msg;
241  upb_test_EmptyMessage* empty_msg;
242 
243  // Succeeds, because we did not request required field checks.
244  test_msg = upb_test_TestRequiredFields_parse(NULL, 0, arena.ptr());
245  EXPECT_NE(nullptr, test_msg);
246 
247  // Fails, because required fields are missing.
249  upb_Decode(NULL, 0, test_msg, &upb_test_TestRequiredFields_msginit,
250  NULL, kUpb_DecodeOption_CheckRequired, arena.ptr()));
251 
252  upb_test_TestRequiredFields_set_required_int32(test_msg, 1);
253  size_t size;
254  char* serialized =
255  upb_test_TestRequiredFields_serialize(test_msg, arena.ptr(), &size);
256  ASSERT_TRUE(serialized != nullptr);
257  EXPECT_NE(0, size);
258 
259  // Fails, but the code path is slightly different because the serialized
260  // payload is not empty.
262  upb_Decode(serialized, size, test_msg,
263  &upb_test_TestRequiredFields_msginit, NULL,
265 
266  empty_msg = upb_test_EmptyMessage_new(arena.ptr());
267  upb_test_TestRequiredFields_set_required_int32(test_msg, 1);
268  upb_test_TestRequiredFields_set_required_int64(test_msg, 2);
269  upb_test_TestRequiredFields_set_required_message(test_msg, empty_msg);
270 
271  // Succeeds, because required fields are present (though not in the input).
273  upb_Decode(NULL, 0, test_msg, &upb_test_TestRequiredFields_msginit,
274  NULL, kUpb_DecodeOption_CheckRequired, arena.ptr()));
275 
276  // Serialize a complete payload.
277  serialized =
278  upb_test_TestRequiredFields_serialize(test_msg, arena.ptr(), &size);
279  ASSERT_TRUE(serialized != nullptr);
280  EXPECT_NE(0, size);
281 
282  upb_test_TestRequiredFields* test_msg2 = upb_test_TestRequiredFields_parse_ex(
283  serialized, size, NULL, kUpb_DecodeOption_CheckRequired, arena.ptr());
284  EXPECT_NE(nullptr, test_msg2);
285 
286  // When we add an incomplete sub-message, this is not flagged by the parser.
287  // This makes parser checking unsuitable for MergeFrom().
288  upb_test_TestRequiredFields_set_optional_message(
289  test_msg2, upb_test_TestRequiredFields_new(arena.ptr()));
291  upb_Decode(serialized, size, test_msg2,
292  &upb_test_TestRequiredFields_msginit, NULL,
294 }
295 
296 TEST(MessageTest, DecodeRequiredFieldsSubMessage) {
298  upb_test_TestRequiredFields* test_msg =
299  upb_test_TestRequiredFields_new(arena.ptr());
300  upb_test_SubMessageHasRequired* sub_msg =
301  upb_test_SubMessageHasRequired_new(arena.ptr());
302  upb_test_EmptyMessage* empty_msg = upb_test_EmptyMessage_new(arena.ptr());
303 
304  upb_test_SubMessageHasRequired_set_optional_message(sub_msg, test_msg);
305  size_t size;
306  char* serialized =
307  upb_test_SubMessageHasRequired_serialize(sub_msg, arena.ptr(), &size);
308  EXPECT_NE(0, size);
309 
310  // No parse error when parsing normally.
311  EXPECT_NE(nullptr, upb_test_SubMessageHasRequired_parse(serialized, size,
312  arena.ptr()));
313 
314  // Parse error when verifying required fields, due to incomplete sub-message.
315  EXPECT_EQ(nullptr, upb_test_SubMessageHasRequired_parse_ex(
316  serialized, size, NULL,
318 
319  upb_test_TestRequiredFields_set_required_int32(test_msg, 1);
320  upb_test_TestRequiredFields_set_required_int64(test_msg, 2);
321  upb_test_TestRequiredFields_set_required_message(test_msg, empty_msg);
322 
323  serialized =
324  upb_test_SubMessageHasRequired_serialize(sub_msg, arena.ptr(), &size);
325  EXPECT_NE(0, size);
326 
327  // No parse error; sub-message now is complete.
328  EXPECT_NE(nullptr, upb_test_SubMessageHasRequired_parse_ex(
329  serialized, size, NULL,
331 }
332 
333 TEST(MessageTest, EncodeRequiredFields) {
335  upb_test_TestRequiredFields* test_msg =
336  upb_test_TestRequiredFields_new(arena.ptr());
337 
338  // Succeeds, we didn't ask for required field checking.
339  size_t size;
340  char* serialized =
341  upb_test_TestRequiredFields_serialize_ex(test_msg, 0, arena.ptr(), &size);
342  ASSERT_TRUE(serialized != nullptr);
343  EXPECT_EQ(size, 0);
344 
345  // Fails, we asked for required field checking but the required field is
346  // missing.
347  serialized = upb_test_TestRequiredFields_serialize_ex(
348  test_msg, kUpb_Encode_CheckRequired, arena.ptr(), &size);
349  ASSERT_TRUE(serialized == nullptr);
350 
351  // Fails, some required fields are present but not others.
352  upb_test_TestRequiredFields_set_required_int32(test_msg, 1);
353  serialized = upb_test_TestRequiredFields_serialize_ex(
354  test_msg, kUpb_Encode_CheckRequired, arena.ptr(), &size);
355  ASSERT_TRUE(serialized == nullptr);
356 
357  // Succeeds, all required fields are set.
358  upb_test_EmptyMessage* empty_msg = upb_test_EmptyMessage_new(arena.ptr());
359  upb_test_TestRequiredFields_set_required_int64(test_msg, 2);
360  upb_test_TestRequiredFields_set_required_message(test_msg, empty_msg);
361  serialized = upb_test_TestRequiredFields_serialize_ex(
362  test_msg, kUpb_Encode_CheckRequired, arena.ptr(), &size);
363  ASSERT_TRUE(serialized != nullptr);
364 }
365 
366 TEST(MessageTest, MaxRequiredFields) {
368  upb_test_TestMaxRequiredFields* test_msg =
369  upb_test_TestMaxRequiredFields_new(arena.ptr());
370 
371  // Fails, we asked for required field checking but the required field is
372  // missing.
373  size_t size;
374  char* serialized = upb_test_TestMaxRequiredFields_serialize_ex(
375  test_msg, kUpb_Encode_CheckRequired, arena.ptr(), &size);
376  ASSERT_TRUE(serialized == nullptr);
377 
379  upb::MessageDefPtr m(upb_test_TestMaxRequiredFields_getmsgdef(symtab.ptr()));
380  upb_MessageValue val;
381  val.int32_val = 1;
382  for (int i = 1; i <= 61; i++) {
383  upb::FieldDefPtr f = m.FindFieldByNumber(i);
384  ASSERT_TRUE(f);
385  upb_Message_Set(test_msg, f.ptr(), val, arena.ptr());
386  }
387 
388  // Fails, field 63 still isn't set.
389  serialized = upb_test_TestMaxRequiredFields_serialize_ex(
390  test_msg, kUpb_Encode_CheckRequired, arena.ptr(), &size);
391  ASSERT_TRUE(serialized == nullptr);
392 
393  // Succeeds, all required fields are set.
394  upb::FieldDefPtr f = m.FindFieldByNumber(62);
395  ASSERT_TRUE(f);
396  upb_Message_Set(test_msg, f.ptr(), val, arena.ptr());
397  serialized = upb_test_TestMaxRequiredFields_serialize_ex(
398  test_msg, kUpb_Encode_CheckRequired, arena.ptr(), &size);
399  ASSERT_TRUE(serialized != nullptr);
400 }
401 
402 TEST(MessageTest, MapField) {
404  upb_test_TestMapFieldExtra* test_msg_extra =
405  upb_test_TestMapFieldExtra_new(arena.ptr());
406 
407  ASSERT_TRUE(upb_test_TestMapFieldExtra_map_field_set(
408  test_msg_extra, 0, upb_test_TestMapFieldExtra_THREE, arena.ptr()));
409 
410  size_t size;
411  char* serialized = upb_test_TestMapFieldExtra_serialize_ex(
412  test_msg_extra, 0, arena.ptr(), &size);
413  ASSERT_NE(nullptr, serialized);
414  ASSERT_NE(0, size);
415 
416  upb_test_TestMapField* test_msg =
417  upb_test_TestMapField_parse(serialized, size, arena.ptr());
418  ASSERT_NE(nullptr, test_msg);
419 
420  ASSERT_FALSE(upb_test_TestMapField_map_field_get(test_msg, 0, nullptr));
421  serialized =
422  upb_test_TestMapField_serialize_ex(test_msg, 0, arena.ptr(), &size);
423  ASSERT_NE(0, size);
424  // parse into second instance
425  upb_test_TestMapFieldExtra* test_msg_extra2 =
426  upb_test_TestMapFieldExtra_parse(serialized, size, arena.ptr());
427  ASSERT_TRUE(
428  upb_test_TestMapFieldExtra_map_field_get(test_msg_extra2, 0, nullptr));
429 }
EXPECT_FALSE
#define EXPECT_FALSE(condition)
Definition: bloaty/third_party/googletest/googletest/include/gtest/gtest.h:1970
kUpb_DecodeStatus_MissingRequired
@ kUpb_DecodeStatus_MissingRequired
Definition: decode.h:80
ASSERT_NE
#define ASSERT_NE(val1, val2)
Definition: bloaty/third_party/googletest/googletest/include/gtest/gtest.h:2060
upb::SymbolTable
Definition: def.hpp:377
upb::MessageDefPtr
Definition: def.hpp:168
kUpb_Encode_CheckRequired
@ kUpb_Encode_CheckRequired
Definition: encode.h:57
EXPECT_THAT
#define EXPECT_THAT(value, matcher)
upb_Decode
upb_DecodeStatus upb_Decode(const char *buf, size_t size, void *msg, const upb_MiniTable *l, const upb_ExtensionRegistry *extreg, int options, upb_Arena *arena)
Definition: decode.c:1076
upb_DefPool_ExtensionRegistry
const upb_ExtensionRegistry * upb_DefPool_ExtensionRegistry(const upb_DefPool *s)
Definition: upb/upb/def.c:3231
testing::internal::string
::std::string string
Definition: bloaty/third_party/protobuf/third_party/googletest/googletest/include/gtest/internal/gtest-port.h:881
kUpb_DecodeStatus_Ok
@ kUpb_DecodeStatus_Ok
Definition: decode.h:72
upb::FieldDefPtr
Definition: def.hpp:50
ASSERT_GE
#define ASSERT_GE(val1, val2)
Definition: bloaty/third_party/googletest/googletest/include/gtest/gtest.h:2072
status
absl::Status status
Definition: rls.cc:251
upb_JsonEncode
size_t upb_JsonEncode(const upb_Message *msg, const upb_MessageDef *m, const upb_DefPool *ext_pool, int options, char *buf, size_t size, upb_Status *status)
Definition: json_encode.c:757
gen_header_frame.vals
list vals
Definition: gen_header_frame.py:73
upb_MessageValue::int32_val
int32_t int32_val
Definition: upb/upb/reflection.h:44
def.hpp
json_encode.h
arena
grpc_core::ScopedArenaPtr arena
Definition: binder_transport_test.cc:237
json_decode.h
testing::ElementsAreArray
internal::ElementsAreArrayMatcher< typename ::std::iterator_traits< Iter >::value_type > ElementsAreArray(Iter first, Iter last)
Definition: cares/cares/test/gmock-1.8.0/gmock/gmock.h:8465
EXPECT_EQ
#define EXPECT_EQ(a, b)
Definition: iomgr/time_averaged_stats_test.cc:27
upb_MessageValue
Definition: upb/upb/reflection.h:40
google::protobuf.internal.python_message.Extensions
Extensions
Definition: bloaty/third_party/protobuf/python/google/protobuf/internal/python_message.py:584
autogen_x86imm.f
f
Definition: autogen_x86imm.py:9
EXPECT_NE
#define EXPECT_NE(val1, val2)
Definition: bloaty/third_party/googletest/googletest/include/gtest/gtest.h:2028
member
int member
Definition: abseil-cpp/absl/base/invoke_test.cc:87
upb_Arena_Malloc
UPB_INLINE void * upb_Arena_Malloc(upb_Arena *a, size_t size)
Definition: upb/upb/upb.h:222
VerifyMessage
void VerifyMessage(const upb_test_TestExtensions *ext_msg)
Definition: msg_test.cc:38
TEST
TEST(MessageTest, Extensions)
Definition: msg_test.cc:52
MapField
Definition: protobuf/php/ext/google/protobuf/map.c:50
symtab
upb_symtab * symtab
Definition: bloaty/third_party/protobuf/php/ext/google/protobuf/protobuf.h:774
upb::Arena
Definition: upb.hpp:68
upb.hpp
upb_JsonDecode
bool upb_JsonDecode(const char *buf, size_t size, upb_Message *msg, const upb_MessageDef *m, const upb_DefPool *symtab, int options, upb_Arena *arena, upb_Status *status)
Definition: json_decode.c:1486
kUpb_DecodeOption_CheckRequired
@ kUpb_DecodeOption_CheckRequired
Definition: decode.h:66
ASSERT_TRUE
#define ASSERT_TRUE(condition)
Definition: bloaty/third_party/googletest/googletest/include/gtest/gtest.h:1973
ASSERT_FALSE
#define ASSERT_FALSE(condition)
Definition: bloaty/third_party/googletest/googletest/include/gtest/gtest.h:1976
EXPECT_TRUE
#define EXPECT_TRUE(condition)
Definition: bloaty/third_party/googletest/googletest/include/gtest/gtest.h:1967
size
voidpf void uLong size
Definition: bloaty/third_party/zlib/contrib/minizip/ioapi.h:136
regress.m
m
Definition: regress/regress.py:25
int32_t
signed int int32_t
Definition: stdint-msvc2008.h:77
upb_Message_Set
bool upb_Message_Set(upb_Message *msg, const upb_FieldDef *f, upb_MessageValue val, upb_Arena *a)
Definition: reflection.c:202
upb::Status
Definition: upb.hpp:35
i
uint64_t i
Definition: abseil-cpp/absl/container/btree_benchmark.cc:230
VerifyMessageSet
void VerifyMessageSet(const upb_test_TestMessageSet *mset_msg)
Definition: msg_test.cc:104


grpc
Author(s):
autogenerated on Thu Mar 13 2025 03:00:41