mirror of
https://github.com/danog/PHP-Parser.git
synced 2025-01-22 22:01:18 +01:00
122 lines
3.3 KiB
PHP
122 lines
3.3 KiB
PHP
<?php
|
|
|
|
namespace PhpParser\Builder;
|
|
|
|
use PhpParser\Comment;
|
|
use PhpParser\Node;
|
|
use PhpParser\Node\Expr\Print_;
|
|
use PhpParser\Node\Expr\Variable;
|
|
use PhpParser\Node\Scalar\String_;
|
|
use PhpParser\Node\Stmt;
|
|
use PHPUnit\Framework\TestCase;
|
|
|
|
class FunctionTest extends TestCase
|
|
{
|
|
public function createFunctionBuilder($name) {
|
|
return new Function_($name);
|
|
}
|
|
|
|
public function testReturnByRef() {
|
|
$node = $this->createFunctionBuilder('test')
|
|
->makeReturnByRef()
|
|
->getNode()
|
|
;
|
|
|
|
$this->assertEquals(
|
|
new Stmt\Function_('test', array(
|
|
'byRef' => true
|
|
)),
|
|
$node
|
|
);
|
|
}
|
|
|
|
public function testParams() {
|
|
$param1 = new Node\Param(new Variable('test1'));
|
|
$param2 = new Node\Param(new Variable('test2'));
|
|
$param3 = new Node\Param(new Variable('test3'));
|
|
|
|
$node = $this->createFunctionBuilder('test')
|
|
->addParam($param1)
|
|
->addParams(array($param2, $param3))
|
|
->getNode()
|
|
;
|
|
|
|
$this->assertEquals(
|
|
new Stmt\Function_('test', array(
|
|
'params' => array($param1, $param2, $param3)
|
|
)),
|
|
$node
|
|
);
|
|
}
|
|
|
|
public function testStmts() {
|
|
$stmt1 = new Print_(new String_('test1'));
|
|
$stmt2 = new Print_(new String_('test2'));
|
|
$stmt3 = new Print_(new String_('test3'));
|
|
|
|
$node = $this->createFunctionBuilder('test')
|
|
->addStmt($stmt1)
|
|
->addStmts(array($stmt2, $stmt3))
|
|
->getNode()
|
|
;
|
|
|
|
$this->assertEquals(
|
|
new Stmt\Function_('test', array(
|
|
'stmts' => array(
|
|
new Stmt\Expression($stmt1),
|
|
new Stmt\Expression($stmt2),
|
|
new Stmt\Expression($stmt3),
|
|
)
|
|
)),
|
|
$node
|
|
);
|
|
}
|
|
|
|
public function testDocComment() {
|
|
$node = $this->createFunctionBuilder('test')
|
|
->setDocComment('/** Test */')
|
|
->getNode();
|
|
|
|
$this->assertEquals(new Stmt\Function_('test', array(), array(
|
|
'comments' => array(new Comment\Doc('/** Test */'))
|
|
)), $node);
|
|
}
|
|
|
|
public function testReturnType() {
|
|
$node = $this->createFunctionBuilder('test')
|
|
->setReturnType('void')
|
|
->getNode();
|
|
|
|
$this->assertEquals(new Stmt\Function_('test', array(
|
|
'returnType' => 'void'
|
|
), array()), $node);
|
|
}
|
|
|
|
/**
|
|
* @expectedException \LogicException
|
|
* @expectedExceptionMessage void type cannot be nullable
|
|
*/
|
|
public function testInvalidNullableVoidType() {
|
|
$this->createFunctionBuilder('test')->setReturnType('?void');
|
|
}
|
|
|
|
/**
|
|
* @expectedException \LogicException
|
|
* @expectedExceptionMessage Expected parameter node, got "Name"
|
|
*/
|
|
public function testInvalidParamError() {
|
|
$this->createFunctionBuilder('test')
|
|
->addParam(new Node\Name('foo'))
|
|
;
|
|
}
|
|
|
|
/**
|
|
* @expectedException \LogicException
|
|
* @expectedExceptionMessage Expected statement or expression node
|
|
*/
|
|
public function testAddNonStmt() {
|
|
$this->createFunctionBuilder('test')
|
|
->addStmt(new Node\Name('Test'));
|
|
}
|
|
}
|