encode_decode_test.php 26 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912
  1. <?php
  2. require_once('test_base.php');
  3. require_once('test_util.php');
  4. use Google\Protobuf\RepeatedField;
  5. use Google\Protobuf\GPBType;
  6. use Foo\TestEnum;
  7. use Foo\TestMessage;
  8. use Foo\TestMessage\Sub;
  9. use Foo\TestPackedMessage;
  10. use Foo\TestRandomFieldOrder;
  11. use Foo\TestUnpackedMessage;
  12. use Google\Protobuf\DoubleValue;
  13. use Google\Protobuf\FloatValue;
  14. use Google\Protobuf\Int32Value;
  15. use Google\Protobuf\UInt32Value;
  16. use Google\Protobuf\Int64Value;
  17. use Google\Protobuf\UInt64Value;
  18. use Google\Protobuf\BoolValue;
  19. use Google\Protobuf\StringValue;
  20. use Google\Protobuf\BytesValue;
  21. use Google\Protobuf\Value;
  22. use Google\Protobuf\ListValue;
  23. use Google\Protobuf\Struct;
  24. use Google\Protobuf\GPBEmpty;
  25. class EncodeDecodeTest extends TestBase
  26. {
  27. public function testDecodeJsonSimple()
  28. {
  29. $m = new TestMessage();
  30. $m->mergeFromJsonString("{\"optionalInt32\":1}");
  31. }
  32. public function testDecodeTopLevelBoolValue()
  33. {
  34. $m = new BoolValue();
  35. $m->mergeFromJsonString("true");
  36. $this->assertEquals(true, $m->getValue());
  37. $m->mergeFromJsonString("false");
  38. $this->assertEquals(false, $m->getValue());
  39. }
  40. public function testEncodeTopLevelBoolValue()
  41. {
  42. $m = new BoolValue();
  43. $m->setValue(true);
  44. $this->assertSame("true", $m->serializeToJsonString());
  45. }
  46. public function testDecodeTopLevelDoubleValue()
  47. {
  48. $m = new DoubleValue();
  49. $m->mergeFromJsonString("1.5");
  50. $this->assertEquals(1.5, $m->getValue());
  51. }
  52. public function testEncodeTopLevelDoubleValue()
  53. {
  54. $m = new DoubleValue();
  55. $m->setValue(1.5);
  56. $this->assertSame("1.5", $m->serializeToJsonString());
  57. }
  58. public function testDecodeTopLevelFloatValue()
  59. {
  60. $m = new FloatValue();
  61. $m->mergeFromJsonString("1.5");
  62. $this->assertEquals(1.5, $m->getValue());
  63. }
  64. public function testEncodeTopLevelFloatValue()
  65. {
  66. $m = new FloatValue();
  67. $m->setValue(1.5);
  68. $this->assertSame("1.5", $m->serializeToJsonString());
  69. }
  70. public function testDecodeTopLevelInt32Value()
  71. {
  72. $m = new Int32Value();
  73. $m->mergeFromJsonString("1");
  74. $this->assertEquals(1, $m->getValue());
  75. }
  76. public function testEncodeTopLevelInt32Value()
  77. {
  78. $m = new Int32Value();
  79. $m->setValue(1);
  80. $this->assertSame("1", $m->serializeToJsonString());
  81. }
  82. public function testDecodeTopLevelUInt32Value()
  83. {
  84. $m = new UInt32Value();
  85. $m->mergeFromJsonString("1");
  86. $this->assertEquals(1, $m->getValue());
  87. }
  88. public function testEncodeTopLevelUInt32Value()
  89. {
  90. $m = new UInt32Value();
  91. $m->setValue(1);
  92. $this->assertSame("1", $m->serializeToJsonString());
  93. }
  94. public function testDecodeTopLevelInt64Value()
  95. {
  96. $m = new Int64Value();
  97. $m->mergeFromJsonString("1");
  98. $this->assertEquals(1, $m->getValue());
  99. }
  100. # public function testEncodeTopLevelInt64Value()
  101. # {
  102. # $m = new Int64Value();
  103. # $m->setValue(1);
  104. # $this->assertSame("\"1\"", $m->serializeToJsonString());
  105. # }
  106. public function testDecodeTopLevelUInt64Value()
  107. {
  108. $m = new UInt64Value();
  109. $m->mergeFromJsonString("1");
  110. $this->assertEquals(1, $m->getValue());
  111. }
  112. # public function testEncodeTopLevelUInt64Value()
  113. # {
  114. # $m = new UInt64Value();
  115. # $m->setValue(1);
  116. # $this->assertSame("\"1\"", $m->serializeToJsonString());
  117. # }
  118. public function testDecodeTopLevelStringValue()
  119. {
  120. $m = new StringValue();
  121. $m->mergeFromJsonString("\"a\"");
  122. $this->assertSame("a", $m->getValue());
  123. }
  124. public function testEncodeTopLevelStringValue()
  125. {
  126. $m = new StringValue();
  127. $m->setValue("a");
  128. $this->assertSame("\"a\"", $m->serializeToJsonString());
  129. }
  130. public function testDecodeTopLevelBytesValue()
  131. {
  132. $m = new BytesValue();
  133. $m->mergeFromJsonString("\"YQ==\"");
  134. $this->assertSame("a", $m->getValue());
  135. }
  136. public function testEncodeTopLevelBytesValue()
  137. {
  138. $m = new BytesValue();
  139. $m->setValue("a");
  140. $this->assertSame("\"YQ==\"", $m->serializeToJsonString());
  141. }
  142. public function testEncode()
  143. {
  144. $from = new TestMessage();
  145. $this->expectEmptyFields($from);
  146. $this->setFields($from);
  147. $this->expectFields($from);
  148. $data = $from->serializeToString();
  149. $this->assertSame(bin2hex(TestUtil::getGoldenTestMessage()),
  150. bin2hex($data));
  151. }
  152. public function testDecode()
  153. {
  154. $to = new TestMessage();
  155. $to->mergeFromString(TestUtil::getGoldenTestMessage());
  156. $this->expectFields($to);
  157. }
  158. public function testEncodeDecode()
  159. {
  160. $from = new TestMessage();
  161. $this->expectEmptyFields($from);
  162. $this->setFields($from);
  163. $this->expectFields($from);
  164. $data = $from->serializeToString();
  165. $to = new TestMessage();
  166. $to->mergeFromString($data);
  167. $this->expectFields($to);
  168. }
  169. public function testEncodeDecodeEmpty()
  170. {
  171. $from = new TestMessage();
  172. $this->expectEmptyFields($from);
  173. $data = $from->serializeToString();
  174. $to = new TestMessage();
  175. $to->mergeFromString($data);
  176. $this->expectEmptyFields($to);
  177. }
  178. public function testEncodeDecodeOneof()
  179. {
  180. $m = new TestMessage();
  181. $m->setOneofInt32(1);
  182. $data = $m->serializeToString();
  183. $n = new TestMessage();
  184. $n->mergeFromString($data);
  185. $this->assertSame(1, $n->getOneofInt32());
  186. $m->setOneofFloat(2.0);
  187. $data = $m->serializeToString();
  188. $n = new TestMessage();
  189. $n->mergeFromString($data);
  190. $this->assertSame(2.0, $n->getOneofFloat());
  191. $m->setOneofString('abc');
  192. $data = $m->serializeToString();
  193. $n = new TestMessage();
  194. $n->mergeFromString($data);
  195. $this->assertSame('abc', $n->getOneofString());
  196. $sub_m = new Sub();
  197. $sub_m->setA(1);
  198. $m->setOneofMessage($sub_m);
  199. $data = $m->serializeToString();
  200. $n = new TestMessage();
  201. $n->mergeFromString($data);
  202. $this->assertSame(1, $n->getOneofMessage()->getA());
  203. // Encode default value
  204. $m->setOneofEnum(TestEnum::ZERO);
  205. $data = $m->serializeToString();
  206. $n = new TestMessage();
  207. $n->mergeFromString($data);
  208. $this->assertSame("oneof_enum", $n->getMyOneof());
  209. $this->assertSame(TestEnum::ZERO, $n->getOneofEnum());
  210. $m->setOneofString("");
  211. $data = $m->serializeToString();
  212. $n = new TestMessage();
  213. $n->mergeFromString($data);
  214. $this->assertSame("oneof_string", $n->getMyOneof());
  215. $this->assertSame("", $n->getOneofString());
  216. $sub_m = new Sub();
  217. $m->setOneofMessage($sub_m);
  218. $data = $m->serializeToString();
  219. $n = new TestMessage();
  220. $n->mergeFromString($data);
  221. $this->assertSame("oneof_message", $n->getMyOneof());
  222. $this->assertFalse(is_null($n->getOneofMessage()));
  223. }
  224. public function testPackedEncode()
  225. {
  226. $from = new TestPackedMessage();
  227. TestUtil::setTestPackedMessage($from);
  228. $this->assertSame(TestUtil::getGoldenTestPackedMessage(),
  229. $from->serializeToString());
  230. }
  231. public function testPackedDecodePacked()
  232. {
  233. $to = new TestPackedMessage();
  234. $to->mergeFromString(TestUtil::getGoldenTestPackedMessage());
  235. TestUtil::assertTestPackedMessage($to);
  236. }
  237. public function testPackedDecodeUnpacked()
  238. {
  239. $to = new TestPackedMessage();
  240. $to->mergeFromString(TestUtil::getGoldenTestUnpackedMessage());
  241. TestUtil::assertTestPackedMessage($to);
  242. }
  243. public function testUnpackedEncode()
  244. {
  245. $from = new TestUnpackedMessage();
  246. TestUtil::setTestPackedMessage($from);
  247. $this->assertSame(TestUtil::getGoldenTestUnpackedMessage(),
  248. $from->serializeToString());
  249. }
  250. public function testUnpackedDecodePacked()
  251. {
  252. $to = new TestUnpackedMessage();
  253. $to->mergeFromString(TestUtil::getGoldenTestPackedMessage());
  254. TestUtil::assertTestPackedMessage($to);
  255. }
  256. public function testUnpackedDecodeUnpacked()
  257. {
  258. $to = new TestUnpackedMessage();
  259. $to->mergeFromString(TestUtil::getGoldenTestUnpackedMessage());
  260. TestUtil::assertTestPackedMessage($to);
  261. }
  262. public function testDecodeInt64()
  263. {
  264. // Read 64 testing
  265. $testVals = array(
  266. '10' => '100a',
  267. '100' => '1064',
  268. '800' => '10a006',
  269. '6400' => '108032',
  270. '70400' => '1080a604',
  271. '774400' => '1080a22f',
  272. '9292800' => '108098b704',
  273. '74342400' => '1080c0b923',
  274. '743424000' => '108080bfe202',
  275. '8177664000' => '108080b5bb1e',
  276. '65421312000' => '108080a8dbf301',
  277. '785055744000' => '108080e0c7ec16',
  278. '9420668928000' => '10808080dd969202',
  279. '103627358208000' => '10808080fff9c717',
  280. '1139900940288000' => '10808080f5bd978302',
  281. '13678811283456000' => '10808080fce699a618',
  282. '109430490267648000' => '10808080e0b7ceb1c201',
  283. '984874412408832000' => '10808080e0f5c1bed50d',
  284. );
  285. $msg = new TestMessage();
  286. foreach ($testVals as $original => $encoded) {
  287. $msg->setOptionalInt64($original);
  288. $data = $msg->serializeToString();
  289. $this->assertSame($encoded, bin2hex($data));
  290. $msg->setOptionalInt64(0);
  291. $msg->mergeFromString($data);
  292. $this->assertEquals($original, $msg->getOptionalInt64());
  293. }
  294. }
  295. public function testDecodeToExistingMessage()
  296. {
  297. $m1 = new TestMessage();
  298. $this->setFields($m1);
  299. $this->expectFields($m1);
  300. $m2 = new TestMessage();
  301. $this->setFields2($m2);
  302. $data = $m2->serializeToString();
  303. $m1->mergeFromString($data);
  304. $this->expectFieldsMerged($m1);
  305. }
  306. public function testDecodeFieldNonExist()
  307. {
  308. $data = hex2bin('c80501');
  309. $m = new TestMessage();
  310. $m->mergeFromString($data);
  311. }
  312. public function testEncodeNegativeInt32()
  313. {
  314. $m = new TestMessage();
  315. $m->setOptionalInt32(-1);
  316. $data = $m->serializeToString();
  317. $this->assertSame("08ffffffffffffffffff01", bin2hex($data));
  318. }
  319. public function testDecodeNegativeInt32()
  320. {
  321. $m = new TestMessage();
  322. $this->assertEquals(0, $m->getOptionalInt32());
  323. $m->mergeFromString(hex2bin("08ffffffffffffffffff01"));
  324. $this->assertEquals(-1, $m->getOptionalInt32());
  325. $m = new TestMessage();
  326. $this->assertEquals(0, $m->getOptionalInt32());
  327. $m->mergeFromString(hex2bin("08ffffffff0f"));
  328. $this->assertEquals(-1, $m->getOptionalInt32());
  329. }
  330. public function testRandomFieldOrder()
  331. {
  332. $m = new TestRandomFieldOrder();
  333. $data = $m->serializeToString();
  334. $this->assertSame("", $data);
  335. }
  336. /**
  337. * @expectedException Exception
  338. */
  339. public function testDecodeInvalidInt32()
  340. {
  341. $m = new TestMessage();
  342. $m->mergeFromString(hex2bin('08'));
  343. }
  344. /**
  345. * @expectedException Exception
  346. */
  347. public function testDecodeInvalidSubMessage()
  348. {
  349. $m = new TestMessage();
  350. $m->mergeFromString(hex2bin('9A010108'));
  351. }
  352. /**
  353. * @expectedException Exception
  354. */
  355. public function testDecodeInvalidInt64()
  356. {
  357. $m = new TestMessage();
  358. $m->mergeFromString(hex2bin('10'));
  359. }
  360. /**
  361. * @expectedException Exception
  362. */
  363. public function testDecodeInvalidUInt32()
  364. {
  365. $m = new TestMessage();
  366. $m->mergeFromString(hex2bin('18'));
  367. }
  368. /**
  369. * @expectedException Exception
  370. */
  371. public function testDecodeInvalidUInt64()
  372. {
  373. $m = new TestMessage();
  374. $m->mergeFromString(hex2bin('20'));
  375. }
  376. /**
  377. * @expectedException Exception
  378. */
  379. public function testDecodeInvalidSInt32()
  380. {
  381. $m = new TestMessage();
  382. $m->mergeFromString(hex2bin('28'));
  383. }
  384. /**
  385. * @expectedException Exception
  386. */
  387. public function testDecodeInvalidSInt64()
  388. {
  389. $m = new TestMessage();
  390. $m->mergeFromString(hex2bin('30'));
  391. }
  392. /**
  393. * @expectedException Exception
  394. */
  395. public function testDecodeInvalidFixed32()
  396. {
  397. $m = new TestMessage();
  398. $m->mergeFromString(hex2bin('3D'));
  399. }
  400. /**
  401. * @expectedException Exception
  402. */
  403. public function testDecodeInvalidFixed64()
  404. {
  405. $m = new TestMessage();
  406. $m->mergeFromString(hex2bin('41'));
  407. }
  408. /**
  409. * @expectedException Exception
  410. */
  411. public function testDecodeInvalidSFixed32()
  412. {
  413. $m = new TestMessage();
  414. $m->mergeFromString(hex2bin('4D'));
  415. }
  416. /**
  417. * @expectedException Exception
  418. */
  419. public function testDecodeInvalidSFixed64()
  420. {
  421. $m = new TestMessage();
  422. $m->mergeFromString(hex2bin('51'));
  423. }
  424. /**
  425. * @expectedException Exception
  426. */
  427. public function testDecodeInvalidFloat()
  428. {
  429. $m = new TestMessage();
  430. $m->mergeFromString(hex2bin('5D'));
  431. }
  432. /**
  433. * @expectedException Exception
  434. */
  435. public function testDecodeInvalidDouble()
  436. {
  437. $m = new TestMessage();
  438. $m->mergeFromString(hex2bin('61'));
  439. }
  440. /**
  441. * @expectedException Exception
  442. */
  443. public function testDecodeInvalidBool()
  444. {
  445. $m = new TestMessage();
  446. $m->mergeFromString(hex2bin('68'));
  447. }
  448. /**
  449. * @expectedException Exception
  450. */
  451. public function testDecodeInvalidStringLengthMiss()
  452. {
  453. $m = new TestMessage();
  454. $m->mergeFromString(hex2bin('72'));
  455. }
  456. /**
  457. * @expectedException Exception
  458. */
  459. public function testDecodeInvalidStringDataMiss()
  460. {
  461. $m = new TestMessage();
  462. $m->mergeFromString(hex2bin('7201'));
  463. }
  464. /**
  465. * @expectedException Exception
  466. */
  467. public function testDecodeInvalidBytesLengthMiss()
  468. {
  469. $m = new TestMessage();
  470. $m->mergeFromString(hex2bin('7A'));
  471. }
  472. /**
  473. * @expectedException Exception
  474. */
  475. public function testDecodeInvalidBytesDataMiss()
  476. {
  477. $m = new TestMessage();
  478. $m->mergeFromString(hex2bin('7A01'));
  479. }
  480. /**
  481. * @expectedException Exception
  482. */
  483. public function testDecodeInvalidEnum()
  484. {
  485. $m = new TestMessage();
  486. $m->mergeFromString(hex2bin('8001'));
  487. }
  488. /**
  489. * @expectedException Exception
  490. */
  491. public function testDecodeInvalidMessageLengthMiss()
  492. {
  493. $m = new TestMessage();
  494. $m->mergeFromString(hex2bin('8A01'));
  495. }
  496. /**
  497. * @expectedException Exception
  498. */
  499. public function testDecodeInvalidMessageDataMiss()
  500. {
  501. $m = new TestMessage();
  502. $m->mergeFromString(hex2bin('8A0101'));
  503. }
  504. /**
  505. * @expectedException Exception
  506. */
  507. public function testDecodeInvalidPackedMessageLength()
  508. {
  509. $m = new TestPackedMessage();
  510. $m->mergeFromString(hex2bin('D205'));
  511. }
  512. public function testUnknown()
  513. {
  514. // Test preserve unknown for varint.
  515. $m = new TestMessage();
  516. $from = hex2bin('F80601'); // TODO(teboring): Add a util to encode
  517. // varint for better readability
  518. $m->mergeFromString($from);
  519. $to = $m->serializeToString();
  520. $this->assertSame(bin2hex($from), bin2hex($to));
  521. // Test preserve unknown for 64-bit.
  522. $m = new TestMessage();
  523. $from = hex2bin('F9060000000000000000');
  524. $m->mergeFromString($from);
  525. $to = $m->serializeToString();
  526. $this->assertSame(bin2hex($from), bin2hex($to));
  527. // Test preserve unknown for length delimited.
  528. $m = new TestMessage();
  529. $from = hex2bin('FA0600');
  530. $m->mergeFromString($from);
  531. $to = $m->serializeToString();
  532. $this->assertSame(bin2hex($from), bin2hex($to));
  533. // Test preserve unknown for 32-bit.
  534. $m = new TestMessage();
  535. $from = hex2bin('FD0600000000');
  536. $m->mergeFromString($from);
  537. $to = $m->serializeToString();
  538. $this->assertSame(bin2hex($from), bin2hex($to));
  539. // Test discard unknown in message.
  540. $m = new TestMessage();
  541. $from = hex2bin('F80601');
  542. $m->mergeFromString($from);
  543. $m->discardUnknownFields();
  544. $to = $m->serializeToString();
  545. $this->assertSame("", bin2hex($to));
  546. // Test discard unknown for singular message field.
  547. $m = new TestMessage();
  548. $from = hex2bin('8A0103F80601');
  549. $m->mergeFromString($from);
  550. $m->discardUnknownFields();
  551. $to = $m->serializeToString();
  552. $this->assertSame("8a0100", bin2hex($to));
  553. // Test discard unknown for repeated message field.
  554. $m = new TestMessage();
  555. $from = hex2bin('FA0203F80601');
  556. $m->mergeFromString($from);
  557. $m->discardUnknownFields();
  558. $to = $m->serializeToString();
  559. $this->assertSame("fa0200", bin2hex($to));
  560. // Test discard unknown for map message value field.
  561. $m = new TestMessage();
  562. $from = hex2bin("BA050708011203F80601");
  563. $m->mergeFromString($from);
  564. $m->discardUnknownFields();
  565. $to = $m->serializeToString();
  566. $this->assertSame("ba050408011200", bin2hex($to));
  567. // Test discard unknown for singular message field.
  568. $m = new TestMessage();
  569. $from = hex2bin('9A0403F80601');
  570. $m->mergeFromString($from);
  571. $m->discardUnknownFields();
  572. $to = $m->serializeToString();
  573. $this->assertSame("9a0400", bin2hex($to));
  574. }
  575. public function testJsonUnknown()
  576. {
  577. // Test unknown number
  578. $m = new TestMessage();
  579. $m->mergeFromJsonString("{\"unknown\":1,
  580. \"optionalInt32\":1}", true);
  581. $this->assertSame(1, $m->getOptionalInt32());
  582. // Test unknown bool
  583. $m = new TestMessage();
  584. $m->mergeFromJsonString("{\"unknown\":true,
  585. \"optionalInt32\":1}", true);
  586. $this->assertSame(1, $m->getOptionalInt32());
  587. // Test unknown string
  588. $m = new TestMessage();
  589. $m->mergeFromJsonString("{\"unknown\":\"abc\",
  590. \"optionalInt32\":1}", true);
  591. $this->assertSame(1, $m->getOptionalInt32());
  592. // Test unknown null
  593. $m = new TestMessage();
  594. $m->mergeFromJsonString("{\"unknown\":null,
  595. \"optionalInt32\":1}", true);
  596. $this->assertSame(1, $m->getOptionalInt32());
  597. // Test unknown array
  598. $m = new TestMessage();
  599. $m->mergeFromJsonString("{\"unknown\":[],
  600. \"optionalInt32\":1}", true);
  601. $this->assertSame(1, $m->getOptionalInt32());
  602. // Test unknown number array
  603. $m = new TestMessage();
  604. $m->mergeFromJsonString("{\"unknown\":[1],
  605. \"optionalInt32\":1}", true);
  606. $this->assertSame(1, $m->getOptionalInt32());
  607. // Test unknown bool array
  608. $m = new TestMessage();
  609. $m->mergeFromJsonString("{\"unknown\":[true],
  610. \"optionalInt32\":1}", true);
  611. $this->assertSame(1, $m->getOptionalInt32());
  612. // Test unknown string array
  613. $m = new TestMessage();
  614. $m->mergeFromJsonString("{\"unknown\":[\"a\"],
  615. \"optionalInt32\":1}", true);
  616. $this->assertSame(1, $m->getOptionalInt32());
  617. // Test unknown null array
  618. $m = new TestMessage();
  619. $m->mergeFromJsonString("{\"unknown\":[null],
  620. \"optionalInt32\":1}", true);
  621. $this->assertSame(1, $m->getOptionalInt32());
  622. // Test unknown array array
  623. $m = new TestMessage();
  624. $m->mergeFromJsonString("{\"unknown\":[[]],
  625. \"optionalInt32\":1}", true);
  626. $this->assertSame(1, $m->getOptionalInt32());
  627. // Test unknown object array
  628. $m = new TestMessage();
  629. $m->mergeFromJsonString("{\"unknown\":[{}],
  630. \"optionalInt32\":1}", true);
  631. $this->assertSame(1, $m->getOptionalInt32());
  632. // Test unknown double value array
  633. $m = new TestMessage();
  634. $m->mergeFromJsonString("{\"unknown\":[1, 2],
  635. \"optionalInt32\":1}", true);
  636. $this->assertSame(1, $m->getOptionalInt32());
  637. // Test unknown object
  638. $m = new TestMessage();
  639. $m->mergeFromJsonString("{\"unknown\":{},
  640. \"optionalInt32\":1}", true);
  641. $this->assertSame(1, $m->getOptionalInt32());
  642. // Test unknown number object
  643. $m = new TestMessage();
  644. $m->mergeFromJsonString("{\"unknown\":{\"a\":1},
  645. \"optionalInt32\":1}", true);
  646. $this->assertSame(1, $m->getOptionalInt32());
  647. // Test unknown bool object
  648. $m = new TestMessage();
  649. $m->mergeFromJsonString("{\"unknown\":{\"a\":true},
  650. \"optionalInt32\":1}", true);
  651. $this->assertSame(1, $m->getOptionalInt32());
  652. // Test unknown string object
  653. $m = new TestMessage();
  654. $m->mergeFromJsonString("{\"unknown\":{\"a\":\"a\"},
  655. \"optionalInt32\":1}", true);
  656. $this->assertSame(1, $m->getOptionalInt32());
  657. // Test unknown null object
  658. $m = new TestMessage();
  659. $m->mergeFromJsonString("{\"unknown\":{\"a\":null},
  660. \"optionalInt32\":1}", true);
  661. $this->assertSame(1, $m->getOptionalInt32());
  662. // Test unknown array object
  663. $m = new TestMessage();
  664. $m->mergeFromJsonString("{\"unknown\":{\"a\":[]},
  665. \"optionalInt32\":1}", true);
  666. $this->assertSame(1, $m->getOptionalInt32());
  667. // Test unknown object object
  668. $m = new TestMessage();
  669. $m->mergeFromJsonString("{\"unknown\":{\"a\":{}},
  670. \"optionalInt32\":1}", true);
  671. $this->assertSame(1, $m->getOptionalInt32());
  672. // Test unknown double value object
  673. $m = new TestMessage();
  674. $m->mergeFromJsonString("{\"unknown\":{\"a\":1, \"b\":1},
  675. \"optionalInt32\":1}", true);
  676. $this->assertSame(1, $m->getOptionalInt32());
  677. }
  678. public function testJsonEncode()
  679. {
  680. $from = new TestMessage();
  681. $this->setFields($from);
  682. $data = $from->serializeToJsonString();
  683. $to = new TestMessage();
  684. $to->mergeFromJsonString($data);
  685. $this->expectFields($to);
  686. }
  687. public function testDecodeDuration()
  688. {
  689. $m = new Google\Protobuf\Duration();
  690. $m->mergeFromJsonString("\"1234.5678s\"");
  691. $this->assertEquals(1234, $m->getSeconds());
  692. $this->assertEquals(567800000, $m->getNanos());
  693. }
  694. public function testEncodeDuration()
  695. {
  696. $m = new Google\Protobuf\Duration();
  697. $m->setSeconds(1234);
  698. $m->setNanos(999999999);
  699. $this->assertEquals("\"1234.999999999s\"", $m->serializeToJsonString());
  700. }
  701. public function testDecodeTimestamp()
  702. {
  703. $m = new Google\Protobuf\Timestamp();
  704. $m->mergeFromJsonString("\"2000-01-01T00:00:00.123456789Z\"");
  705. $this->assertEquals(946684800, $m->getSeconds());
  706. $this->assertEquals(123456789, $m->getNanos());
  707. }
  708. public function testEncodeTimestamp()
  709. {
  710. $m = new Google\Protobuf\Timestamp();
  711. $m->setSeconds(946684800);
  712. $m->setNanos(123456789);
  713. $this->assertEquals("\"2000-01-01T00:00:00.123456789Z\"",
  714. $m->serializeToJsonString());
  715. }
  716. public function testDecodeTopLevelValue()
  717. {
  718. $m = new Value();
  719. $m->mergeFromJsonString("\"a\"");
  720. $this->assertSame("a", $m->getStringValue());
  721. $m = new Value();
  722. $m->mergeFromJsonString("1.5");
  723. $this->assertSame(1.5, $m->getNumberValue());
  724. $m = new Value();
  725. $m->mergeFromJsonString("true");
  726. $this->assertSame(true, $m->getBoolValue());
  727. $m = new Value();
  728. $m->mergeFromJsonString("null");
  729. $this->assertSame("null_value", $m->getKind());
  730. $m = new Value();
  731. $m->mergeFromJsonString("[1]");
  732. $this->assertSame("list_value", $m->getKind());
  733. $m = new Value();
  734. $m->mergeFromJsonString("{\"a\":1}");
  735. $this->assertSame("struct_value", $m->getKind());
  736. }
  737. public function testEncodeTopLevelValue()
  738. {
  739. $m = new Value();
  740. $m->setStringValue("a");
  741. $this->assertSame("\"a\"", $m->serializeToJsonString());
  742. $m = new Value();
  743. $m->setNumberValue(1.5);
  744. $this->assertSame("1.5", $m->serializeToJsonString());
  745. $m = new Value();
  746. $m->setBoolValue(true);
  747. $this->assertSame("true", $m->serializeToJsonString());
  748. $m = new Value();
  749. $m->setNullValue(0);
  750. $this->assertSame("null", $m->serializeToJsonString());
  751. }
  752. public function testDecodeTopLevelListValue()
  753. {
  754. $m = new ListValue();
  755. $m->mergeFromJsonString("[1]");
  756. $this->assertSame(1.0, $m->getValues()[0]->getNumberValue());
  757. }
  758. public function testEncodeTopLevelListValue()
  759. {
  760. $m = new ListValue();
  761. $arr = $m->getValues();
  762. $sub = new Value();
  763. $sub->setNumberValue(1.5);
  764. $arr[] = $sub;
  765. $this->assertSame("[1.5]", $m->serializeToJsonString());
  766. }
  767. public function testDecodeTopLevelStruct()
  768. {
  769. $m = new Struct();
  770. $m->mergeFromJsonString("{\"a\":{\"b\":1}}");
  771. $this->assertSame(1.0, $m->getFields()["a"]
  772. ->getStructValue()
  773. ->getFields()["b"]->getNumberValue());
  774. }
  775. public function testEncodeTopLevelStruct()
  776. {
  777. $m = new Struct();
  778. $map = $m->getFields();
  779. $sub = new Value();
  780. $sub->setNumberValue(1.5);
  781. $map["a"] = $sub;
  782. $this->assertSame("{\"a\":1.5}", $m->serializeToJsonString());
  783. }
  784. }