[Validator] fixed StaticMethodLoader trying to invoke methods of abstract classes (closes #8589)

This commit is contained in:
Fabien Potencier 2013-07-27 06:56:17 +02:00
parent 63ef3c1901
commit b41cf82651
2 changed files with 21 additions and 4 deletions

View File

@ -31,7 +31,7 @@ class StaticMethodLoader implements LoaderInterface
/** @var \ReflectionClass $reflClass */ /** @var \ReflectionClass $reflClass */
$reflClass = $metadata->getReflectionClass(); $reflClass = $metadata->getReflectionClass();
if (!$reflClass->isInterface() && $reflClass->hasMethod($this->methodName)) { if (!$reflClass->isInterface() && !$reflClass->isAbstract() && $reflClass->hasMethod($this->methodName)) {
$reflMethod = $reflClass->getMethod($this->methodName); $reflMethod = $reflClass->getMethod($this->methodName);
if (!$reflMethod->isStatic()) { if (!$reflMethod->isStatic()) {

View File

@ -48,12 +48,12 @@ class StaticMethodLoaderTest extends \PHPUnit_Framework_TestCase
$loader = new StaticMethodLoader('loadMetadata'); $loader = new StaticMethodLoader('loadMetadata');
$metadata = new ClassMetadata(__NAMESPACE__.'\StaticLoaderDocument'); $metadata = new ClassMetadata(__NAMESPACE__.'\StaticLoaderDocument');
$loader->loadClassMetadata($metadata); $loader->loadClassMetadata($metadata);
$this->assertSame(0, count($metadata->getConstraints())); $this->assertCount(0, $metadata->getConstraints());
$loader = new StaticMethodLoader('loadMetadata'); $loader = new StaticMethodLoader('loadMetadata');
$metadata = new ClassMetadata(__NAMESPACE__.'\BaseStaticLoaderDocument'); $metadata = new ClassMetadata(__NAMESPACE__.'\BaseStaticLoaderDocument');
$loader->loadClassMetadata($metadata); $loader->loadClassMetadata($metadata);
$this->assertSame(1, count($metadata->getConstraints())); $this->assertCount(1, $metadata->getConstraints());
} }
public function testLoadClassMetadataIgnoresInterfaces() public function testLoadClassMetadataIgnoresInterfaces()
@ -63,7 +63,17 @@ class StaticMethodLoaderTest extends \PHPUnit_Framework_TestCase
$loader->loadClassMetadata($metadata); $loader->loadClassMetadata($metadata);
$this->assertSame(0, count($metadata->getConstraints())); $this->assertCount(0, $metadata->getConstraints());
}
public function testLoadClassMetadataIgnoresAbstractClasses()
{
$loader = new StaticMethodLoader('loadMetadata');
$metadata = new ClassMetadata(__NAMESPACE__.'\AbstractStaticLoader');
$loader->loadClassMetadata($metadata);
$this->assertCount(0, $metadata->getConstraints());
} }
} }
@ -72,6 +82,13 @@ interface StaticLoaderInterface
public static function loadMetadata(ClassMetadata $metadata); public static function loadMetadata(ClassMetadata $metadata);
} }
abstract class AbstractStaticLoader
{
public static function loadMetadata(ClassMetadata $metadata)
{
}
}
class StaticLoaderEntity class StaticLoaderEntity
{ {
public static $invokedWith = null; public static $invokedWith = null;