1179 lines
		
	
	
		
			36 KiB
		
	
	
	
		
			PHP
		
	
	
	
			
		
		
	
	
			1179 lines
		
	
	
		
			36 KiB
		
	
	
	
		
			PHP
		
	
	
	
| <?php
 | |
| 
 | |
| require_once('test_base.php');
 | |
| require_once('test_util.php');
 | |
| 
 | |
| use Google\Protobuf\RepeatedField;
 | |
| use Google\Protobuf\GPBType;
 | |
| use Foo\TestAny;
 | |
| use Foo\TestEnum;
 | |
| use Foo\TestMessage;
 | |
| use Foo\TestMessage\Sub;
 | |
| use Foo\TestPackedMessage;
 | |
| use Foo\TestRandomFieldOrder;
 | |
| use Foo\TestUnpackedMessage;
 | |
| use Google\Protobuf\Any;
 | |
| use Google\Protobuf\DoubleValue;
 | |
| use Google\Protobuf\FieldMask;
 | |
| use Google\Protobuf\FloatValue;
 | |
| use Google\Protobuf\Int32Value;
 | |
| use Google\Protobuf\UInt32Value;
 | |
| use Google\Protobuf\Int64Value;
 | |
| use Google\Protobuf\UInt64Value;
 | |
| use Google\Protobuf\BoolValue;
 | |
| use Google\Protobuf\StringValue;
 | |
| use Google\Protobuf\BytesValue;
 | |
| use Google\Protobuf\Value;
 | |
| use Google\Protobuf\ListValue;
 | |
| use Google\Protobuf\Struct;
 | |
| use Google\Protobuf\GPBEmpty;
 | |
| 
 | |
| class EncodeDecodeTest extends TestBase
 | |
