1
0
mirror of https://github.com/danog/PHP-Parser.git synced 2025-01-10 15:08:36 +01:00
PHP-Parser/test/PhpParser/Builder/ParamTest.php

201 lines
6.2 KiB
PHP
Raw Normal View History

<?php declare(strict_types=1);
2012-03-11 00:06:02 +01:00
namespace PhpParser\Builder;
use PhpParser\Node;
use PhpParser\Node\Expr;
use PhpParser\Node\Scalar;
class ParamTest extends \PHPUnit\Framework\TestCase
2012-03-11 00:06:02 +01:00
{
public function createParamBuilder($name) {
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,
new Expr\ConstFetch(new Node\Name('null'))
2017-08-13 14:35:03 +02:00
],
[
2012-03-11 00:06:02 +01:00
true,
new Expr\ConstFetch(new Node\Name('true'))
2017-08-13 14:35:03 +02:00
],
[
2012-03-11 00:06:02 +01:00
false,
new Expr\ConstFetch(new Node\Name('false'))
2017-08-13 14:35:03 +02:00
],
[
2012-03-11 00:06:02 +01:00
31415,
new Scalar\LNumber(31415)
2017-08-13 14:35:03 +02:00
],
[
2012-03-11 00:06:02 +01:00
3.1415,
new Scalar\DNumber(3.1415)
2017-08-13 14:35:03 +02:00
],
[
2012-03-11 00:06:02 +01:00
'Hallo World',
new Scalar\String_('Hallo World')
2017-08-13 14:35:03 +02:00
],
[
[1, 2, 3],
new Expr\Array_([
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_([
new Expr\ArrayItem(
new Scalar\String_('bar'),
new Scalar\String_('foo')
),
new Expr\ArrayItem(
new Scalar\String_('foo'),
new Scalar\String_('bar')
),
2017-08-13 14:35:03 +02: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
}
/**
* @dataProvider provideTestTypes
* @dataProvider provideTestNullableTypes
* @dataProvider provideTestUnionTypes
*/
public function testTypes($typeHint, $expectedType) {
2012-03-11 00:06:02 +01:00
$node = $this->createParamBuilder('test')
->setTypeHint($typeHint)
2012-03-11 00:06:02 +01:00
->getNode()
;
$type = $node->type;
2012-03-11 00:06:02 +01: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
$this->assertInstanceOf(get_class($expectedType), $type);
$this->assertEquals($expectedType, $type);
}
2012-03-11 00:06:02 +01: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')],
['Some\Class', new Node\Name('Some\Class')],
['\Foo', new Node\Name\FullyQualified('Foo')],
['self', new Node\Name('self')],
[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'))],
[
new Node\NullableType(new Node\Identifier('int')),
new Node\NullableType(new Node\Identifier('int'))
2017-08-13 14:35:03 +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
],
];
}
2012-03-11 00:06:02 +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')
]),
],
];
}
public function testVoidTypeError() {
$this->expectException(\LogicException::class);
$this->expectExceptionMessage('Parameter type cannot be void');
$this->createParamBuilder('test')->setType('void');
}
2012-03-11 00:06:02 +01:00
public function testInvalidTypeError() {
$this->expectException(\LogicException::class);
$this->expectExceptionMessage('Type must be a string, or an instance of Name, Identifier, NullableType or UnionType');
$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(
new Node\Param(new Expr\Variable('test'), null, null, false, true),
2017-04-16 12:45:18 +02:00
$node
);
}
}