2017-11-02 18:56:01 +01:00
|
|
|
<?php declare(strict_types=1);
|
2012-03-11 00:06:02 +01:00
|
|
|
|
2014-02-06 14:44:16 +01:00
|
|
|
namespace PhpParser\Builder;
|
|
|
|
|
|
|
|
use PhpParser\Node;
|
2021-06-16 17:47:22 +02:00
|
|
|
use PhpParser\Node\Arg;
|
|
|
|
use PhpParser\Node\Attribute;
|
|
|
|
use PhpParser\Node\AttributeGroup;
|
2014-02-06 14:44:16 +01:00
|
|
|
use PhpParser\Node\Expr;
|
2021-06-16 17:47:22 +02:00
|
|
|
use PhpParser\Node\Identifier;
|
|
|
|
use PhpParser\Node\Name;
|
2014-02-06 14:44:16 +01:00
|
|
|
use PhpParser\Node\Scalar;
|
2021-06-16 17:47:22 +02:00
|
|
|
use PhpParser\Node\Scalar\LNumber;
|
2014-02-06 14:44:16 +01:00
|
|
|
|
2019-01-19 11:18:00 +01:00
|
|
|
class ParamTest extends \PHPUnit\Framework\TestCase
|
2012-03-11 00:06:02 +01:00
|
|
|
{
|
|
|
|
public function createParamBuilder($name) {
|
2014-02-06 14:44:16 +01:00
|
|
|
return new Param($name);
|
2012-03-11 00:06:02 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @dataProvider provideTestDefaultValues
|
|
|
|
*/
|
|
|
|
public function testDefaultValues($value, $expectedValueNode) {
|
|
|
|
$node = $this->createParamBuilder('test')
|
|
|
|
->setDefault($value)
|
|
|
|
->getNode()
|
|
|
|
;
|
|
|
|
|
|
|
|
$this->assertEquals($expectedValueNode, $node->default);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function provideTestDefaultValues() {
|
2017-08-13 14:35:03 +02:00
|
|
|
return [
|
|
|
|
[
|
2012-03-11 00:06:02 +01:00
|
|
|
null,
|
2014-02-06 14:44:16 +01:00
|
|
|
new Expr\ConstFetch(new Node\Name('null'))
|
2017-08-13 14:35:03 +02:00
|
|
|
],
|
|
|
|
[
|
2012-03-11 00:06:02 +01:00
|
|
|
true,
|
2014-02-06 14:44:16 +01:00
|
|
|
new Expr\ConstFetch(new Node\Name('true'))
|
2017-08-13 14:35:03 +02:00
|
|
|
],
|
|
|
|
[
|
2012-03-11 00:06:02 +01:00
|
|
|
false,
|
2014-02-06 14:44:16 +01:00
|
|
|
new Expr\ConstFetch(new Node\Name('false'))
|
2017-08-13 14:35:03 +02:00
|
|
|
],
|
|
|
|
[
|
2012-03-11 00:06:02 +01:00
|
|
|
31415,
|
2014-02-06 14:44:16 +01:00
|
|
|
new Scalar\LNumber(31415)
|
2017-08-13 14:35:03 +02:00
|
|
|
],
|
|
|
|
[
|
2012-03-11 00:06:02 +01:00
|
|
|
3.1415,
|
2014-02-06 14:44:16 +01:00
|
|
|
new Scalar\DNumber(3.1415)
|
2017-08-13 14:35:03 +02:00
|
|
|
],
|
|
|
|
[
|
2012-03-11 00:06:02 +01:00
|
|
|
'Hallo World',
|
2015-03-20 21:47:20 +01:00
|
|
|
new Scalar\String_('Hallo World')
|
2017-08-13 14:35:03 +02:00
|
|
|
],
|
|
|
|
[
|
|
|
|
[1, 2, 3],
|
|
|
|
new Expr\Array_([
|
2014-02-06 14:44:16 +01:00
|
|
|
new Expr\ArrayItem(new Scalar\LNumber(1)),
|
|
|
|
new Expr\ArrayItem(new Scalar\LNumber(2)),
|
|
|
|
new Expr\ArrayItem(new Scalar\LNumber(3)),
|
2017-08-13 14:35:03 +02:00
|
|
|
])
|
|
|
|
],
|
|
|
|
[
|
|
|
|
['foo' => 'bar', 'bar' => 'foo'],
|
|
|
|
new Expr\Array_([
|
2014-02-06 14:44:16 +01:00
|
|
|
new Expr\ArrayItem(
|
2015-03-20 21:47:20 +01:00
|
|
|
new Scalar\String_('bar'),
|
|
|
|
new Scalar\String_('foo')
|
2012-03-11 08:53:04 +01:00
|
|
|
),
|
2014-02-06 14:44:16 +01:00
|
|
|
new Expr\ArrayItem(
|
2015-03-20 21:47:20 +01:00
|
|
|
new Scalar\String_('foo'),
|
|
|
|
new Scalar\String_('bar')
|
2012-03-11 08:53:04 +01:00
|
|
|
),
|
2017-08-13 14:35:03 +02:00
|
|
|
])
|
|
|
|
],
|
|
|
|
[
|
2014-02-06 14:44:16 +01:00
|
|
|
new Scalar\MagicConst\Dir,
|
|
|
|
new Scalar\MagicConst\Dir
|
2017-08-13 14:35:03 +02:00
|
|
|
]
|
|
|
|
];
|
2012-03-11 00:06:02 +01:00
|
|
|
}
|
|
|
|
|
2016-09-16 13:52:47 +02:00
|
|
|
/**
|
2018-07-22 21:41:21 +02:00
|
|
|
* @dataProvider provideTestTypes
|
2019-11-17 01:42:21 +01:00
|
|
|
* @dataProvider provideTestNullableTypes
|
|
|
|
* @dataProvider provideTestUnionTypes
|
2016-09-16 13:52:47 +02:00
|
|
|
*/
|
2018-07-22 21:41:21 +02:00
|
|
|
public function testTypes($typeHint, $expectedType) {
|
2012-03-11 00:06:02 +01:00
|
|
|
$node = $this->createParamBuilder('test')
|
2016-09-16 13:52:47 +02:00
|
|
|
->setTypeHint($typeHint)
|
2012-03-11 00:06:02 +01:00
|
|
|
->getNode()
|
|
|
|
;
|
2016-09-16 13:52:47 +02:00
|
|
|
$type = $node->type;
|
2012-03-11 00:06:02 +01:00
|
|
|
|
2016-09-16 13:52:47 +02:00
|
|
|
/* Manually implement comparison to avoid __toString stupidity */
|
|
|
|
if ($expectedType instanceof Node\NullableType) {
|
|
|
|
$this->assertInstanceOf(get_class($expectedType), $type);
|
|
|
|
$expectedType = $expectedType->type;
|
|
|
|
$type = $type->type;
|
|
|
|
}
|
2012-03-11 00:06:02 +01:00
|
|
|
|
2017-04-28 19:09:39 +02:00
|
|
|
$this->assertInstanceOf(get_class($expectedType), $type);
|
|
|
|
$this->assertEquals($expectedType, $type);
|
2016-09-16 13:52:47 +02:00
|
|
|
}
|
2012-03-11 00:06:02 +01:00
|
|
|
|
2018-07-22 21:41:21 +02:00
|
|
|
public function provideTestTypes() {
|
2017-08-13 14:35:03 +02:00
|
|
|
return [
|
|
|
|
['array', new Node\Identifier('array')],
|
|
|
|
['callable', new Node\Identifier('callable')],
|
|
|
|
['bool', new Node\Identifier('bool')],
|
|
|
|
['int', new Node\Identifier('int')],
|
|
|
|
['float', new Node\Identifier('float')],
|
|
|
|
['string', new Node\Identifier('string')],
|
|
|
|
['iterable', new Node\Identifier('iterable')],
|
|
|
|
['object', new Node\Identifier('object')],
|
|
|
|
['Array', new Node\Identifier('array')],
|
|
|
|
['CALLABLE', new Node\Identifier('callable')],
|
2020-05-28 22:50:32 +02:00
|
|
|
['mixed', new Node\Identifier('mixed')],
|
2017-08-13 14:35:03 +02:00
|
|
|
['Some\Class', new Node\Name('Some\Class')],
|
|
|
|
['\Foo', new Node\Name\FullyQualified('Foo')],
|
|
|
|
['self', new Node\Name('self')],
|
2019-11-17 01:42:21 +01:00
|
|
|
[new Node\Name('Some\Class'), new Node\Name('Some\Class')],
|
|
|
|
];
|
|
|
|
}
|
|
|
|
|
|
|
|
public function provideTestNullableTypes() {
|
|
|
|
return [
|
2017-08-13 14:35:03 +02:00
|
|
|
['?array', new Node\NullableType(new Node\Identifier('array'))],
|
|
|
|
['?Some\Class', new Node\NullableType(new Node\Name('Some\Class'))],
|
|
|
|
[
|
2017-04-28 19:09:39 +02:00
|
|
|
new Node\NullableType(new Node\Identifier('int')),
|
|
|
|
new Node\NullableType(new Node\Identifier('int'))
|
2017-08-13 14:35:03 +02:00
|
|
|
],
|
|
|
|
[
|
2016-09-16 13:52:47 +02:00
|
|
|
new Node\NullableType(new Node\Name('Some\Class')),
|
|
|
|
new Node\NullableType(new Node\Name('Some\Class'))
|
2017-08-13 14:35:03 +02:00
|
|
|
],
|
|
|
|
];
|
2016-09-16 13:52:47 +02:00
|
|
|
}
|
2012-03-11 00:06:02 +01:00
|
|
|
|
2019-11-17 01:42:21 +01:00
|
|
|
public function provideTestUnionTypes() {
|
|
|
|
return [
|
|
|
|
[
|
|
|
|
new Node\UnionType([
|
|
|
|
new Node\Name('Some\Class'),
|
|
|
|
new Node\Identifier('array'),
|
|
|
|
]),
|
|
|
|
new Node\UnionType([
|
|
|
|
new Node\Name('Some\Class'),
|
|
|
|
new Node\Identifier('array'),
|
|
|
|
]),
|
|
|
|
],
|
|
|
|
[
|
|
|
|
new Node\UnionType([
|
|
|
|
new Node\Identifier('self'),
|
|
|
|
new Node\Identifier('array'),
|
|
|
|
new Node\Name\FullyQualified('Foo')
|
|
|
|
]),
|
|
|
|
new Node\UnionType([
|
|
|
|
new Node\Identifier('self'),
|
|
|
|
new Node\Identifier('array'),
|
|
|
|
new Node\Name\FullyQualified('Foo')
|
|
|
|
]),
|
|
|
|
],
|
|
|
|
];
|
|
|
|
}
|
|
|
|
|
2016-09-16 13:52:47 +02:00
|
|
|
public function testVoidTypeError() {
|
2018-09-22 10:43:54 +02:00
|
|
|
$this->expectException(\LogicException::class);
|
|
|
|
$this->expectExceptionMessage('Parameter type cannot be void');
|
2018-07-22 21:41:21 +02:00
|
|
|
$this->createParamBuilder('test')->setType('void');
|
2016-09-16 13:52:47 +02:00
|
|
|
}
|
2012-03-11 00:06:02 +01:00
|
|
|
|
2016-09-16 13:52:47 +02:00
|
|
|
public function testInvalidTypeError() {
|
2018-09-22 10:43:54 +02:00
|
|
|
$this->expectException(\LogicException::class);
|
2021-09-02 18:35:05 +02:00
|
|
|
$this->expectExceptionMessage('Type must be a string, or an instance of Name, Identifier or ComplexType');
|
2018-07-22 21:41:21 +02:00
|
|
|
$this->createParamBuilder('test')->setType(new \stdClass);
|
2012-03-11 00:06:02 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testByRef() {
|
|
|
|
$node = $this->createParamBuilder('test')
|
|
|
|
->makeByRef()
|
|
|
|
->getNode()
|
|
|
|
;
|
|
|
|
|
|
|
|
$this->assertEquals(
|
2017-01-19 23:32:49 +01:00
|
|
|
new Node\Param(new Expr\Variable('test'), null, null, true),
|
2012-03-11 00:06:02 +01:00
|
|
|
$node
|
|
|
|
);
|
|
|
|
}
|
2017-04-16 12:45:18 +02:00
|
|
|
|
|
|
|
public function testVariadic() {
|
|
|
|
$node = $this->createParamBuilder('test')
|
|
|
|
->makeVariadic()
|
|
|
|
->getNode()
|
|
|
|
;
|
|
|
|
|
|
|
|
$this->assertEquals(
|
2017-04-19 11:17:52 +02:00
|
|
|
new Node\Param(new Expr\Variable('test'), null, null, false, true),
|
2017-04-16 12:45:18 +02:00
|
|
|
$node
|
|
|
|
);
|
|
|
|
}
|
2021-06-16 17:47:22 +02:00
|
|
|
|
|
|
|
public function testAddAttribute() {
|
|
|
|
$attribute = new Attribute(
|
|
|
|
new Name('Attr'),
|
|
|
|
[new Arg(new LNumber(1), false, false, [], new Identifier('name'))]
|
|
|
|
);
|
|
|
|
$attributeGroup = new AttributeGroup([$attribute]);
|
|
|
|
|
|
|
|
$node = $this->createParamBuilder('attributeGroup')
|
|
|
|
->addAttribute($attributeGroup)
|
|
|
|
->getNode();
|
|
|
|
|
|
|
|
$this->assertEquals(
|
|
|
|
new Node\Param(new Expr\Variable('attributeGroup'), null, null, false, false, [], 0, [$attributeGroup]),
|
|
|
|
$node
|
|
|
|
);
|
|
|
|
}
|
2015-03-20 21:47:20 +01:00
|
|
|
}
|