| {
 | |
|     public function testDecodeJsonSimple()
 | |
|     {
 | |
|         $m = new TestMessage();
 | |
|         $m->mergeFromJsonString("{\"optionalInt32\":1}");
 | |
|         $this->assertEquals(1, $m->getOptionalInt32());
 | |
|     }
 | |
| 
 | |
|     public function testDecodeTopLevelBoolValue()
 | |
|     {
 | |
|         $m = new BoolValue();
 | |
| 
 | |
|         $m->mergeFromJsonString("true");
 | |
|         $this->assertEquals(true, $m->getValue());
 | |
| 
 | |
|         $m->mergeFromJsonString("false");
 | |
|         $this->assertEquals(false, $m->getValue());
 | |
|     }
 | |
| 
 | |
|     public function testEncodeTopLevelBoolValue()
 | |
|     {
 | |
|         $m = new BoolValue();
 | |
|         $m->setValue(true);
 | |
|         $this->assertSame("true", $m->serializeToJsonString());
 | |
|     }
 | |
| 
 | |
|     public function testDecodeTopLevelDoubleValue()
 | |
|     {
 | |
|         $m = new DoubleValue();
 | |
|         $m->mergeFromJsonString("1.5");
 | |
|         $this->assertEquals(1.5, $m->getValue());
 | |
|     }
 | |
| 
 | |
|     public function testEncodeTopLevelDoubleValue()
 | |
|     {
 | |
|         $m = new DoubleValue();
 | |
|         $m->setValue(1.5);
 | |
|         $this->assertSame("1.5", $m->serializeToJsonString());
 | |
|     }
 | |
| 
 | |
|     public function testDecodeTopLevelFloatValue()
 | |
|     {
 | |
|         $m = new FloatValue();
 | |
|         $m->mergeFromJsonString("1.5");
 | |
|         $this->assertEquals(1.5, $m->getValue());
 | |
|     }
 | |
| 
 | |
|     public function testEncodeTopLevelFloatValue()
 | |
|     {
 | |
|         $m = new FloatValue();
 | |
|         $m->setValue(1.5);
 | |
|         $this->assertSame("1.5", $m->serializeToJsonString());
 | |
|     }
 | |
| 
 | |
|     public function testDecodeTopLevelInt32Value()
 | |
|     {
 | |
|         $m = new Int32Value();
 | |
|         $m->mergeFromJsonString("1");
 | |
|         $this->assertEquals(1, $m->getValue());
 | |
|     }
 | |
| 
 | |
|     public function testEncodeTopLevelInt32Value()
 | |
|     {
 | |
|         $m = new Int32Value();
 | |
|         $m->setValue(1);
 | |
|         $this->assertSame("1", $m->serializeToJsonString());
 | |
|     }
 | |
| 
 | |
|     public function testDecodeTopLevelUInt32Value()
 | |
|     {
 | |
|         $m = new UInt32Value();
 | |
|         $m->mergeFromJsonString("1");
 | |
|         $this->assertEquals(1, $m->getValue());
 | |
|     }
 | |
| 
 | |
|     public function testEncodeTopLevelUInt32Value()
 | |
|     {
 | |
|         $m = new UInt32Value();
 | |
|         $m->setValue(1);
 | |
|         $this->assertSame("1", $m->serializeToJsonString());
 | |
|     }
 | |
| 
 | |
|     public function testDecodeTopLevelInt64Value()
 | |
|     {
 | |
|         $m = new Int64Value();
 | |
|         $m->mergeFromJsonString("1");
 | |
|         $this->assertEquals(1, $m->getValue());
 | |
|     }
 | |
| 
 | |
|     # public function testEncodeTopLevelInt64Value()
 | |
|     # {
 | |
|     #     $m = new Int64Value();
 | |
|     #     $m->setValue(1);
 | |
|     #     $this->assertSame("\"1\"", $m->serializeToJsonString());
 | |
|     # }
 | |
| 
 | |
|     public function testDecodeTopLevelUInt64Value()
 | |
|     {
 | |
|         $m = new UInt64Value();
 | |
|         $m->mergeFromJsonString("1");
 | |
|         $this->assertEquals(1, $m->getValue());
 | |
|     }
 | |
| 
 | |
|     # public function testEncodeTopLevelUInt64Value()
 | |
|     # {
 | |
|     #     $m = new UInt64Value();
 | |
|     #     $m->setValue(1);
 | |
|     #     $this->assertSame("\"1\"", $m->serializeToJsonString());
 | |
|     # }
 | |
| 
 | |
|     public function testDecodeTopLevelStringValue()
 | |
|     {
 | |
|         $m = new StringValue();
 | |
|         $m->mergeFromJsonString("\"a\"");
 | |
|         $this->assertSame("a", $m->getValue());
 | |
|     }
 | |
| 
 | |
|     public function testEncodeTopLevelStringValue()
 | |
|     {
 | |
|         $m = new StringValue();
 | |
|         $m->setValue("a");
 | |
|         $this->assertSame("\"a\"", $m->serializeToJsonString());
 | |
|     }
 | |
| 
 | |
|     public function testDecodeTopLevelBytesValue()
 | |
|     {
 | |
|         $m = new BytesValue();
 | |
|         $m->mergeFromJsonString("\"YQ==\"");
 | |
|         $this->assertSame("a", $m->getValue());
 | |
|     }
 | |
| 
 | |
|     public function testEncodeTopLevelBytesValue()
 | |
|     {
 | |
|         $m = new BytesValue();
 | |
|         $m->setValue("a");
 | |
|         $this->assertSame("\"YQ==\"", $m->serializeToJsonString());
 | |
|     }
 | |
| 
 | |
|     public function generateRandomString($length = 10) {
 | |
|         $randomString = str_repeat("+", $length);
 | |
|         for ($i = 0; $i < $length; $i++) {
 | |
|             $randomString[$i] = rand(0, 255);
 | |
|         }
 | |
|         return $randomString;
 | |
|     }
 | |
| 
 | |
|     public function testEncodeTopLevelLongBytesValue()
 | |
|     {
 | |
|         $m = new BytesValue();
 | |
|         $data = $this->generateRandomString(12007);
 | |
|         $m->setValue($data);
 | |
|         $expected = "\"" . base64_encode($data) . "\"";
 | |
|         $this->assertSame(strlen($expected), strlen($m->serializeToJsonString()));
 | |
|     }
 | |
| 
 | |
|     public function testEncode()
 | |
|     {
 | |
|         $from = new TestMessage();
 | |
|         $this->expectEmptyFields($from);
 | |
|         $this->setFields($from);
 | |
|         $this->expectFields($from);
 | |
| 
 | |
|         $data = $from->serializeToString();
 | |
|         $this->assertSame(bin2hex(TestUtil::getGoldenTestMessage()),
 | |
|                           bin2hex($data));
 | |
|     }
 | |
| 
 | |
|     public function testDecode()
 | |
|     {
 | |
|         $to = new TestMessage();
 | |
|         $to->mergeFromString(TestUtil::getGoldenTestMessage());
 | |
|         $this->expectFields($to);
 | |
|     }
 | |
| 
 | |
|     public function testEncodeDecode()
 | |
|     {
 | |
|         $from = new TestMessage();
 | |
|         $this->expectEmptyFields($from);
 | |
|         $this->setFields($from);
 | |
|         $this->expectFields($from);
 | |
| 
 | |
|         $data = $from->serializeToString();
 | |
| 
 | |
|         $to = new TestMessage();
 | |
|         $to->mergeFromString($data);
 | |
|         $this->expectFields($to);
 | |
|     }
 | |
| 
 | |
|     public function testEncodeDecodeEmpty()
 | |
|     {
 | |
|         $from = new TestMessage();
 | |
|         $this->expectEmptyFields($from);
 | |
| 
 | |
|         $data = $from->serializeToString();
 | |
| 
 | |
|         $to = new TestMessage();
 | |
|         $to->mergeFromString($data);
 | |
|         $this->expectEmptyFields($to);
 | |
|     }
 | |
| 
 | |
|     public function testEncodeDecodeOneof()
 | |
|     {
 | |
|         $m = new TestMessage();
 | |
| 
 | |
|         $m->setOneofInt32(1);
 | |
|         $data = $m->serializeToString();
 | |
|         $n = new TestMessage();
 | |
|         $n->mergeFromString($data);
 | |
|         $this->assertSame(1, $n->getOneofInt32());
 | |
| 
 | |
|         $m->setOneofFloat(2.0);
 | |
|         $data = $m->serializeToString();
 | |
|         $n = new TestMessage();
 | |
|         $n->mergeFromString($data);
 | |
|         $this->assertSame(2.0, $n->getOneofFloat());
 | |
| 
 | |
|         $m->setOneofString('abc');
 | |
|         $data = $m->serializeToString();
 | |
|         $n = new TestMessage();
 | |
|         $n->mergeFromString($data);
 | |
|         $this->assertSame('abc', $n->getOneofString());
 | |
| 
 | |
|         $sub_m = new Sub();
 | |
|         $sub_m->setA(1);
 | |
|         $m->setOneofMessage($sub_m);
 | |
|         $data = $m->serializeToString();
 | |
|         $n = new TestMessage();
 | |
|         $n->mergeFromString($data);
 | |
|         $this->assertSame(1, $n->getOneofMessage()->getA());
 | |
| 
 | |
|         // Encode default value
 | |
|         $m->setOneofEnum(TestEnum::ZERO);
 | |
|         $data = $m->serializeToString();
 | |
|         $n = new TestMessage();
 | |
|         $n->mergeFromString($data);
 | |
|         $this->assertSame("oneof_enum", $n->getMyOneof());
 | |
|         $this->assertSame(TestEnum::ZERO, $n->getOneofEnum());
 | |
| 
 | |
|         $m->setOneofString("");
 | |
|         $data = $m->serializeToString();
 | |
|         $n = new TestMessage();
 | |
|         $n->mergeFromString($data);
 | |
|         $this->assertSame("oneof_string", $n->getMyOneof());
 | |
|         $this->assertSame("", $n->getOneofString());
 | |
| 
 | |
|         $sub_m = new Sub();
 | |
|         $m->setOneofMessage($sub_m);
 | |
|         $data = $m->serializeToString();
 | |
|         $n = new TestMessage();
 | |
|         $n->mergeFromString($data);
 | |
|         $this->assertSame("oneof_message", $n->getMyOneof());
 | |
|         $this->assertFalse(is_null($n->getOneofMessage()));
 | |
| 
 | |
|     }
 | |
| 
 | |
|     public function testJsonEncodeDecodeOneof()
 | |
|     {
 | |
|         $m = new TestMessage();
 | |
| 
 | |
|         $m->setOneofEnum(TestEnum::ONE);
 | |
|         $data = $m->serializeToJsonString();
 | |
|         $n = new TestMessage();
 | |
|         $n->mergeFromJsonString($data);
 | |
|         $this->assertSame("oneof_enum", $n->getMyOneof());
 | |
|         $this->assertSame(TestEnum::ONE, $n->getOneofEnum());
 | |
| 
 | |
|         $m->setOneofString("a");
 | |
|         $data = $m->serializeToJsonString();
 | |
|         $n = new TestMessage();
 | |
|         $n->mergeFromJsonString($data);
 | |
|         $this->assertSame("oneof_string", $n->getMyOneof());
 | |
|         $this->assertSame("a", $n->getOneofString());
 | |
| 
 | |
|         $m->setOneofBytes("bbbb");
 | |
|         $data = $m->serializeToJsonString();
 | |
|         $n = new TestMessage();
 | |
|         $n->mergeFromJsonString($data);
 | |
|         $this->assertSame("oneof_bytes", $n->getMyOneof());
 | |
|         $this->assertSame("bbbb", $n->getOneofBytes());
 | |
| 
 | |
|         $sub_m = new Sub();
 | |
|         $m->setOneofMessage($sub_m);
 | |
|         $data = $m->serializeToJsonString();
 | |
|         $n = new TestMessage();
 | |
|         $n->mergeFromJsonString($data);
 | |
|         $this->assertSame("oneof_message", $n->getMyOneof());
 | |
|         $this->assertFalse(is_null($n->getOneofMessage()));
 | |
|     }
 | |
| 
 | |
|     public function testPackedEncode()
 | |
|     {
 | |
|         $from = new TestPackedMessage();
 | |
|         TestUtil::setTestPackedMessage($from);
 | |
|         $this->assertSame(TestUtil::getGoldenTestPackedMessage(),
 | |
|                           $from->serializeToString());
 | |
|     }
 | |
| 
 | |
|     public function testPackedDecodePacked()
 | |
|     {
 | |
|         $to = new TestPackedMessage();
 | |
|         $to->mergeFromString(TestUtil::getGoldenTestPackedMessage());
 | |
|         TestUtil::assertTestPackedMessage($to);
 | |
|         $this->assertTrue(true);
 | |
|     }
 | |
| 
 | |
|     public function testPackedDecodeUnpacked()
 | |
|     {
 | |
|         $to = new TestPackedMessage();
 | |
|         $to->mergeFromString(TestUtil::getGoldenTestUnpackedMessage());
 | |
|         TestUtil::assertTestPackedMessage($to);
 | |
|         $this->assertTrue(true);
 | |
|     }
 | |
| 
 | |
|     public function testUnpackedEncode()
 | |
|     {
 | |
|         $from = new TestUnpackedMessage();
 | |
|         TestUtil::setTestPackedMessage($from);
 | |
|         $this->assertSame(TestUtil::getGoldenTestUnpackedMessage(),
 | |
|                           $from->serializeToString());
 | |
|     }
 | |
| 
 | |
|     public function testUnpackedDecodePacked()
 | |
|     {
 | |
|         $to = new TestUnpackedMessage();
 | |
|         $to->mergeFromString(TestUtil::getGoldenTestPackedMessage());
 | |
|         TestUtil::assertTestPackedMessage($to);
 | |
|         $this->assertTrue(true);
 | |
|     }
 | |
| 
 | |
|     public function testUnpackedDecodeUnpacked()
 | |
|     {
 | |
|         $to = new TestUnpackedMessage();
 | |
|         $to->mergeFromString(TestUtil::getGoldenTestUnpackedMessage());
 | |
|         TestUtil::assertTestPackedMessage($to);
 | |
|         $this->assertTrue(true);
 | |
|     }
 | |
| 
 | |
|     public function testDecodeInt64()
 | |
|     {
 | |
|         // Read 64 testing
 | |
|         $testVals = array(
 | |
|             '10'                 => '100a',
 | |
|             '100'                => '1064',
 | |
|             '800'                => '10a006',
 | |
|             '6400'               => '108032',
 | |
|             '70400'              => '1080a604',
 | |
|             '774400'             => '1080a22f',
 | |
|             '9292800'            => '108098b704',
 | |
|             '74342400'           => '1080c0b923',
 | |
|             '743424000'          => '108080bfe202',
 | |
|             '8177664000'         => '108080b5bb1e',
 | |
|             '65421312000'        => '108080a8dbf301',
 | |
|             '785055744000'       => '108080e0c7ec16',
 | |
|             '9420668928000'      => '10808080dd969202',
 | |
|             '103627358208000'    => '10808080fff9c717',
 | |
|             '1139900940288000'   => '10808080f5bd978302',
 | |
|             '13678811283456000'  => '10808080fce699a618',
 | |
|             '109430490267648000' => '10808080e0b7ceb1c201',
 | |
|             '984874412408832000' => '10808080e0f5c1bed50d',
 | |
|         );
 | |
| 
 | |
|         $msg = new TestMessage();
 | |
|         foreach ($testVals as $original => $encoded) {
 | |
|             $msg->setOptionalInt64($original);
 | |
|             $data = $msg->serializeToString();
 | |
|             $this->assertSame($encoded, bin2hex($data));
 | |
|             $msg->setOptionalInt64(0);
 | |
|             $msg->mergeFromString($data);
 | |
|             $this->assertEquals($original, $msg->getOptionalInt64());
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     public function testDecodeToExistingMessage()
 | |
|     {
 | |
|         $m1 = new TestMessage();
 | |
|         $this->setFields($m1);
 | |
|         $this->expectFields($m1);
 | |
| 
 | |
|         $m2 = new TestMessage();
 | |
|         $this->setFields2($m2);
 | |
|         $data = $m2->serializeToString();
 | |
| 
 | |
|         $m1->mergeFromString($data);
 | |
|         $this->expectFieldsMerged($m1);
 | |
|     }
 | |
| 
 | |
|     public function testDecodeFieldNonExist()
 | |
|     {
 | |
|         $data = hex2bin('c80501');
 | |
|         $m = new TestMessage();
 | |
|         $m->mergeFromString($data);
 | |
|         $this->assertTrue(true);
 | |
|     }
 | |
| 
 | |
|     public function testEncodeNegativeInt32()
 | |
|     {
 | |
|         $m = new TestMessage();
 | |
|         $m->setOptionalInt32(-1);
 | |
|         $data = $m->serializeToString();
 | |
|         $this->assertSame("08ffffffffffffffffff01", bin2hex($data));
 | |
|     }
 | |
| 
 | |
|     public function testDecodeNegativeInt32()
 | |
|     {
 | |
|         $m = new TestMessage();
 | |
|         $this->assertEquals(0, $m->getOptionalInt32());
 | |
|         $m->mergeFromString(hex2bin("08ffffffffffffffffff01"));
 | |
|         $this->assertEquals(-1, $m->getOptionalInt32());
 | |
| 
 | |
|         $m = new TestMessage();
 | |
|         $this->assertEquals(0, $m->getOptionalInt32());
 | |
|         $m->mergeFromString(hex2bin("08ffffffff0f"));
 | |
|         $this->assertEquals(-1, $m->getOptionalInt32());
 | |
|     }
 | |
| 
 | |
|     public function testRandomFieldOrder()
 | |
|     {
 | |
|         $m = new TestRandomFieldOrder();
 | |
|         $data = $m->serializeToString();
 | |
|         $this->assertSame("", $data);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @expectedException Exception
 | |
|      */
 | |
|     public function testDecodeInvalidInt32()
 | |
|     {
 | |
|         $m = new TestMessage();
 | |
|         $m->mergeFromString(hex2bin('08'));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @expectedException Exception
 | |
|      */
 | |
|     public function testDecodeInvalidSubMessage()
 | |
|     {
 | |
|         $m = new TestMessage();
 | |
|         $m->mergeFromString(hex2bin('9A010108'));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @expectedException Exception
 | |
|      */
 | |
|     public function testDecodeInvalidInt64()
 | |
|     {
 | |
|         $m = new TestMessage();
 | |
|         $m->mergeFromString(hex2bin('10'));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @expectedException Exception
 | |
|      */
 | |
|     public function testDecodeInvalidUInt32()
 | |
|     {
 | |
|         $m = new TestMessage();
 | |
|         $m->mergeFromString(hex2bin('18'));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @expectedException Exception
 | |
|      */
 | |
|     public function testDecodeInvalidUInt64()
 | |
|     {
 | |
|         $m = new TestMessage();
 | |
|         $m->mergeFromString(hex2bin('20'));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @expectedException Exception
 | |
|      */
 | |
|     public function testDecodeInvalidSInt32()
 | |
|     {
 | |
|         $m = new TestMessage();
 | |
|         $m->mergeFromString(hex2bin('28'));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @expectedException Exception
 | |
|      */
 | |
|     public function testDecodeInvalidSInt64()
 | |
|     {
 | |
|         $m = new TestMessage();
 | |
|         $m->mergeFromString(hex2bin('30'));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @expectedException Exception
 | |
|      */
 | |
|     public function testDecodeInvalidFixed32()
 | |
|     {
 | |
|         $m = new TestMessage();
 | |
|         $m->mergeFromString(hex2bin('3D'));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @expectedException Exception
 | |
|      */
 | |
|     public function testDecodeInvalidFixed64()
 | |
|     {
 | |
|         $m = new TestMessage();
 | |
|         $m->mergeFromString(hex2bin('41'));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @expectedException Exception
 | |
|      */
 | |
|     public function testDecodeInvalidSFixed32()
 | |
|     {
 | |
|         $m = new TestMessage();
 | |
|         $m->mergeFromString(hex2bin('4D'));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @expectedException Exception
 | |
|      */
 | |
|     public function testDecodeInvalidSFixed64()
 | |
|     {
 | |
|         $m = new TestMessage();
 | |
|         $m->mergeFromString(hex2bin('51'));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @expectedException Exception
 | |
|      */
 | |
|     public function testDecodeInvalidFloat()
 | |
|     {
 | |
|         $m = new TestMessage();
 | |
|         $m->mergeFromString(hex2bin('5D'));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @expectedException Exception
 | |
|      */
 | |
|     public function testDecodeInvalidDouble()
 | |
|     {
 | |
|         $m = new TestMessage();
 | |
|         $m->mergeFromString(hex2bin('61'));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @expectedException Exception
 | |
|      */
 | |
|     public function testDecodeInvalidBool()
 | |
|     {
 | |
|         $m = new TestMessage();
 | |
|         $m->mergeFromString(hex2bin('68'));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @expectedException Exception
 | |
|      */
 | |
|     public function testDecodeInvalidStringLengthMiss()
 | |
|     {
 | |
|         $m = new TestMessage();
 | |
|         $m->mergeFromString(hex2bin('72'));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @expectedException Exception
 | |
|      */
 | |
|     public function testDecodeInvalidStringDataMiss()
 | |
|     {
 | |
|         $m = new TestMessage();
 | |
|         $m->mergeFromString(hex2bin('7201'));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @expectedException Exception
 | |
|      */
 | |
|     public function testDecodeInvalidBytesLengthMiss()
 | |
|     {
 | |
|         $m = new TestMessage();
 | |
|         $m->mergeFromString(hex2bin('7A'));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @expectedException Exception
 | |
|      */
 | |
|     public function testDecodeInvalidBytesDataMiss()
 | |
|     {
 | |
|         $m = new TestMessage();
 | |
|         $m->mergeFromString(hex2bin('7A01'));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @expectedException Exception
 | |
|      */
 | |
|     public function testDecodeInvalidEnum()
 | |
|     {
 | |
|         $m = new TestMessage();
 | |
|         $m->mergeFromString(hex2bin('8001'));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @expectedException Exception
 | |
|      */
 | |
|     public function testDecodeInvalidMessageLengthMiss()
 | |
|     {
 | |
|         $m = new TestMessage();
 | |
|         $m->mergeFromString(hex2bin('8A01'));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @expectedException Exception
 | |
|      */
 | |
|     public function testDecodeInvalidMessageDataMiss()
 | |
|     {
 | |
|         $m = new TestMessage();
 | |
|         $m->mergeFromString(hex2bin('8A0101'));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @expectedException Exception
 | |
|      */
 | |
|     public function testDecodeInvalidPackedMessageLength()
 | |
|     {
 | |
|         $m = new TestPackedMessage();
 | |
|         $m->mergeFromString(hex2bin('D205'));
 | |
|     }
 | |
| 
 | |
|     public function testUnknown()
 | |
|     {
 | |
|         // Test preserve unknown for varint.
 | |
|         $m = new TestMessage();
 | |
|         $from = hex2bin('F80601');  // TODO(teboring): Add a util to encode
 | |
|                                     // varint for better readability
 | |
|         $m->mergeFromString($from);
 | |
|         $to = $m->serializeToString();
 | |
|         $this->assertSame(bin2hex($from), bin2hex($to));
 | |
| 
 | |
|         // Test preserve unknown for 64-bit.
 | |
|         $m = new TestMessage();
 | |
|         $from = hex2bin('F9060000000000000000');
 | |
|         $m->mergeFromString($from);
 | |
|         $to = $m->serializeToString();
 | |
|         $this->assertSame(bin2hex($from), bin2hex($to));
 | |
| 
 | |
|         // Test preserve unknown for length delimited.
 | |
|         $m = new TestMessage();
 | |
|         $from = hex2bin('FA0600');
 | |
|         $m->mergeFromString($from);
 | |
|         $to = $m->serializeToString();
 | |
|         $this->assertSame(bin2hex($from), bin2hex($to));
 | |
| 
 | |
|         // Test preserve unknown for 32-bit.
 | |
|         $m = new TestMessage();
 | |
|         $from = hex2bin('FD0600000000');
 | |
|         $m->mergeFromString($from);
 | |
|         $to = $m->serializeToString();
 | |
|         $this->assertSame(bin2hex($from), bin2hex($to));
 | |
| 
 | |
|         // Test discard unknown in message.
 | |
|         $m = new TestMessage();
 | |
|         $from = hex2bin('F80601');
 | |
|         $m->mergeFromString($from);
 | |
|         $m->discardUnknownFields();
 | |
|         $to = $m->serializeToString();
 | |
|         $this->assertSame("", bin2hex($to));
 | |
| 
 | |
|         // Test discard unknown for singular message field.
 | |
|         $m = new TestMessage();
 | |
|         $from = hex2bin('8A0103F80601');
 | |
|         $m->mergeFromString($from);
 | |
|         $m->discardUnknownFields();
 | |
|         $to = $m->serializeToString();
 | |
|         $this->assertSame("8a0100", bin2hex($to));
 | |
| 
 | |
|         // Test discard unknown for repeated message field.
 | |
|         $m = new TestMessage();
 | |
|         $from = hex2bin('FA0203F80601');
 | |
|         $m->mergeFromString($from);
 | |
|         $m->discardUnknownFields();
 | |
|         $to = $m->serializeToString();
 | |
|         $this->assertSame("fa0200", bin2hex($to));
 | |
| 
 | |
|         // Test discard unknown for map message value field.
 | |
|         $m = new TestMessage();
 | |
|         $from = hex2bin("BA050708011203F80601");
 | |
|         $m->mergeFromString($from);
 | |
|         $m->discardUnknownFields();
 | |
|         $to = $m->serializeToString();
 | |
|         $this->assertSame("ba050408011200", bin2hex($to));
 | |
| 
 | |
|         // Test discard unknown for singular message field.
 | |
|         $m = new TestMessage();
 | |
|         $from = hex2bin('9A0403F80601');
 | |
|         $m->mergeFromString($from);
 | |
|         $m->discardUnknownFields();
 | |
|         $to = $m->serializeToString();
 | |
|         $this->assertSame("9a0400", bin2hex($to));
 | |
|     }
 | |
| 
 | |
|     public function testJsonUnknown()
 | |
|     {
 | |
|         // Test unknown number
 | |
|         $m = new TestMessage();
 | |
|         $m->mergeFromJsonString("{\"unknown\":1,
 | |
|                                 \"optionalInt32\":1}", true);
 | |
|         $this->assertSame(1, $m->getOptionalInt32());
 | |
| 
 | |
|         // Test unknown bool
 | |
|         $m = new TestMessage();
 | |
|         $m->mergeFromJsonString("{\"unknown\":true,
 | |
|                                 \"optionalInt32\":1}", true);
 | |
|         $this->assertSame(1, $m->getOptionalInt32());
 | |
| 
 | |
|         // Test unknown string
 | |
|         $m = new TestMessage();
 | |
|         $m->mergeFromJsonString("{\"unknown\":\"abc\",
 | |
|                                 \"optionalInt32\":1}", true);
 | |
|         $this->assertSame(1, $m->getOptionalInt32());
 | |
| 
 | |
|         // Test unknown null
 | |
|         $m = new TestMessage();
 | |
|         $m->mergeFromJsonString("{\"unknown\":null,
 | |
|                                 \"optionalInt32\":1}", true);
 | |
|         $this->assertSame(1, $m->getOptionalInt32());
 | |
| 
 | |
|         // Test unknown array
 | |
|         $m = new TestMessage();
 | |
|         $m->mergeFromJsonString("{\"unknown\":[],
 | |
|                                 \"optionalInt32\":1}", true);
 | |
|         $this->assertSame(1, $m->getOptionalInt32());
 | |
| 
 | |
|         // Test unknown number array
 | |
|         $m = new TestMessage();
 | |
|         $m->mergeFromJsonString("{\"unknown\":[1],
 | |
|                                 \"optionalInt32\":1}", true);
 | |
|         $this->assertSame(1, $m->getOptionalInt32());
 | |
| 
 | |
|         // Test unknown bool array
 | |
|         $m = new TestMessage();
 | |
|         $m->mergeFromJsonString("{\"unknown\":[true],
 | |
|                                 \"optionalInt32\":1}", true);
 | |
|         $this->assertSame(1, $m->getOptionalInt32());
 | |
| 
 | |
|         // Test unknown string array
 | |
|         $m = new TestMessage();
 | |
|         $m->mergeFromJsonString("{\"unknown\":[\"a\"],
 | |
|                                 \"optionalInt32\":1}", true);
 | |
|         $this->assertSame(1, $m->getOptionalInt32());
 | |
| 
 | |
|         // Test unknown null array
 | |
|         $m = new TestMessage();
 | |
|         $m->mergeFromJsonString("{\"unknown\":[null],
 | |
|                                 \"optionalInt32\":1}", true);
 | |
|         $this->assertSame(1, $m->getOptionalInt32());
 | |
| 
 | |
|         // Test unknown array array
 | |
|         $m = new TestMessage();
 | |
|         $m->mergeFromJsonString("{\"unknown\":[[]],
 | |
|                                 \"optionalInt32\":1}", true);
 | |
|         $this->assertSame(1, $m->getOptionalInt32());
 | |
| 
 | |
|         // Test unknown object array
 | |
|         $m = new TestMessage();
 | |
|         $m->mergeFromJsonString("{\"unknown\":[{}],
 | |
|                                 \"optionalInt32\":1}", true);
 | |
|         $this->assertSame(1, $m->getOptionalInt32());
 | |
| 
 | |
|         // Test unknown double value array
 | |
|         $m = new TestMessage();
 | |
|         $m->mergeFromJsonString("{\"unknown\":[1, 2],
 | |
|                                 \"optionalInt32\":1}", true);
 | |
|         $this->assertSame(1, $m->getOptionalInt32());
 | |
| 
 | |
|         // Test unknown object
 | |
|         $m = new TestMessage();
 | |
|         $m->mergeFromJsonString("{\"unknown\":{},
 | |
|                                 \"optionalInt32\":1}", true);
 | |
|         $this->assertSame(1, $m->getOptionalInt32());
 | |
| 
 | |
|         // Test unknown number object
 | |
|         $m = new TestMessage();
 | |
|         $m->mergeFromJsonString("{\"unknown\":{\"a\":1},
 | |
|                                 \"optionalInt32\":1}", true);
 | |
|         $this->assertSame(1, $m->getOptionalInt32());
 | |
| 
 | |
|         // Test unknown bool object
 | |
|         $m = new TestMessage();
 | |
|         $m->mergeFromJsonString("{\"unknown\":{\"a\":true},
 | |
|                                 \"optionalInt32\":1}", true);
 | |
|         $this->assertSame(1, $m->getOptionalInt32());
 | |
| 
 | |
|         // Test unknown string object
 | |
|         $m = new TestMessage();
 | |
|         $m->mergeFromJsonString("{\"unknown\":{\"a\":\"a\"},
 | |
|                                 \"optionalInt32\":1}", true);
 | |
|         $this->assertSame(1, $m->getOptionalInt32());
 | |
| 
 | |
|         // Test unknown null object
 | |
|         $m = new TestMessage();
 | |
|         $m->mergeFromJsonString("{\"unknown\":{\"a\":null},
 | |
|                                 \"optionalInt32\":1}", true);
 | |
|         $this->assertSame(1, $m->getOptionalInt32());
 | |
| 
 | |
|         // Test unknown array object
 | |
|         $m = new TestMessage();
 | |
|         $m->mergeFromJsonString("{\"unknown\":{\"a\":[]},
 | |
|                                 \"optionalInt32\":1}", true);
 | |
|         $this->assertSame(1, $m->getOptionalInt32());
 | |
| 
 | |
|         // Test unknown object object
 | |
|         $m = new TestMessage();
 | |
|         $m->mergeFromJsonString("{\"unknown\":{\"a\":{}},
 | |
|                                 \"optionalInt32\":1}", true);
 | |
|         $this->assertSame(1, $m->getOptionalInt32());
 | |
| 
 | |
|         // Test unknown double value object
 | |
|         $m = new TestMessage();
 | |
|         $m->mergeFromJsonString("{\"unknown\":{\"a\":1, \"b\":1},
 | |
|                                 \"optionalInt32\":1}", true);
 | |
|         $this->assertSame(1, $m->getOptionalInt32());
 | |
|     }
 | |
| 
 | |
|     public function testJsonEncode()
 | |
|     {
 | |
|         $from = new TestMessage();
 | |
|         $this->setFields($from);
 | |
|         $data = $from->serializeToJsonString();
 | |
|         $to = new TestMessage();
 | |
|         $to->mergeFromJsonString($data);
 | |
|         $this->expectFields($to);
 | |
|     }
 | |
| 
 | |
|     public function testDecodeDuration()
 | |
|     {
 | |
|         $m = new Google\Protobuf\Duration();
 | |
|         $m->mergeFromJsonString("\"1234.5678s\"");
 | |
|         $this->assertEquals(1234, $m->getSeconds());
 | |
|         $this->assertEquals(567800000, $m->getNanos());
 | |
|     }
 | |
| 
 | |
|     public function testEncodeDuration()
 | |
|     {
 | |
|         $m = new Google\Protobuf\Duration();
 | |
|         $m->setSeconds(1234);
 | |
|         $m->setNanos(999999999);
 | |
|         $this->assertEquals("\"1234.999999999s\"", $m->serializeToJsonString());
 | |
|     }
 | |
| 
 | |
|     public function testDecodeTimestamp()
 | |
|     {
 | |
|         $m = new Google\Protobuf\Timestamp();
 | |
|         $m->mergeFromJsonString("\"2000-01-01T00:00:00.123456789Z\"");
 | |
|         $this->assertEquals(946684800, $m->getSeconds());
 | |
|         $this->assertEquals(123456789, $m->getNanos());
 | |
|     }
 | |
| 
 | |
|     public function testEncodeTimestamp()
 | |
|     {
 | |
|         $m = new Google\Protobuf\Timestamp();
 | |
|         $m->setSeconds(946684800);
 | |
|         $m->setNanos(123456789);
 | |
|         $this->assertEquals("\"2000-01-01T00:00:00.123456789Z\"",
 | |
|                             $m->serializeToJsonString());
 | |
|     }
 | |
| 
 | |
|     public function testDecodeTopLevelValue()
 | |
|     {
 | |
|         $m = new Value();
 | |
|         $m->mergeFromJsonString("\"a\"");
 | |
|         $this->assertSame("a", $m->getStringValue());
 | |
| 
 | |
|         $m = new Value();
 | |
|         $m->mergeFromJsonString("1.5");
 | |
|         $this->assertSame(1.5, $m->getNumberValue());
 | |
| 
 | |
|         $m = new Value();
 | |
|         $m->mergeFromJsonString("true");
 | |
|         $this->assertSame(true, $m->getBoolValue());
 | |
| 
 | |
|         $m = new Value();
 | |
|         $m->mergeFromJsonString("null");
 | |
|         $this->assertSame("null_value", $m->getKind());
 | |
| 
 | |
|         $m = new Value();
 | |
|         $m->mergeFromJsonString("[1]");
 | |
|         $this->assertSame("list_value", $m->getKind());
 | |
| 
 | |
|         $m = new Value();
 | |
|         $m->mergeFromJsonString("{\"a\":1}");
 | |
|         $this->assertSame("struct_value", $m->getKind());
 | |
|     }
 | |
| 
 | |
|     public function testEncodeTopLevelValue()
 | |
|     {
 | |
|         $m = new Value();
 | |
|         $m->setStringValue("a");
 | |
|         $this->assertSame("\"a\"", $m->serializeToJsonString());
 | |
| 
 | |
|         $m = new Value();
 | |
|         $m->setNumberValue(1.5);
 | |
|         $this->assertSame("1.5", $m->serializeToJsonString());
 | |
| 
 | |
|         $m = new Value();
 | |
|         $m->setBoolValue(true);
 | |
|         $this->assertSame("true", $m->serializeToJsonString());
 | |
| 
 | |
|         $m = new Value();
 | |
|         $m->setNullValue(0);
 | |
|         $this->assertSame("null", $m->serializeToJsonString());
 | |
|     }
 | |
| 
 | |
|     public function testDecodeTopLevelListValue()
 | |
|     {
 | |
|         $m = new ListValue();
 | |
|         $m->mergeFromJsonString("[1]");
 | |
|         $this->assertSame(1.0, $m->getValues()[0]->getNumberValue());
 | |
|     }
 | |
| 
 | |
|     public function testEncodeTopLevelListValue()
 | |
|     {
 | |
|         $m = new ListValue();
 | |
|         $arr = $m->getValues();
 | |
|         $sub = new Value();
 | |
|         $sub->setNumberValue(1.5);
 | |
|         $arr[] = $sub;
 | |
|         $this->assertSame("[1.5]", $m->serializeToJsonString());
 | |
|     }
 | |
| 
 | |
|     public function testEncodeEmptyListValue()
 | |
|     {
 | |
|         $m = new Struct();
 | |
|         $m->setFields(['test' => (new Value())->setListValue(new ListValue())]);
 | |
|         $this->assertSame('{"test":[]}', $m->serializeToJsonString());
 | |
|     }
 | |
| 
 | |
|     public function testDecodeTopLevelStruct()
 | |
|     {
 | |
|         $m = new Struct();
 | |
|         $m->mergeFromJsonString("{\"a\":{\"b\":1}}");
 | |
|         $this->assertSame(1.0, $m->getFields()["a"]
 | |
|                                  ->getStructValue()
 | |
|                                  ->getFields()["b"]->getNumberValue());
 | |
|     }
 | |
| 
 | |
|     public function testEncodeTopLevelStruct()
 | |
|     {
 | |
|         $m = new Struct();
 | |
|         $map = $m->getFields();
 | |
|         $sub = new Value();
 | |
|         $sub->setNumberValue(1.5);
 | |
|         $map["a"] = $sub;
 | |
|         $this->assertSame("{\"a\":1.5}", $m->serializeToJsonString());
 | |
|     }
 | |
| 
 | |
|     public function testEncodeEmptyStruct()
 | |
|     {
 | |
|         $m = new Struct();
 | |
|         $m->setFields(['test' => (new Value())->setStructValue(new Struct())]);
 | |
|         $this->assertSame('{"test":{}}', $m->serializeToJsonString());
 | |
|     }
 | |
| 
 | |
|     public function testDecodeTopLevelAny()
 | |
|     {
 | |
|         // Make sure packed message has been created at least once.
 | |
|         $packed = new TestMessage();
 | |
| 
 | |
|         $m1 = new Any();
 | |
|         $m1->mergeFromJsonString(
 | |
|             "{\"optionalInt32\": 1, " .
 | |
|             "\"@type\":\"type.googleapis.com/foo.TestMessage\"}");
 | |
|         $this->assertSame("type.googleapis.com/foo.TestMessage",
 | |
|                           $m1->getTypeUrl());
 | |
|         $this->assertSame("0801", bin2hex($m1->getValue()));
 | |
| 
 | |
|         $m2 = new Any();
 | |
|         $m2->mergeFromJsonString(
 | |
|             "{\"@type\":\"type.googleapis.com/foo.TestMessage\", " .
 | |
|             "\"optionalInt32\": 1}");
 | |
|         $this->assertSame("type.googleapis.com/foo.TestMessage",
 | |
|                           $m2->getTypeUrl());
 | |
|         $this->assertSame("0801", bin2hex($m2->getValue()));
 | |
| 
 | |
|         $m3 = new Any();
 | |
|         $m3->mergeFromJsonString(
 | |
|             "{\"optionalInt32\": 1, " .
 | |
|             "\"@type\":\"type.googleapis.com/foo.TestMessage\", " .
 | |
|             "\"optionalInt64\": 2}");
 | |
|         $this->assertSame("type.googleapis.com/foo.TestMessage",
 | |
|                           $m3->getTypeUrl());
 | |
|         $this->assertSame("08011002", bin2hex($m3->getValue()));
 | |
|     }
 | |
| 
 | |
|     public function testDecodeAny()
 | |
|     {
 | |
|         // Make sure packed message has been created at least once.
 | |
|         $packed = new TestMessage();
 | |
| 
 | |
|         $m1 = new TestAny();
 | |
|         $m1->mergeFromJsonString(
 | |
|             "{\"any\": {\"optionalInt32\": 1, " .
 | |
|             "\"@type\":\"type.googleapis.com/foo.TestMessage\"}}");
 | |
|         $this->assertSame("type.googleapis.com/foo.TestMessage",
 | |
|                           $m1->getAny()->getTypeUrl());
 | |
|         $this->assertSame("0801", bin2hex($m1->getAny()->getValue()));
 | |
| 
 | |
|         $m2 = new TestAny();
 | |
|         $m2->mergeFromJsonString(
 | |
|             "{\"any\":{\"@type\":\"type.googleapis.com/foo.TestMessage\", " .
 | |
|             "\"optionalInt32\": 1}}");
 | |
|         $this->assertSame("type.googleapis.com/foo.TestMessage",
 | |
|                           $m2->getAny()->getTypeUrl());
 | |
|         $this->assertSame("0801", bin2hex($m2->getAny()->getValue()));
 | |
| 
 | |
|         $m3 = new TestAny();
 | |
|         $m3->mergeFromJsonString(
 | |
|             "{\"any\":{\"optionalInt32\": 1, " .
 | |
|             "\"@type\":\"type.googleapis.com/foo.TestMessage\", " .
 | |
|             "\"optionalInt64\": 2}}");
 | |
|         $this->assertSame("type.googleapis.com/foo.TestMessage",
 | |
|                           $m3->getAny()->getTypeUrl());
 | |
|         $this->assertSame("08011002", bin2hex($m3->getAny()->getValue()));
 | |
|     }
 | |
| 
 | |
|     public function testDecodeAnyWithWellKnownPacked()
 | |
|     {
 | |
|         // Make sure packed message has been created at least once.
 | |
|         $packed = new Int32Value();
 | |
| 
 | |
|         $m1 = new TestAny();
 | |
|         $m1->mergeFromJsonString(
 | |
|             "{\"any\":" .
 | |
|             "  {\"@type\":\"type.googleapis.com/google.protobuf.Int32Value\"," .
 | |
|             "   \"value\":1}}");
 | |
|         $this->assertSame("type.googleapis.com/google.protobuf.Int32Value",
 | |
|                           $m1->getAny()->getTypeUrl());
 | |
|         $this->assertSame("0801", bin2hex($m1->getAny()->getValue()));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @expectedException Exception
 | |
|      */
 | |
|     public function testDecodeAnyWithUnknownPacked()
 | |
|     {
 | |
|         $m = new TestAny();
 | |
|         $m->mergeFromJsonString(
 | |
|             "{\"any\":" .
 | |
|             "  {\"@type\":\"type.googleapis.com/unknown\"," .
 | |
|             "   \"value\":1}}");
 | |
|     }
 | |
| 
 | |
|     public function testEncodeTopLevelAny()
 | |
|     {
 | |
|         // Test a normal message.
 | |
|         $packed = new TestMessage();
 | |
|         $packed->setOptionalInt32(123);
 | |
|         $packed->setOptionalString("abc");
 | |
| 
 | |
|         $m = new Any();
 | |
|         $m->pack($packed);
 | |
|         $expected1 =
 | |
|             "{\"@type\":\"type.googleapis.com/foo.TestMessage\"," .
 | |
|             "\"optional_int32\":123,\"optional_string\":\"abc\"}";
 | |
|         $expected2 =
 | |
|             "{\"@type\":\"type.googleapis.com/foo.TestMessage\"," .
 | |
|             "\"optionalInt32\":123,\"optionalString\":\"abc\"}";
 | |
|         $result = $m->serializeToJsonString();
 | |
|         $this->assertTrue($expected1 === $result || $expected2 === $result);
 | |
| 
 | |
|         // Test a well known message.
 | |
|         $packed = new Int32Value();
 | |
|         $packed->setValue(123);
 | |
| 
 | |
|         $m = new Any();
 | |
|         $m->pack($packed);
 | |
|         $this->assertSame(
 | |
|             "{\"@type\":\"type.googleapis.com/google.protobuf.Int32Value\"," .
 | |
|             "\"value\":123}",
 | |
|             $m->serializeToJsonString());
 | |
| 
 | |
|         // Test an Any message.
 | |
|         $outer = new Any();
 | |
|         $outer->pack($m);
 | |
|         $this->assertSame(
 | |
|             "{\"@type\":\"type.googleapis.com/google.protobuf.Any\"," .
 | |
|             "\"value\":{\"@type\":\"type.googleapis.com/google.protobuf.Int32Value\"," .
 | |
|             "\"value\":123}}",
 | |
|             $outer->serializeToJsonString());
 | |
| 
 | |
|         // Test a Timestamp message.
 | |
|         $packed = new Google\Protobuf\Timestamp();
 | |
|         $packed->setSeconds(946684800);
 | |
|         $packed->setNanos(123456789);
 | |
|         $m = new Any();
 | |
|         $m->pack($packed);
 | |
|         $this->assertSame(
 | |
|             "{\"@type\":\"type.googleapis.com/google.protobuf.Timestamp\"," .
 | |
|             "\"value\":\"2000-01-01T00:00:00.123456789Z\"}",
 | |
|             $m->serializeToJsonString());
 | |
|     }
 | |
| 
 | |
|     public function testDecodeTopLevelFieldMask()
 | |
|     {
 | |
|         $m = new TestMessage();
 | |
|         $m->setMapStringString(['a'=>'abcdefg']);
 | |
|         $data1 = $m->serializeToJsonString();
 | |
|         $n = new TestMessage();
 | |
|         $n->mergeFromJsonString($data1);
 | |
|         $data2 = $n->serializeToJsonString();
 | |
|         $this->assertSame($data1, $data2);
 | |
| 
 | |
|         $m = new FieldMask();
 | |
|         $m->mergeFromJsonString("\"foo.barBaz,qux\"");
 | |
|         $this->assertSame("foo.bar_baz", $m->getPaths()[0]);
 | |
|         $this->assertSame("qux", $m->getPaths()[1]);
 | |
|     }
 | |
| 
 | |
|     public function testEncodeTopLevelFieldMask()
 | |
|     {
 | |
|         $m = new FieldMask();
 | |
|         $m->setPaths(["foo.bar_baz", "qux"]);
 | |
|         $this->assertSame("\"foo.barBaz,qux\"", $m->serializeToJsonString());
 | |
|     }
 | |
| 
 | |
|     public function testDecodeEmptyFieldMask()
 | |
|     {
 | |
|         $m = new FieldMask();
 | |
|         $m->mergeFromJsonString("\"\"");
 | |
|         $this->assertEquals("", $m->serializeToString());
 | |
|     }
 | |
| 
 | |
|     public function testJsonDecodeMapWithDefaultValueKey()
 | |
|     {
 | |
|         $m = new TestMessage();
 | |
|         $m->getMapInt32Int32()[0] = 0;
 | |
|         $this->assertSame("{\"mapInt32Int32\":{\"0\":0}}",
 | |
|                           $m->serializeToJsonString());
 | |
| 
 | |
|         $m = new TestMessage();
 | |
|         $m->getMapStringString()[""] = "";
 | |
|         $this->assertSame("{\"mapStringString\":{\"\":\"\"}}",
 | |
|                           $m->serializeToJsonString());
 | |
|     }
 | |
| 
 | |
|     public function testJsonDecodeNumericStringMapKey()
 | |
|     {
 | |
|         $m = new TestMessage();
 | |
|         $m->getMapStringString()["1"] = "1";
 | |
|         $data = $m->serializeToJsonString();
 | |
|         $this->assertSame("{\"mapStringString\":{\"1\":\"1\"}}", $data);
 | |
|         $n = new TestMessage();
 | |
|         $n->mergeFromJsonString($data);
 | |
|     }
 | |
| 
 | |
| }
 |