Protocol Buffers - Google's data interchange format (grpc依赖)
https://developers.google.com/protocol-buffers/
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
225 lines
6.7 KiB
225 lines
6.7 KiB
<?php |
|
|
|
require_once('test_base.php'); |
|
require_once('test_util.php'); |
|
|
|
use Google\Protobuf\RepeatedField; |
|
use Google\Protobuf\GPBType; |
|
use Foo\TestEnum; |
|
use Foo\TestMessage; |
|
use Foo\TestMessage_Sub; |
|
use Foo\TestPackedMessage; |
|
use Foo\TestUnpackedMessage; |
|
|
|
class EncodeDecodeTest extends TestBase |
|
{ |
|
|
|
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 TestMessage_Sub(); |
|
$sub_m->setA(1); |
|
$m->setOneofMessage($sub_m); |
|
$data = $m->serializeToString(); |
|
$n = new TestMessage(); |
|
$n->mergeFromString($data); |
|
$this->assertSame(1, $n->getOneofMessage()->getA()); |
|
} |
|
|
|
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); |
|
} |
|
|
|
public function testPackedDecodeUnpacked() |
|
{ |
|
$to = new TestPackedMessage(); |
|
$to->mergeFromString(TestUtil::getGoldenTestUnpackedMessage()); |
|
TestUtil::assertTestPackedMessage($to); |
|
} |
|
|
|
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); |
|
} |
|
|
|
public function testUnpackedDecodeUnpacked() |
|
{ |
|
$to = new TestUnpackedMessage(); |
|
$to->mergeFromString(TestUtil::getGoldenTestUnpackedMessage()); |
|
TestUtil::assertTestPackedMessage($to); |
|
} |
|
|
|
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); |
|
} |
|
|
|
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()); |
|
} |
|
|
|
# TODO(teboring): Add test back when php implementation is ready for json |
|
# encode/decode. |
|
# public function testJsonEncode() |
|
# { |
|
# $from = new TestMessage(); |
|
# $this->setFields($from); |
|
# $data = $from->jsonEncode(); |
|
# $to = new TestMessage(); |
|
# $to->jsonDecode($data); |
|
# $this->expectFields($to); |
|
# } |
|
}
|
|
|