2016-09-15 18:09:01 +00:00
|
|
|
<?php
|
|
|
|
|
2017-04-20 03:03:34 +00:00
|
|
|
require_once('generated/NoNamespaceEnum.php');
|
|
|
|
require_once('generated/NoNamespaceMessage.php');
|
2017-02-12 00:36:17 +00:00
|
|
|
require_once('test_base.php');
|
2016-09-15 18:09:01 +00:00
|
|
|
require_once('test_util.php');
|
|
|
|
|
|
|
|
use Google\Protobuf\Internal\RepeatedField;
|
2017-03-10 21:42:59 +00:00
|
|
|
use Google\Protobuf\Internal\MapField;
|
2016-09-15 18:09:01 +00:00
|
|
|
use Google\Protobuf\Internal\GPBType;
|
|
|
|
use Foo\TestEnum;
|
2017-06-05 07:10:18 +00:00
|
|
|
use Foo\TestIncludeNamespaceMessage;
|
2017-03-17 18:08:06 +00:00
|
|
|
use Foo\TestIncludePrefixMessage;
|
2016-09-15 18:09:01 +00:00
|
|
|
use Foo\TestMessage;
|
|
|
|
use Foo\TestMessage_Sub;
|
2017-08-04 23:35:49 +00:00
|
|
|
use Foo\TestReverseFieldOrder;
|
2017-08-21 20:39:15 +00:00
|
|
|
use Foo\testLowerCaseMessage;
|
|
|
|
use Foo\testLowerCaseEnum;
|
2017-06-05 07:10:18 +00:00
|
|
|
use Php\Test\TestNamespace;
|
2016-09-15 18:09:01 +00:00
|
|
|
|
2017-02-12 00:36:17 +00:00
|
|
|
class GeneratedClassTest extends TestBase
|
2016-09-15 18:09:01 +00:00
|
|
|
{
|
|
|
|
|
|
|
|
#########################################################
|
|
|
|
# Test field accessors.
|
|
|
|
#########################################################
|
|
|
|
|
|
|
|
public function testSetterGetter()
|
|
|
|
{
|
|
|
|
$m = new TestMessage();
|
|
|
|
$m->setOptionalInt32(1);
|
|
|
|
$this->assertSame(1, $m->getOptionalInt32());
|
|
|
|
}
|
|
|
|
|
|
|
|
#########################################################
|
|
|
|
# Test int32 field.
|
|
|
|
#########################################################
|
|
|
|
|
|
|
|
public function testInt32Field()
|
|
|
|
{
|
|
|
|
$m = new TestMessage();
|
|
|
|
|
|
|
|
// Set integer.
|
|
|
|
$m->setOptionalInt32(MAX_INT32);
|
|
|
|
$this->assertSame(MAX_INT32, $m->getOptionalInt32());
|
|
|
|
$m->setOptionalInt32(MIN_INT32);
|
|
|
|
$this->assertSame(MIN_INT32, $m->getOptionalInt32());
|
|
|
|
|
|
|
|
// Set float.
|
|
|
|
$m->setOptionalInt32(1.1);
|
|
|
|
$this->assertSame(1, $m->getOptionalInt32());
|
|
|
|
$m->setOptionalInt32(MAX_INT32_FLOAT);
|
|
|
|
$this->assertSame(MAX_INT32, $m->getOptionalInt32());
|
|
|
|
$m->setOptionalInt32(MIN_INT32_FLOAT);
|
|
|
|
$this->assertSame(MIN_INT32, $m->getOptionalInt32());
|
|
|
|
|
|
|
|
// Set string.
|
|
|
|
$m->setOptionalInt32('2');
|
|
|
|
$this->assertSame(2, $m->getOptionalInt32());
|
|
|
|
$m->setOptionalInt32('3.1');
|
|
|
|
$this->assertSame(3, $m->getOptionalInt32());
|
|
|
|
$m->setOptionalInt32(MAX_INT32_STRING);
|
|
|
|
$this->assertSame(MAX_INT32, $m->getOptionalInt32());
|
|
|
|
$m->setOptionalInt32(MIN_INT32_STRING);
|
|
|
|
$this->assertSame(MIN_INT32, $m->getOptionalInt32());
|
|
|
|
}
|
|
|
|
|
|
|
|
#########################################################
|
|
|
|
# Test uint32 field.
|
|
|
|
#########################################################
|
|
|
|
|
|
|
|
public function testUint32Field()
|
|
|
|
{
|
|
|
|
$m = new TestMessage();
|
|
|
|
|
|
|
|
// Set integer.
|
|
|
|
$m->setOptionalUint32(MAX_UINT32);
|
|
|
|
$this->assertSame(-1, $m->getOptionalUint32());
|
|
|
|
$m->setOptionalUint32(-1);
|
|
|
|
$this->assertSame(-1, $m->getOptionalUint32());
|
|
|
|
$m->setOptionalUint32(MIN_UINT32);
|
|
|
|
$this->assertSame(MIN_INT32, $m->getOptionalUint32());
|
|
|
|
|
|
|
|
// Set float.
|
|
|
|
$m->setOptionalUint32(1.1);
|
|
|
|
$this->assertSame(1, $m->getOptionalUint32());
|
|
|
|
$m->setOptionalUint32(MAX_UINT32_FLOAT);
|
|
|
|
$this->assertSame(-1, $m->getOptionalUint32());
|
|
|
|
$m->setOptionalUint32(-1.0);
|
|
|
|
$this->assertSame(-1, $m->getOptionalUint32());
|
|
|
|
$m->setOptionalUint32(MIN_UINT32_FLOAT);
|
|
|
|
$this->assertSame(MIN_INT32, $m->getOptionalUint32());
|
|
|
|
|
|
|
|
// Set string.
|
|
|
|
$m->setOptionalUint32('2');
|
|
|
|
$this->assertSame(2, $m->getOptionalUint32());
|
|
|
|
$m->setOptionalUint32('3.1');
|
|
|
|
$this->assertSame(3, $m->getOptionalUint32());
|
|
|
|
$m->setOptionalUint32(MAX_UINT32_STRING);
|
|
|
|
$this->assertSame(-1, $m->getOptionalUint32());
|
|
|
|
$m->setOptionalUint32('-1.0');
|
|
|
|
$this->assertSame(-1, $m->getOptionalUint32());
|
|
|
|
$m->setOptionalUint32(MIN_UINT32_STRING);
|
|
|
|
$this->assertSame(MIN_INT32, $m->getOptionalUint32());
|
|
|
|
}
|
|
|
|
|
|
|
|
#########################################################
|
|
|
|
# Test int64 field.
|
|
|
|
#########################################################
|
|
|
|
|
|
|
|
public function testInt64Field()
|
|
|
|
{
|
|
|
|
$m = new TestMessage();
|
|
|
|
|
|
|
|
// Set integer.
|
|
|
|
$m->setOptionalInt64(MAX_INT64);
|
|
|
|
$this->assertSame(MAX_INT64, $m->getOptionalInt64());
|
|
|
|
$m->setOptionalInt64(MIN_INT64);
|
|
|
|
$this->assertEquals(MIN_INT64, $m->getOptionalInt64());
|
|
|
|
|
|
|
|
// Set float.
|
|
|
|
$m->setOptionalInt64(1.1);
|
2016-10-26 00:27:05 +00:00
|
|
|
if (PHP_INT_SIZE == 4) {
|
|
|
|
$this->assertSame('1', $m->getOptionalInt64());
|
|
|
|
} else {
|
|
|
|
$this->assertSame(1, $m->getOptionalInt64());
|
|
|
|
}
|
2016-09-15 18:09:01 +00:00
|
|
|
|
|
|
|
// Set string.
|
|
|
|
$m->setOptionalInt64('2');
|
2016-10-26 00:27:05 +00:00
|
|
|
if (PHP_INT_SIZE == 4) {
|
|
|
|
$this->assertSame('2', $m->getOptionalInt64());
|
|
|
|
} else {
|
|
|
|
$this->assertSame(2, $m->getOptionalInt64());
|
|
|
|
}
|
|
|
|
|
2016-09-15 18:09:01 +00:00
|
|
|
$m->setOptionalInt64('3.1');
|
2016-10-26 00:27:05 +00:00
|
|
|
if (PHP_INT_SIZE == 4) {
|
|
|
|
$this->assertSame('3', $m->getOptionalInt64());
|
|
|
|
} else {
|
|
|
|
$this->assertSame(3, $m->getOptionalInt64());
|
|
|
|
}
|
|
|
|
|
2016-09-15 18:09:01 +00:00
|
|
|
$m->setOptionalInt64(MAX_INT64_STRING);
|
2016-10-26 00:27:05 +00:00
|
|
|
if (PHP_INT_SIZE == 4) {
|
|
|
|
$this->assertSame(MAX_INT64_STRING, $m->getOptionalInt64());
|
|
|
|
} else {
|
|
|
|
$this->assertSame(MAX_INT64, $m->getOptionalInt64());
|
|
|
|
}
|
|
|
|
|
2016-09-15 18:09:01 +00:00
|
|
|
$m->setOptionalInt64(MIN_INT64_STRING);
|
2016-10-26 00:27:05 +00:00
|
|
|
if (PHP_INT_SIZE == 4) {
|
|
|
|
$this->assertSame(MIN_INT64_STRING, $m->getOptionalInt64());
|
|
|
|
} else {
|
|
|
|
$this->assertSame(MIN_INT64, $m->getOptionalInt64());
|
|
|
|
}
|
2016-09-15 18:09:01 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#########################################################
|
|
|
|
# Test uint64 field.
|
|
|
|
#########################################################
|
|
|
|
|
|
|
|
public function testUint64Field()
|
|
|
|
{
|
|
|
|
$m = new TestMessage();
|
|
|
|
|
|
|
|
// Set integer.
|
|
|
|
$m->setOptionalUint64(MAX_UINT64);
|
2016-10-26 00:27:05 +00:00
|
|
|
if (PHP_INT_SIZE == 4) {
|
|
|
|
$this->assertSame(MAX_UINT64_STRING, $m->getOptionalUint64());
|
|
|
|
} else {
|
|
|
|
$this->assertSame(MAX_UINT64, $m->getOptionalUint64());
|
|
|
|
}
|
2016-09-15 18:09:01 +00:00
|
|
|
|
|
|
|
// Set float.
|
|
|
|
$m->setOptionalUint64(1.1);
|
2016-10-26 00:27:05 +00:00
|
|
|
if (PHP_INT_SIZE == 4) {
|
|
|
|
$this->assertSame('1', $m->getOptionalUint64());
|
|
|
|
} else {
|
|
|
|
$this->assertSame(1, $m->getOptionalUint64());
|
|
|
|
}
|
2016-09-15 18:09:01 +00:00
|
|
|
|
|
|
|
// Set string.
|
|
|
|
$m->setOptionalUint64('2');
|
2016-10-26 00:27:05 +00:00
|
|
|
if (PHP_INT_SIZE == 4) {
|
|
|
|
$this->assertSame('2', $m->getOptionalUint64());
|
|
|
|
} else {
|
|
|
|
$this->assertSame(2, $m->getOptionalUint64());
|
|
|
|
}
|
|
|
|
|
2016-09-15 18:09:01 +00:00
|
|
|
$m->setOptionalUint64('3.1');
|
2016-10-26 00:27:05 +00:00
|
|
|
if (PHP_INT_SIZE == 4) {
|
|
|
|
$this->assertSame('3', $m->getOptionalUint64());
|
|
|
|
} else {
|
|
|
|
$this->assertSame(3, $m->getOptionalUint64());
|
|
|
|
}
|
|
|
|
|
2016-09-15 18:09:01 +00:00
|
|
|
$m->setOptionalUint64(MAX_UINT64_STRING);
|
2016-10-26 00:27:05 +00:00
|
|
|
if (PHP_INT_SIZE == 4) {
|
|
|
|
$this->assertSame(MAX_UINT64_STRING, $m->getOptionalUint64());
|
|
|
|
} else {
|
|
|
|
$this->assertSame(MAX_UINT64, $m->getOptionalUint64());
|
|
|
|
}
|
2016-09-15 18:09:01 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#########################################################
|
|
|
|
# Test enum field.
|
|
|
|
#########################################################
|
|
|
|
|
|
|
|
public function testEnumField()
|
|
|
|
{
|
|
|
|
$m = new TestMessage();
|
|
|
|
|
|
|
|
// Set enum.
|
|
|
|
$m->setOptionalEnum(TestEnum::ONE);
|
|
|
|
$this->assertEquals(TestEnum::ONE, $m->getOptionalEnum());
|
|
|
|
|
|
|
|
// Set integer.
|
|
|
|
$m->setOptionalEnum(1);
|
|
|
|
$this->assertEquals(TestEnum::ONE, $m->getOptionalEnum());
|
|
|
|
|
|
|
|
// Set float.
|
|
|
|
$m->setOptionalEnum(1.1);
|
|
|
|
$this->assertEquals(TestEnum::ONE, $m->getOptionalEnum());
|
|
|
|
|
|
|
|
// Set string.
|
|
|
|
$m->setOptionalEnum("1");
|
|
|
|
$this->assertEquals(TestEnum::ONE, $m->getOptionalEnum());
|
|
|
|
}
|
|
|
|
|
2017-04-20 04:20:55 +00:00
|
|
|
public function testNestedEnum()
|
|
|
|
{
|
|
|
|
$m = new TestMessage();
|
|
|
|
$m->setOptionalNestedEnum(\Foo\TestMessage_NestedEnum::ZERO);
|
|
|
|
}
|
|
|
|
|
2016-09-15 18:09:01 +00:00
|
|
|
#########################################################
|
|
|
|
# Test float field.
|
|
|
|
#########################################################
|
|
|
|
|
|
|
|
public function testFloatField()
|
|
|
|
{
|
|
|
|
$m = new TestMessage();
|
|
|
|
|
|
|
|
// Set integer.
|
|
|
|
$m->setOptionalFloat(1);
|
|
|
|
$this->assertEquals(1.0, $m->getOptionalFloat(), '', MAX_FLOAT_DIFF);
|
|
|
|
|
|
|
|
// Set float.
|
|
|
|
$m->setOptionalFloat(1.1);
|
|
|
|
$this->assertEquals(1.1, $m->getOptionalFloat(), '', MAX_FLOAT_DIFF);
|
|
|
|
|
|
|
|
// Set string.
|
|
|
|
$m->setOptionalFloat('2');
|
|
|
|
$this->assertEquals(2.0, $m->getOptionalFloat(), '', MAX_FLOAT_DIFF);
|
|
|
|
$m->setOptionalFloat('3.1');
|
|
|
|
$this->assertEquals(3.1, $m->getOptionalFloat(), '', MAX_FLOAT_DIFF);
|
|
|
|
}
|
|
|
|
|
|
|
|
#########################################################
|
|
|
|
# Test double field.
|
|
|
|
#########################################################
|
|
|
|
|
|
|
|
public function testDoubleField()
|
|
|
|
{
|
|
|
|
$m = new TestMessage();
|
|
|
|
|
|
|
|
// Set integer.
|
|
|
|
$m->setOptionalDouble(1);
|
|
|
|
$this->assertEquals(1.0, $m->getOptionalDouble(), '', MAX_FLOAT_DIFF);
|
|
|
|
|
|
|
|
// Set float.
|
|
|
|
$m->setOptionalDouble(1.1);
|
|
|
|
$this->assertEquals(1.1, $m->getOptionalDouble(), '', MAX_FLOAT_DIFF);
|
|
|
|
|
|
|
|
// Set string.
|
|
|
|
$m->setOptionalDouble('2');
|
|
|
|
$this->assertEquals(2.0, $m->getOptionalDouble(), '', MAX_FLOAT_DIFF);
|
|
|
|
$m->setOptionalDouble('3.1');
|
|
|
|
$this->assertEquals(3.1, $m->getOptionalDouble(), '', MAX_FLOAT_DIFF);
|
|
|
|
}
|
|
|
|
|
|
|
|
#########################################################
|
|
|
|
# Test bool field.
|
|
|
|
#########################################################
|
|
|
|
|
|
|
|
public function testBoolField()
|
|
|
|
{
|
|
|
|
$m = new TestMessage();
|
|
|
|
|
|
|
|
// Set bool.
|
|
|
|
$m->setOptionalBool(true);
|
|
|
|
$this->assertSame(true, $m->getOptionalBool());
|
|
|
|
|
|
|
|
// Set integer.
|
|
|
|
$m->setOptionalBool(-1);
|
|
|
|
$this->assertSame(true, $m->getOptionalBool());
|
|
|
|
|
|
|
|
// Set float.
|
|
|
|
$m->setOptionalBool(1.1);
|
|
|
|
$this->assertSame(true, $m->getOptionalBool());
|
|
|
|
|
|
|
|
// Set string.
|
|
|
|
$m->setOptionalBool('');
|
|
|
|
$this->assertSame(false, $m->getOptionalBool());
|
|
|
|
}
|
|
|
|
|
|
|
|
#########################################################
|
|
|
|
# Test string field.
|
|
|
|
#########################################################
|
|
|
|
|
|
|
|
public function testStringField()
|
|
|
|
{
|
|
|
|
$m = new TestMessage();
|
|
|
|
|
|
|
|
// Set string.
|
|
|
|
$m->setOptionalString('abc');
|
|
|
|
$this->assertSame('abc', $m->getOptionalString());
|
|
|
|
|
|
|
|
// Set integer.
|
|
|
|
$m->setOptionalString(1);
|
|
|
|
$this->assertSame('1', $m->getOptionalString());
|
|
|
|
|
|
|
|
// Set double.
|
|
|
|
$m->setOptionalString(1.1);
|
|
|
|
$this->assertSame('1.1', $m->getOptionalString());
|
|
|
|
|
|
|
|
// Set bool.
|
|
|
|
$m->setOptionalString(true);
|
|
|
|
$this->assertSame('1', $m->getOptionalString());
|
|
|
|
}
|
|
|
|
|
|
|
|
#########################################################
|
|
|
|
# Test bytes field.
|
|
|
|
#########################################################
|
|
|
|
|
|
|
|
public function testBytesField()
|
|
|
|
{
|
|
|
|
$m = new TestMessage();
|
|
|
|
|
|
|
|
// Set string.
|
|
|
|
$m->setOptionalBytes('abc');
|
|
|
|
$this->assertSame('abc', $m->getOptionalBytes());
|
|
|
|
|
|
|
|
// Set integer.
|
|
|
|
$m->setOptionalBytes(1);
|
|
|
|
$this->assertSame('1', $m->getOptionalBytes());
|
|
|
|
|
|
|
|
// Set double.
|
|
|
|
$m->setOptionalBytes(1.1);
|
|
|
|
$this->assertSame('1.1', $m->getOptionalBytes());
|
|
|
|
|
|
|
|
// Set bool.
|
|
|
|
$m->setOptionalBytes(true);
|
|
|
|
$this->assertSame('1', $m->getOptionalBytes());
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testBytesFieldInvalidUTF8Success()
|
|
|
|
{
|
|
|
|
$m = new TestMessage();
|
|
|
|
$hex = hex2bin("ff");
|
|
|
|
$m->setOptionalBytes($hex);
|
|
|
|
}
|
|
|
|
|
|
|
|
#########################################################
|
|
|
|
# Test message field.
|
|
|
|
#########################################################
|
|
|
|
|
|
|
|
public function testMessageField()
|
|
|
|
{
|
|
|
|
$m = new TestMessage();
|
|
|
|
|
|
|
|
$sub_m = new TestMessage_Sub();
|
|
|
|
$sub_m->setA(1);
|
|
|
|
$m->setOptionalMessage($sub_m);
|
|
|
|
$this->assertSame(1, $m->getOptionalMessage()->getA());
|
|
|
|
|
|
|
|
$null = null;
|
|
|
|
$m->setOptionalMessage($null);
|
|
|
|
$this->assertNull($m->getOptionalMessage());
|
|
|
|
}
|
|
|
|
|
|
|
|
#########################################################
|
|
|
|
# Test repeated field.
|
|
|
|
#########################################################
|
|
|
|
|
|
|
|
public function testRepeatedField()
|
|
|
|
{
|
|
|
|
$m = new TestMessage();
|
|
|
|
|
|
|
|
$repeated_int32 = new RepeatedField(GPBType::INT32);
|
|
|
|
$m->setRepeatedInt32($repeated_int32);
|
|
|
|
$this->assertSame($repeated_int32, $m->getRepeatedInt32());
|
|
|
|
}
|
|
|
|
|
2017-03-10 21:42:59 +00:00
|
|
|
public function testRepeatedFieldViaArray()
|
|
|
|
{
|
|
|
|
$m = new TestMessage();
|
|
|
|
|
|
|
|
$arr = array();
|
|
|
|
$m->setRepeatedInt32($arr);
|
|
|
|
$this->assertSame(0, count($m->getRepeatedInt32()));
|
|
|
|
|
|
|
|
$arr = array(1, 2.1, "3");
|
|
|
|
$m->setRepeatedInt32($arr);
|
|
|
|
$this->assertTrue($m->getRepeatedInt32() instanceof RepeatedField);
|
|
|
|
$this->assertSame("Google\Protobuf\Internal\RepeatedField",
|
|
|
|
get_class($m->getRepeatedInt32()));
|
|
|
|
$this->assertSame(3, count($m->getRepeatedInt32()));
|
|
|
|
$this->assertSame(1, $m->getRepeatedInt32()[0]);
|
|
|
|
$this->assertSame(2, $m->getRepeatedInt32()[1]);
|
|
|
|
$this->assertSame(3, $m->getRepeatedInt32()[2]);
|
|
|
|
$this->assertFalse($arr instanceof RepeatedField);
|
|
|
|
}
|
|
|
|
|
|
|
|
#########################################################
|
|
|
|
# Test map field.
|
|
|
|
#########################################################
|
|
|
|
|
|
|
|
public function testMapField()
|
|
|
|
{
|
|
|
|
$m = new TestMessage();
|
|
|
|
|
|
|
|
$map_int32_int32 = new MapField(GPBType::INT32, GPBType::INT32);
|
|
|
|
$m->setMapInt32Int32($map_int32_int32);
|
|
|
|
$this->assertSame($map_int32_int32, $m->getMapInt32Int32());
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testMapFieldViaArray()
|
|
|
|
{
|
|
|
|
$m = new TestMessage();
|
|
|
|
|
|
|
|
$dict = array();
|
|
|
|
$m->setMapInt32Int32($dict);
|
|
|
|
$this->assertSame(0, count($m->getMapInt32Int32()));
|
|
|
|
|
|
|
|
$dict = array(5 => 5, 6.1 => 6.1, "7" => "7");
|
|
|
|
$m->setMapInt32Int32($dict);
|
|
|
|
$this->assertTrue($m->getMapInt32Int32() instanceof MapField);
|
|
|
|
$this->assertSame(3, count($m->getMapInt32Int32()));
|
|
|
|
$this->assertSame(5, $m->getMapInt32Int32()[5]);
|
|
|
|
$this->assertSame(6, $m->getMapInt32Int32()[6]);
|
|
|
|
$this->assertSame(7, $m->getMapInt32Int32()[7]);
|
|
|
|
$this->assertFalse($dict instanceof MapField);
|
|
|
|
}
|
|
|
|
|
2016-09-15 18:09:01 +00:00
|
|
|
#########################################################
|
|
|
|
# Test oneof field.
|
|
|
|
#########################################################
|
|
|
|
|
|
|
|
public function testOneofField() {
|
|
|
|
$m = new TestMessage();
|
|
|
|
|
2017-01-27 21:17:54 +00:00
|
|
|
$this->assertSame("", $m->getMyOneof());
|
|
|
|
|
2016-09-15 18:09:01 +00:00
|
|
|
$m->setOneofInt32(1);
|
|
|
|
$this->assertSame(1, $m->getOneofInt32());
|
|
|
|
$this->assertSame(0.0, $m->getOneofFloat());
|
|
|
|
$this->assertSame('', $m->getOneofString());
|
|
|
|
$this->assertSame(NULL, $m->getOneofMessage());
|
2017-01-27 21:17:54 +00:00
|
|
|
$this->assertSame("oneof_int32", $m->getMyOneof());
|
2016-09-15 18:09:01 +00:00
|
|
|
|
|
|
|
$m->setOneofFloat(2.0);
|
|
|
|
$this->assertSame(0, $m->getOneofInt32());
|
|
|
|
$this->assertSame(2.0, $m->getOneofFloat());
|
|
|
|
$this->assertSame('', $m->getOneofString());
|
|
|
|
$this->assertSame(NULL, $m->getOneofMessage());
|
2017-01-27 21:17:54 +00:00
|
|
|
$this->assertSame("oneof_float", $m->getMyOneof());
|
2016-09-15 18:09:01 +00:00
|
|
|
|
|
|
|
$m->setOneofString('abc');
|
|
|
|
$this->assertSame(0, $m->getOneofInt32());
|
|
|
|
$this->assertSame(0.0, $m->getOneofFloat());
|
|
|
|
$this->assertSame('abc', $m->getOneofString());
|
|
|
|
$this->assertSame(NULL, $m->getOneofMessage());
|
2017-01-27 21:17:54 +00:00
|
|
|
$this->assertSame("oneof_string", $m->getMyOneof());
|
2016-09-15 18:09:01 +00:00
|
|
|
|
|
|
|
$sub_m = new TestMessage_Sub();
|
|
|
|
$sub_m->setA(1);
|
|
|
|
$m->setOneofMessage($sub_m);
|
|
|
|
$this->assertSame(0, $m->getOneofInt32());
|
|
|
|
$this->assertSame(0.0, $m->getOneofFloat());
|
|
|
|
$this->assertSame('', $m->getOneofString());
|
|
|
|
$this->assertSame(1, $m->getOneofMessage()->getA());
|
2017-01-27 21:17:54 +00:00
|
|
|
$this->assertSame("oneof_message", $m->getMyOneof());
|
2016-09-15 18:09:01 +00:00
|
|
|
}
|
2016-10-11 17:36:25 +00:00
|
|
|
|
2017-02-12 00:36:17 +00:00
|
|
|
#########################################################
|
|
|
|
# Test clear method.
|
|
|
|
#########################################################
|
|
|
|
|
|
|
|
public function testMessageClear()
|
|
|
|
{
|
|
|
|
$m = new TestMessage();
|
|
|
|
$this->setFields($m);
|
|
|
|
$this->expectFields($m);
|
|
|
|
$m->clear();
|
|
|
|
$this->expectEmptyFields($m);
|
|
|
|
}
|
|
|
|
|
2017-03-01 18:39:48 +00:00
|
|
|
#########################################################
|
|
|
|
# Test mergeFrom method.
|
|
|
|
#########################################################
|
|
|
|
|
|
|
|
public function testMessageMergeFrom()
|
|
|
|
{
|
|
|
|
$m = new TestMessage();
|
|
|
|
$this->setFields($m);
|
|
|
|
$this->expectFields($m);
|
|
|
|
$arr = $m->getOptionalMessage()->getB();
|
|
|
|
$arr[] = 1;
|
|
|
|
|
|
|
|
$n = new TestMessage();
|
|
|
|
|
|
|
|
// Singular
|
|
|
|
$n->setOptionalInt32(100);
|
|
|
|
$sub1 = new TestMessage_Sub();
|
|
|
|
$sub1->setA(101);
|
2017-06-20 01:15:49 +00:00
|
|
|
|
|
|
|
$b = $sub1->getB();
|
|
|
|
$b[] = 102;
|
|
|
|
$sub1->setB($b);
|
|
|
|
|
2017-03-01 18:39:48 +00:00
|
|
|
$n->setOptionalMessage($sub1);
|
|
|
|
|
|
|
|
// Repeated
|
2017-06-20 01:15:49 +00:00
|
|
|
$repeatedInt32 = $n->getRepeatedInt32();
|
|
|
|
$repeatedInt32[] = 200;
|
|
|
|
$n->setRepeatedInt32($repeatedInt32);
|
|
|
|
|
|
|
|
$repeatedString = $n->getRepeatedString();
|
|
|
|
$repeatedString[] = 'abc';
|
|
|
|
$n->setRepeatedString($repeatedString);
|
|
|
|
|
2017-03-01 18:39:48 +00:00
|
|
|
$sub2 = new TestMessage_Sub();
|
|
|
|
$sub2->setA(201);
|
2017-06-20 01:15:49 +00:00
|
|
|
$repeatedMessage = $n->getRepeatedMessage();
|
|
|
|
$repeatedMessage[] = $sub2;
|
|
|
|
$n->setRepeatedMessage($repeatedMessage);
|
2017-03-01 18:39:48 +00:00
|
|
|
|
|
|
|
// Map
|
2017-06-20 01:15:49 +00:00
|
|
|
$mapInt32Int32 = $n->getMapInt32Int32();
|
|
|
|
$mapInt32Int32[1] = 300;
|
|
|
|
$mapInt32Int32[-62] = 301;
|
|
|
|
$n->setMapInt32Int32($mapInt32Int32);
|
|
|
|
|
|
|
|
$mapStringString = $n->getMapStringString();
|
|
|
|
$mapStringString['def'] = 'def';
|
|
|
|
$n->setMapStringString($mapStringString);
|
|
|
|
|
|
|
|
$mapInt32Message = $n->getMapInt32Message();
|
|
|
|
$mapInt32Message[1] = new TestMessage_Sub();
|
|
|
|
$mapInt32Message[1]->setA(302);
|
|
|
|
$mapInt32Message[2] = new TestMessage_Sub();
|
|
|
|
$mapInt32Message[2]->setA(303);
|
|
|
|
$n->setMapInt32Message($mapInt32Message);
|
2017-03-01 18:39:48 +00:00
|
|
|
|
|
|
|
$m->mergeFrom($n);
|
|
|
|
|
|
|
|
$this->assertSame(100, $m->getOptionalInt32());
|
|
|
|
$this->assertSame(42, $m->getOptionalUint32());
|
|
|
|
$this->assertSame(101, $m->getOptionalMessage()->getA());
|
|
|
|
$this->assertSame(2, count($m->getOptionalMessage()->getB()));
|
|
|
|
$this->assertSame(1, $m->getOptionalMessage()->getB()[0]);
|
|
|
|
$this->assertSame(102, $m->getOptionalMessage()->getB()[1]);
|
|
|
|
|
|
|
|
$this->assertSame(3, count($m->getRepeatedInt32()));
|
|
|
|
$this->assertSame(200, $m->getRepeatedInt32()[2]);
|
|
|
|
$this->assertSame(2, count($m->getRepeatedUint32()));
|
|
|
|
$this->assertSame(3, count($m->getRepeatedString()));
|
|
|
|
$this->assertSame('abc', $m->getRepeatedString()[2]);
|
|
|
|
$this->assertSame(3, count($m->getRepeatedMessage()));
|
|
|
|
$this->assertSame(201, $m->getRepeatedMessage()[2]->getA());
|
|
|
|
|
|
|
|
$this->assertSame(2, count($m->getMapInt32Int32()));
|
|
|
|
$this->assertSame(300, $m->getMapInt32Int32()[1]);
|
|
|
|
$this->assertSame(301, $m->getMapInt32Int32()[-62]);
|
|
|
|
$this->assertSame(1, count($m->getMapUint32Uint32()));
|
|
|
|
$this->assertSame(2, count($m->getMapStringString()));
|
|
|
|
$this->assertSame('def', $m->getMapStringString()['def']);
|
|
|
|
|
|
|
|
$this->assertSame(2, count($m->getMapInt32Message()));
|
|
|
|
$this->assertSame(302, $m->getMapInt32Message()[1]->getA());
|
|
|
|
$this->assertSame(303, $m->getMapInt32Message()[2]->getA());
|
|
|
|
|
|
|
|
$this->assertSame("", $m->getMyOneof());
|
|
|
|
|
|
|
|
// Check sub-messages are copied by value.
|
|
|
|
$n->getOptionalMessage()->setA(-101);
|
|
|
|
$this->assertSame(101, $m->getOptionalMessage()->getA());
|
2017-06-20 01:15:49 +00:00
|
|
|
|
|
|
|
$repeatedMessage = $n->getRepeatedMessage();
|
|
|
|
$repeatedMessage[0]->setA(-201);
|
|
|
|
$n->setRepeatedMessage($repeatedMessage);
|
2017-03-01 18:39:48 +00:00
|
|
|
$this->assertSame(201, $m->getRepeatedMessage()[2]->getA());
|
2017-06-20 01:15:49 +00:00
|
|
|
|
|
|
|
$mapInt32Message = $n->getMapInt32Message();
|
|
|
|
$mapInt32Message[1]->setA(-302);
|
|
|
|
$n->setMapInt32Message($mapInt32Message);
|
|
|
|
|
2017-03-01 18:39:48 +00:00
|
|
|
$this->assertSame(302, $m->getMapInt32Message()[1]->getA());
|
|
|
|
|
|
|
|
// Test merge oneof.
|
|
|
|
$m = new TestMessage();
|
|
|
|
|
|
|
|
$n = new TestMessage();
|
|
|
|
$n->setOneofInt32(1);
|
|
|
|
$m->mergeFrom($n);
|
|
|
|
$this->assertSame(1, $m->getOneofInt32());
|
|
|
|
|
|
|
|
$sub = new TestMessage_Sub();
|
|
|
|
$n->setOneofMessage($sub);
|
|
|
|
$n->getOneofMessage()->setA(400);
|
|
|
|
$m->mergeFrom($n);
|
|
|
|
$this->assertSame(400, $m->getOneofMessage()->getA());
|
|
|
|
$n->getOneofMessage()->setA(-400);
|
|
|
|
$this->assertSame(400, $m->getOneofMessage()->getA());
|
|
|
|
|
|
|
|
// Test all fields
|
|
|
|
$m = new TestMessage();
|
|
|
|
$n = new TestMessage();
|
|
|
|
$this->setFields($m);
|
|
|
|
$n->mergeFrom($m);
|
|
|
|
$this->expectFields($n);
|
|
|
|
}
|
|
|
|
|
2016-10-11 17:36:25 +00:00
|
|
|
#########################################################
|
2017-01-31 17:17:32 +00:00
|
|
|
# Test message/enum without namespace.
|
2016-10-11 17:36:25 +00:00
|
|
|
#########################################################
|
|
|
|
|
2017-02-12 00:36:17 +00:00
|
|
|
public function testMessageWithoutNamespace()
|
|
|
|
{
|
2017-04-20 03:03:34 +00:00
|
|
|
$m = new TestMessage();
|
2017-04-24 19:40:37 +00:00
|
|
|
$sub = new NoNameSpaceMessage();
|
|
|
|
$m->setOptionalNoNamespaceMessage($sub);
|
2017-06-20 01:15:49 +00:00
|
|
|
$repeatedNoNamespaceMessage = $m->getRepeatedNoNamespaceMessage();
|
|
|
|
$repeatedNoNamespaceMessage[] = new NoNameSpaceMessage();
|
|
|
|
$m->setRepeatedNoNamespaceMessage($repeatedNoNamespaceMessage);
|
2017-04-20 04:20:55 +00:00
|
|
|
|
|
|
|
$n = new NoNamespaceMessage();
|
|
|
|
$n->setB(NoNamespaceMessage_NestedEnum::ZERO);
|
2017-01-31 17:17:32 +00:00
|
|
|
}
|
|
|
|
|
2017-02-12 00:36:17 +00:00
|
|
|
public function testEnumWithoutNamespace()
|
|
|
|
{
|
2017-04-20 03:03:34 +00:00
|
|
|
$m = new TestMessage();
|
|
|
|
$m->setOptionalNoNamespaceEnum(NoNameSpaceEnum::VALUE_A);
|
2017-06-20 01:15:49 +00:00
|
|
|
$repeatedNoNamespaceEnum = $m->getRepeatedNoNamespaceEnum();
|
|
|
|
$repeatedNoNamespaceEnum[] = NoNameSpaceEnum::VALUE_A;
|
|
|
|
$m->setRepeatedNoNamespaceEnum($repeatedNoNamespaceEnum);
|
2016-10-11 17:36:25 +00:00
|
|
|
}
|
2017-03-17 18:08:06 +00:00
|
|
|
|
|
|
|
#########################################################
|
|
|
|
# Test message with given prefix.
|
|
|
|
#########################################################
|
|
|
|
|
|
|
|
public function testPrefixMessage()
|
|
|
|
{
|
|
|
|
$m = new TestIncludePrefixMessage();
|
|
|
|
$n = new PrefixTestPrefix();
|
|
|
|
$n->setA(1);
|
|
|
|
$m->setPrefixMessage($n);
|
|
|
|
$this->assertSame(1, $m->getPrefixMessage()->getA());
|
|
|
|
}
|
2017-04-20 08:19:03 +00:00
|
|
|
|
2017-06-05 07:10:18 +00:00
|
|
|
#########################################################
|
|
|
|
# Test message with given namespace.
|
|
|
|
#########################################################
|
|
|
|
|
|
|
|
public function testNamespaceMessage()
|
|
|
|
{
|
|
|
|
$m = new TestIncludeNamespaceMessage();
|
|
|
|
|
|
|
|
$n = new TestNamespace();
|
|
|
|
$n->setA(1);
|
|
|
|
$m->setNamespaceMessage($n);
|
|
|
|
$this->assertSame(1, $m->getNamespaceMessage()->getA());
|
|
|
|
|
|
|
|
$n = new TestEmptyNamespace();
|
|
|
|
$n->setA(1);
|
|
|
|
$m->setEmptyNamespaceMessage($n);
|
|
|
|
$this->assertSame(1, $m->getEmptyNamespaceMessage()->getA());
|
|
|
|
}
|
|
|
|
|
2017-04-20 08:19:03 +00:00
|
|
|
#########################################################
|
|
|
|
# Test prefix for reserved words.
|
|
|
|
#########################################################
|
|
|
|
|
|
|
|
public function testPrefixForReservedWords()
|
|
|
|
{
|
|
|
|
$m = new \Foo\TestMessage_Empty();
|
|
|
|
$m = new \Foo\PBEmpty();
|
|
|
|
$m = new \PrefixEmpty();
|
2017-05-29 22:30:47 +00:00
|
|
|
$m = new \Foo\PBARRAY();
|
2017-09-08 22:11:49 +00:00
|
|
|
|
|
|
|
$m = new \Lower\PBabstract();
|
|
|
|
$m = new \Lower\PBand();
|
|
|
|
$m = new \Lower\PBarray();
|
|
|
|
$m = new \Lower\PBas();
|
|
|
|
$m = new \Lower\PBbreak();
|
|
|
|
$m = new \Lower\PBcallable();
|
|
|
|
$m = new \Lower\PBcase();
|
|
|
|
$m = new \Lower\PBcatch();
|
|
|
|
$m = new \Lower\PBclass();
|
|
|
|
$m = new \Lower\PBclone();
|
|
|
|
$m = new \Lower\PBconst();
|
|
|
|
$m = new \Lower\PBcontinue();
|
|
|
|
$m = new \Lower\PBdeclare();
|
|
|
|
$m = new \Lower\PBdefault();
|
|
|
|
$m = new \Lower\PBdie();
|
|
|
|
$m = new \Lower\PBdo();
|
|
|
|
$m = new \Lower\PBecho();
|
|
|
|
$m = new \Lower\PBelse();
|
|
|
|
$m = new \Lower\PBelseif();
|
|
|
|
$m = new \Lower\PBempty();
|
|
|
|
$m = new \Lower\PBenddeclare();
|
|
|
|
$m = new \Lower\PBendfor();
|
|
|
|
$m = new \Lower\PBendforeach();
|
|
|
|
$m = new \Lower\PBendif();
|
|
|
|
$m = new \Lower\PBendswitch();
|
|
|
|
$m = new \Lower\PBendwhile();
|
|
|
|
$m = new \Lower\PBeval();
|
|
|
|
$m = new \Lower\PBexit();
|
|
|
|
$m = new \Lower\PBextends();
|
|
|
|
$m = new \Lower\PBfinal();
|
|
|
|
$m = new \Lower\PBfor();
|
|
|
|
$m = new \Lower\PBforeach();
|
|
|
|
$m = new \Lower\PBfunction();
|
|
|
|
$m = new \Lower\PBglobal();
|
|
|
|
$m = new \Lower\PBgoto();
|
|
|
|
$m = new \Lower\PBif();
|
|
|
|
$m = new \Lower\PBimplements();
|
|
|
|
$m = new \Lower\PBinclude();
|
|
|
|
$m = new \Lower\PBinclude_once();
|
|
|
|
$m = new \Lower\PBinstanceof();
|
|
|
|
$m = new \Lower\PBinsteadof();
|
|
|
|
$m = new \Lower\PBinterface();
|
|
|
|
$m = new \Lower\PBisset();
|
|
|
|
$m = new \Lower\PBlist();
|
|
|
|
$m = new \Lower\PBnamespace();
|
|
|
|
$m = new \Lower\PBnew();
|
|
|
|
$m = new \Lower\PBor();
|
|
|
|
$m = new \Lower\PBprint();
|
|
|
|
$m = new \Lower\PBprivate();
|
|
|
|
$m = new \Lower\PBprotected();
|
|
|
|
$m = new \Lower\PBpublic();
|
|
|
|
$m = new \Lower\PBrequire();
|
|
|
|
$m = new \Lower\PBrequire_once();
|
|
|
|
$m = new \Lower\PBreturn();
|
|
|
|
$m = new \Lower\PBstatic();
|
|
|
|
$m = new \Lower\PBswitch();
|
|
|
|
$m = new \Lower\PBthrow();
|
|
|
|
$m = new \Lower\PBtrait();
|
|
|
|
$m = new \Lower\PBtry();
|
|
|
|
$m = new \Lower\PBunset();
|
|
|
|
$m = new \Lower\PBuse();
|
|
|
|
$m = new \Lower\PBvar();
|
|
|
|
$m = new \Lower\PBwhile();
|
|
|
|
$m = new \Lower\PBxor();
|
|
|
|
$m = new \Lower\PBint();
|
|
|
|
$m = new \Lower\PBfloat();
|
|
|
|
$m = new \Lower\PBbool();
|
|
|
|
$m = new \Lower\PBstring();
|
|
|
|
$m = new \Lower\PBtrue();
|
|
|
|
$m = new \Lower\PBfalse();
|
|
|
|
$m = new \Lower\PBnull();
|
|
|
|
$m = new \Lower\PBvoid();
|
|
|
|
$m = new \Lower\PBiterable();
|
|
|
|
|
|
|
|
$m = new \Upper\PBABSTRACT();
|
|
|
|
$m = new \Upper\PBAND();
|
|
|
|
$m = new \Upper\PBARRAY();
|
|
|
|
$m = new \Upper\PBAS();
|
|
|
|
$m = new \Upper\PBBREAK();
|
|
|
|
$m = new \Upper\PBCALLABLE();
|
|
|
|
$m = new \Upper\PBCASE();
|
|
|
|
$m = new \Upper\PBCATCH();
|
|
|
|
$m = new \Upper\PBCLASS();
|
|
|
|
$m = new \Upper\PBCLONE();
|
|
|
|
$m = new \Upper\PBCONST();
|
|
|
|
$m = new \Upper\PBCONTINUE();
|
|
|
|
$m = new \Upper\PBDECLARE();
|
|
|
|
$m = new \Upper\PBDEFAULT();
|
|
|
|
$m = new \Upper\PBDIE();
|
|
|
|
$m = new \Upper\PBDO();
|
|
|
|
$m = new \Upper\PBECHO();
|
|
|
|
$m = new \Upper\PBELSE();
|
|
|
|
$m = new \Upper\PBELSEIF();
|
|
|
|
$m = new \Upper\PBEMPTY();
|
|
|
|
$m = new \Upper\PBENDDECLARE();
|
|
|
|
$m = new \Upper\PBENDFOR();
|
|
|
|
$m = new \Upper\PBENDFOREACH();
|
|
|
|
$m = new \Upper\PBENDIF();
|
|
|
|
$m = new \Upper\PBENDSWITCH();
|
|
|
|
$m = new \Upper\PBENDWHILE();
|
|
|
|
$m = new \Upper\PBEVAL();
|
|
|
|
$m = new \Upper\PBEXIT();
|
|
|
|
$m = new \Upper\PBEXTENDS();
|
|
|
|
$m = new \Upper\PBFINAL();
|
|
|
|
$m = new \Upper\PBFOR();
|
|
|
|
$m = new \Upper\PBFOREACH();
|
|
|
|
$m = new \Upper\PBFUNCTION();
|
|
|
|
$m = new \Upper\PBGLOBAL();
|
|
|
|
$m = new \Upper\PBGOTO();
|
|
|
|
$m = new \Upper\PBIF();
|
|
|
|
$m = new \Upper\PBIMPLEMENTS();
|
|
|
|
$m = new \Upper\PBINCLUDE();
|
|
|
|
$m = new \Upper\PBINCLUDE_ONCE();
|
|
|
|
$m = new \Upper\PBINSTANCEOF();
|
|
|
|
$m = new \Upper\PBINSTEADOF();
|
|
|
|
$m = new \Upper\PBINTERFACE();
|
|
|
|
$m = new \Upper\PBISSET();
|
|
|
|
$m = new \Upper\PBLIST();
|
|
|
|
$m = new \Upper\PBNAMESPACE();
|
|
|
|
$m = new \Upper\PBNEW();
|
|
|
|
$m = new \Upper\PBOR();
|
|
|
|
$m = new \Upper\PBPRINT();
|
|
|
|
$m = new \Upper\PBPRIVATE();
|
|
|
|
$m = new \Upper\PBPROTECTED();
|
|
|
|
$m = new \Upper\PBPUBLIC();
|
|
|
|
$m = new \Upper\PBREQUIRE();
|
|
|
|
$m = new \Upper\PBREQUIRE_ONCE();
|
|
|
|
$m = new \Upper\PBRETURN();
|
|
|
|
$m = new \Upper\PBSTATIC();
|
|
|
|
$m = new \Upper\PBSWITCH();
|
|
|
|
$m = new \Upper\PBTHROW();
|
|
|
|
$m = new \Upper\PBTRAIT();
|
|
|
|
$m = new \Upper\PBTRY();
|
|
|
|
$m = new \Upper\PBUNSET();
|
|
|
|
$m = new \Upper\PBUSE();
|
|
|
|
$m = new \Upper\PBVAR();
|
|
|
|
$m = new \Upper\PBWHILE();
|
|
|
|
$m = new \Upper\PBXOR();
|
|
|
|
$m = new \Upper\PBINT();
|
|
|
|
$m = new \Upper\PBFLOAT();
|
|
|
|
$m = new \Upper\PBBOOL();
|
|
|
|
$m = new \Upper\PBSTRING();
|
|
|
|
$m = new \Upper\PBTRUE();
|
|
|
|
$m = new \Upper\PBFALSE();
|
|
|
|
$m = new \Upper\PBNULL();
|
|
|
|
$m = new \Upper\PBVOID();
|
|
|
|
$m = new \Upper\PBITERABLE();
|
|
|
|
|
|
|
|
$m = \Lower_enum\NotAllowed::PBabstract;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBand;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBarray;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBas;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBbreak;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBcallable;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBcase;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBcatch;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBclass;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBclone;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBconst;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBcontinue;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBdeclare;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBdefault;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBdie;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBdo;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBecho;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBelse;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBelseif;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBempty;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBenddeclare;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBendfor;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBendforeach;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBendif;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBendswitch;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBendwhile;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBeval;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBexit;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBextends;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBfinal;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBfor;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBforeach;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBfunction;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBglobal;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBgoto;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBif;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBimplements;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBinclude;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBinclude_once;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBinstanceof;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBinsteadof;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBinterface;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBisset;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBlist;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBnamespace;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBnew;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBor;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBprint;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBprivate;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBprotected;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBpublic;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBrequire;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBrequire_once;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBreturn;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBstatic;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBswitch;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBthrow;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBtrait;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBtry;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBunset;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBuse;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBvar;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBwhile;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBxor;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBint;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBfloat;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBbool;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBstring;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBtrue;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBfalse;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBnull;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBvoid;
|
|
|
|
$m = \Lower_enum\NotAllowed::PBiterable;
|
2017-04-20 08:19:03 +00:00
|
|
|
}
|
2017-05-29 17:39:14 +00:00
|
|
|
|
|
|
|
#########################################################
|
|
|
|
# Test fluent setters.
|
|
|
|
#########################################################
|
|
|
|
|
|
|
|
public function testFluentSetters()
|
|
|
|
{
|
|
|
|
$m = (new TestMessage())
|
|
|
|
->setOptionalInt32(1)
|
2017-05-29 22:30:47 +00:00
|
|
|
->setOptionalUInt32(2);
|
2017-05-29 17:39:14 +00:00
|
|
|
$this->assertSame(1, $m->getOptionalInt32());
|
2017-05-29 22:30:47 +00:00
|
|
|
$this->assertSame(2, $m->getOptionalUInt32());
|
2017-05-29 17:39:14 +00:00
|
|
|
}
|
2017-08-04 23:35:49 +00:00
|
|
|
|
|
|
|
#########################################################
|
|
|
|
# Test Reverse Field Order.
|
|
|
|
#########################################################
|
|
|
|
|
|
|
|
public function testReverseFieldOrder()
|
|
|
|
{
|
|
|
|
$m = new TestReverseFieldOrder();
|
|
|
|
$m->setB("abc");
|
|
|
|
$this->assertSame("abc", $m->getB());
|
|
|
|
$this->assertNotSame("abc", $m->getA());
|
|
|
|
}
|
2017-08-21 20:39:15 +00:00
|
|
|
|
|
|
|
#########################################################
|
|
|
|
# Test Reverse Field Order.
|
|
|
|
#########################################################
|
|
|
|
|
|
|
|
public function testLowerCase()
|
|
|
|
{
|
|
|
|
$m = new testLowerCaseMessage();
|
|
|
|
$n = testLowerCaseEnum::VALUE;
|
|
|
|
}
|
2016-09-15 18:09:01 +00:00
|
|
|
}
|