mirror of
https://github.com/danog/PHP-Parser.git
synced 2025-01-07 13:38:26 +01:00
18129480ae
Type makes it sound like a type-hint, and on a number of other nodes $type is used for exactly that. Use $flags to hold modifiers instead.
67 lines
2.0 KiB
PHP
67 lines
2.0 KiB
PHP
<?php
|
|
|
|
namespace PhpParser\Node\Stmt;
|
|
|
|
class ClassTest extends \PHPUnit_Framework_TestCase
|
|
{
|
|
public function testIsAbstract() {
|
|
$class = new Class_('Foo', array('type' => Class_::MODIFIER_ABSTRACT));
|
|
$this->assertTrue($class->isAbstract());
|
|
|
|
$class = new Class_('Foo');
|
|
$this->assertFalse($class->isAbstract());
|
|
}
|
|
|
|
public function testIsFinal() {
|
|
$class = new Class_('Foo', array('type' => Class_::MODIFIER_FINAL));
|
|
$this->assertTrue($class->isFinal());
|
|
|
|
$class = new Class_('Foo');
|
|
$this->assertFalse($class->isFinal());
|
|
}
|
|
|
|
public function testGetMethods() {
|
|
$methods = array(
|
|
new ClassMethod('foo'),
|
|
new ClassMethod('bar'),
|
|
new ClassMethod('fooBar'),
|
|
);
|
|
$class = new Class_('Foo', array(
|
|
'stmts' => array(
|
|
new TraitUse(array()),
|
|
$methods[0],
|
|
new ClassConst(array()),
|
|
$methods[1],
|
|
new Property(0, array()),
|
|
$methods[2],
|
|
)
|
|
));
|
|
|
|
$this->assertSame($methods, $class->getMethods());
|
|
}
|
|
|
|
public function testGetMethod() {
|
|
$methodConstruct = new ClassMethod('__CONSTRUCT');
|
|
$methodTest = new ClassMethod('test');
|
|
$class = new Class_('Foo', array(
|
|
'stmts' => array(
|
|
new ClassConst(array()),
|
|
$methodConstruct,
|
|
new Property(0, array()),
|
|
$methodTest,
|
|
)
|
|
));
|
|
|
|
$this->assertSame($methodConstruct, $class->getMethod('__construct'));
|
|
$this->assertSame($methodTest, $class->getMethod('test'));
|
|
$this->assertNull($class->getMethod('nonExisting'));
|
|
}
|
|
|
|
public function testDeprecatedTypeNode() {
|
|
$class = new Class_('Foo', array('type' => Class_::MODIFIER_ABSTRACT));
|
|
$this->assertTrue($class->isAbstract());
|
|
$this->assertSame(Class_::MODIFIER_ABSTRACT, $class->flags);
|
|
$this->assertSame(Class_::MODIFIER_ABSTRACT, $class->type);
|
|
}
|
|
}
|