2010-03-19 00:38:42 +03:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace Doctrine\Tests\ORM\Tools;
|
|
|
|
|
2014-09-10 18:41:49 +04:00
|
|
|
use Doctrine\Common\Annotations\AnnotationReader;
|
|
|
|
use Doctrine\Common\Persistence\Mapping\RuntimeReflectionService;
|
|
|
|
use Doctrine\ORM\Mapping\ClassMetadata;
|
2013-03-31 03:47:45 +04:00
|
|
|
use Doctrine\ORM\Mapping\ClassMetadataFactory;
|
2014-09-10 18:41:49 +04:00
|
|
|
use Doctrine\ORM\Mapping\ClassMetadataInfo;
|
|
|
|
use Doctrine\ORM\Mapping\Driver\AnnotationDriver;
|
|
|
|
use Doctrine\ORM\Tools\EntityGenerator;
|
2013-08-20 14:15:17 +04:00
|
|
|
use Doctrine\Tests\Models\DDC2372\DDC2372Admin;
|
2014-09-10 18:41:49 +04:00
|
|
|
use Doctrine\Tests\Models\DDC2372\DDC2372User;
|
2014-09-10 18:57:35 +04:00
|
|
|
use Doctrine\Tests\OrmTestCase;
|
2010-03-19 00:38:42 +03:00
|
|
|
|
2014-09-10 18:57:35 +04:00
|
|
|
class EntityGeneratorTest extends OrmTestCase
|
2010-03-19 00:38:42 +03:00
|
|
|
{
|
2012-04-01 20:29:49 +04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @var EntityGenerator
|
|
|
|
*/
|
2010-03-19 01:35:16 +03:00
|
|
|
private $_generator;
|
2011-02-03 01:21:42 +03:00
|
|
|
private $_tmpDir;
|
|
|
|
private $_namespace;
|
2010-03-19 01:35:16 +03:00
|
|
|
|
|
|
|
public function setUp()
|
|
|
|
{
|
2011-02-03 01:21:42 +03:00
|
|
|
$this->_namespace = uniqid("doctrine_");
|
|
|
|
$this->_tmpDir = \sys_get_temp_dir();
|
|
|
|
\mkdir($this->_tmpDir . \DIRECTORY_SEPARATOR . $this->_namespace);
|
2010-03-19 01:35:16 +03:00
|
|
|
$this->_generator = new EntityGenerator();
|
2011-10-15 22:44:25 +04:00
|
|
|
$this->_generator->setAnnotationPrefix("");
|
2010-03-19 01:35:16 +03:00
|
|
|
$this->_generator->setGenerateAnnotations(true);
|
|
|
|
$this->_generator->setGenerateStubMethods(true);
|
|
|
|
$this->_generator->setRegenerateEntityIfExists(false);
|
|
|
|
$this->_generator->setUpdateEntityIfExists(true);
|
2012-01-13 14:24:35 +04:00
|
|
|
$this->_generator->setFieldVisibility(EntityGenerator::FIELD_VISIBLE_PROTECTED);
|
2010-03-19 01:35:16 +03:00
|
|
|
}
|
|
|
|
|
2011-02-03 01:21:42 +03:00
|
|
|
public function tearDown()
|
2010-03-19 00:38:42 +03:00
|
|
|
{
|
2011-02-03 01:21:42 +03:00
|
|
|
$ri = new \RecursiveIteratorIterator(new \RecursiveDirectoryIterator($this->_tmpDir . '/' . $this->_namespace));
|
|
|
|
foreach ($ri AS $file) {
|
|
|
|
/* @var $file \SplFileInfo */
|
|
|
|
if ($file->isFile()) {
|
|
|
|
\unlink($file->getPathname());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
rmdir($this->_tmpDir . '/' . $this->_namespace);
|
|
|
|
}
|
|
|
|
|
2014-09-12 22:29:37 +04:00
|
|
|
/**
|
|
|
|
* @param ClassMetadataInfo[] $embeddedClasses
|
|
|
|
*
|
|
|
|
* @return ClassMetadataInfo
|
|
|
|
*/
|
|
|
|
public function generateBookEntityFixture(array $embeddedClasses = array())
|
2011-02-03 01:21:42 +03:00
|
|
|
{
|
|
|
|
$metadata = new ClassMetadataInfo($this->_namespace . '\EntityGeneratorBook');
|
|
|
|
$metadata->namespace = $this->_namespace;
|
|
|
|
$metadata->customRepositoryClassName = $this->_namespace . '\EntityGeneratorBookRepository';
|
2011-12-20 01:56:19 +04:00
|
|
|
|
2010-03-29 17:20:41 +04:00
|
|
|
$metadata->table['name'] = 'book';
|
2012-01-28 14:16:36 +04:00
|
|
|
$metadata->table['uniqueConstraints']['name_uniq'] = array('columns' => array('name'));
|
|
|
|
$metadata->table['indexes']['status_idx'] = array('columns' => array('status'));
|
2010-03-20 01:38:45 +03:00
|
|
|
$metadata->mapField(array('fieldName' => 'name', 'type' => 'string'));
|
|
|
|
$metadata->mapField(array('fieldName' => 'status', 'type' => 'string', 'default' => 'published'));
|
2010-03-19 00:38:42 +03:00
|
|
|
$metadata->mapField(array('fieldName' => 'id', 'type' => 'integer', 'id' => true));
|
2010-03-20 01:38:45 +03:00
|
|
|
$metadata->mapOneToOne(array('fieldName' => 'author', 'targetEntity' => 'Doctrine\Tests\ORM\Tools\EntityGeneratorAuthor', 'mappedBy' => 'book'));
|
2010-03-19 00:38:42 +03:00
|
|
|
$joinColumns = array(
|
2010-03-20 01:38:45 +03:00
|
|
|
array('name' => 'author_id', 'referencedColumnName' => 'id')
|
2010-03-19 00:38:42 +03:00
|
|
|
);
|
|
|
|
$metadata->mapManyToMany(array(
|
2010-03-20 01:38:45 +03:00
|
|
|
'fieldName' => 'comments',
|
|
|
|
'targetEntity' => 'Doctrine\Tests\ORM\Tools\EntityGeneratorComment',
|
2013-05-09 12:55:12 +04:00
|
|
|
'fetch' => ClassMetadataInfo::FETCH_EXTRA_LAZY,
|
2010-03-19 00:38:42 +03:00
|
|
|
'joinTable' => array(
|
2010-03-20 01:38:45 +03:00
|
|
|
'name' => 'book_comment',
|
|
|
|
'joinColumns' => array(array('name' => 'book_id', 'referencedColumnName' => 'id')),
|
|
|
|
'inverseJoinColumns' => array(array('name' => 'comment_id', 'referencedColumnName' => 'id')),
|
2010-03-19 00:38:42 +03:00
|
|
|
),
|
|
|
|
));
|
2011-02-03 01:21:42 +03:00
|
|
|
$metadata->addLifecycleCallback('loading', 'postLoad');
|
|
|
|
$metadata->addLifecycleCallback('willBeRemoved', 'preRemove');
|
2010-03-19 00:38:42 +03:00
|
|
|
$metadata->setIdGeneratorType(ClassMetadataInfo::GENERATOR_TYPE_AUTO);
|
|
|
|
|
2014-09-12 22:29:37 +04:00
|
|
|
foreach ($embeddedClasses as $fieldName => $embeddedClass) {
|
|
|
|
$this->mapNestedEmbedded($fieldName, $metadata, $embeddedClass);
|
|
|
|
$this->mapEmbedded($fieldName, $metadata, $embeddedClass);
|
|
|
|
}
|
|
|
|
|
2011-02-03 01:21:42 +03:00
|
|
|
$this->_generator->writeEntityClass($metadata, $this->_tmpDir);
|
2010-03-19 01:35:16 +03:00
|
|
|
|
|
|
|
return $metadata;
|
2010-03-19 00:38:42 +03:00
|
|
|
}
|
|
|
|
|
2012-04-01 21:59:21 +04:00
|
|
|
private function generateEntityTypeFixture(array $field)
|
|
|
|
{
|
|
|
|
$metadata = new ClassMetadataInfo($this->_namespace . '\EntityType');
|
|
|
|
$metadata->namespace = $this->_namespace;
|
|
|
|
|
|
|
|
$metadata->table['name'] = 'entity_type';
|
|
|
|
$metadata->mapField(array('fieldName' => 'id', 'type' => 'integer', 'id' => true));
|
|
|
|
$metadata->setIdGeneratorType(ClassMetadataInfo::GENERATOR_TYPE_AUTO);
|
|
|
|
|
|
|
|
$name = $field['fieldName'];
|
|
|
|
$type = $field['dbType'];
|
|
|
|
$metadata->mapField(array('fieldName' => $name, 'type' => $type));
|
|
|
|
|
|
|
|
$this->_generator->writeEntityClass($metadata, $this->_tmpDir);
|
|
|
|
|
|
|
|
return $metadata;
|
|
|
|
}
|
|
|
|
|
2010-03-19 00:38:42 +03:00
|
|
|
/**
|
2014-09-12 22:29:37 +04:00
|
|
|
* @return ClassMetadataInfo
|
2010-03-19 00:38:42 +03:00
|
|
|
*/
|
2014-09-12 22:29:37 +04:00
|
|
|
private function generateIsbnEmbeddableFixture(array $embeddedClasses = array())
|
|
|
|
{
|
|
|
|
$metadata = new ClassMetadataInfo($this->_namespace . '\EntityGeneratorIsbn');
|
|
|
|
$metadata->namespace = $this->_namespace;
|
|
|
|
$metadata->isEmbeddedClass = true;
|
|
|
|
$metadata->mapField(array('fieldName' => 'prefix', 'type' => 'integer'));
|
|
|
|
$metadata->mapField(array('fieldName' => 'groupNumber', 'type' => 'integer'));
|
|
|
|
$metadata->mapField(array('fieldName' => 'publisherNumber', 'type' => 'integer'));
|
|
|
|
$metadata->mapField(array('fieldName' => 'titleNumber', 'type' => 'integer'));
|
|
|
|
$metadata->mapField(array('fieldName' => 'checkDigit', 'type' => 'integer'));
|
|
|
|
|
|
|
|
foreach ($embeddedClasses as $fieldName => $embeddedClass) {
|
|
|
|
$this->mapEmbedded($fieldName, $metadata, $embeddedClass);
|
|
|
|
}
|
|
|
|
|
|
|
|
$this->_generator->writeEntityClass($metadata, $this->_tmpDir);
|
|
|
|
|
|
|
|
return $metadata;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return ClassMetadataInfo
|
|
|
|
*/
|
|
|
|
private function generateTestEmbeddableFixture()
|
|
|
|
{
|
|
|
|
$metadata = new ClassMetadataInfo($this->_namespace . '\EntityGeneratorTestEmbeddable');
|
|
|
|
$metadata->namespace = $this->_namespace;
|
|
|
|
$metadata->isEmbeddedClass = true;
|
|
|
|
$metadata->mapField(array('fieldName' => 'field1', 'type' => 'integer'));
|
|
|
|
$metadata->mapField(array('fieldName' => 'field2', 'type' => 'integer', 'nullable' => true));
|
|
|
|
$metadata->mapField(array('fieldName' => 'field3', 'type' => 'datetime'));
|
|
|
|
$metadata->mapField(array('fieldName' => 'field4', 'type' => 'datetime', 'nullable' => true));
|
|
|
|
|
|
|
|
$this->_generator->writeEntityClass($metadata, $this->_tmpDir);
|
|
|
|
|
|
|
|
return $metadata;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param string $fieldName
|
|
|
|
* @param ClassMetadataInfo $classMetadata
|
|
|
|
* @param ClassMetadataInfo $embeddableMetadata
|
|
|
|
* @param string|null $columnPrefix
|
|
|
|
*/
|
|
|
|
private function mapEmbedded(
|
|
|
|
$fieldName,
|
|
|
|
ClassMetadataInfo $classMetadata,
|
|
|
|
ClassMetadataInfo $embeddableMetadata,
|
|
|
|
$columnPrefix = false
|
|
|
|
) {
|
|
|
|
$classMetadata->mapEmbedded(
|
|
|
|
array('fieldName' => $fieldName, 'class' => $embeddableMetadata->name, 'columnPrefix' => $columnPrefix)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param string $fieldName
|
|
|
|
* @param ClassMetadataInfo $classMetadata
|
|
|
|
* @param ClassMetadataInfo $embeddableMetadata
|
|
|
|
*/
|
|
|
|
private function mapNestedEmbedded(
|
|
|
|
$fieldName,
|
|
|
|
ClassMetadataInfo $classMetadata,
|
|
|
|
ClassMetadataInfo $embeddableMetadata
|
|
|
|
) {
|
|
|
|
foreach ($embeddableMetadata->embeddedClasses as $property => $embeddableClass) {
|
|
|
|
$classMetadata->mapEmbedded(array(
|
|
|
|
'fieldName' => $fieldName . '.' . $property,
|
|
|
|
'class' => $embeddableClass['class'],
|
|
|
|
'columnPrefix' => $embeddableClass['columnPrefix'],
|
|
|
|
'declaredField' => $embeddableClass['declaredField']
|
|
|
|
? $fieldName . '.' . $embeddableClass['declaredField']
|
|
|
|
: $fieldName,
|
|
|
|
'originalField' => $embeddableClass['originalField'] ?: $property,
|
|
|
|
));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param ClassMetadataInfo $metadata
|
|
|
|
*/
|
|
|
|
private function loadEntityClass(ClassMetadataInfo $metadata)
|
2011-02-03 01:21:42 +03:00
|
|
|
{
|
2014-09-12 22:29:37 +04:00
|
|
|
$className = basename(str_replace('\\', '/', $metadata->name));
|
|
|
|
$path = $this->_tmpDir . '/' . $this->_namespace . '/' . $className . '.php';
|
|
|
|
|
2011-02-03 01:21:42 +03:00
|
|
|
$this->assertFileExists($path);
|
2014-09-12 22:29:37 +04:00
|
|
|
|
2011-02-03 01:21:42 +03:00
|
|
|
require_once $path;
|
2014-09-12 22:29:37 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param ClassMetadataInfo $metadata
|
|
|
|
*
|
|
|
|
* @return mixed An instance of the given metadata's class.
|
|
|
|
*/
|
|
|
|
public function newInstance($metadata)
|
|
|
|
{
|
|
|
|
$this->loadEntityClass($metadata);
|
2011-02-03 01:21:42 +03:00
|
|
|
|
|
|
|
return new $metadata->name;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testGeneratedEntityClass()
|
2010-03-19 00:38:42 +03:00
|
|
|
{
|
2014-09-12 22:29:37 +04:00
|
|
|
$testMetadata = $this->generateTestEmbeddableFixture();
|
|
|
|
$isbnMetadata = $this->generateIsbnEmbeddableFixture(array('test' => $testMetadata));
|
|
|
|
$metadata = $this->generateBookEntityFixture(array('isbn' => $isbnMetadata));
|
2011-02-03 01:21:42 +03:00
|
|
|
|
|
|
|
$book = $this->newInstance($metadata);
|
|
|
|
$this->assertTrue(class_exists($metadata->name), "Class does not exist.");
|
2011-02-03 01:30:16 +03:00
|
|
|
$this->assertTrue(method_exists($metadata->namespace . '\EntityGeneratorBook', '__construct'), "EntityGeneratorBook::__construct() missing.");
|
2011-02-03 01:21:42 +03:00
|
|
|
$this->assertTrue(method_exists($metadata->namespace . '\EntityGeneratorBook', 'getId'), "EntityGeneratorBook::getId() missing.");
|
|
|
|
$this->assertTrue(method_exists($metadata->namespace . '\EntityGeneratorBook', 'setName'), "EntityGeneratorBook::setName() missing.");
|
|
|
|
$this->assertTrue(method_exists($metadata->namespace . '\EntityGeneratorBook', 'getName'), "EntityGeneratorBook::getName() missing.");
|
2014-09-12 22:29:37 +04:00
|
|
|
$this->assertTrue(method_exists($metadata->namespace . '\EntityGeneratorBook', 'setStatus'), "EntityGeneratorBook::setStatus() missing.");
|
|
|
|
$this->assertTrue(method_exists($metadata->namespace . '\EntityGeneratorBook', 'getStatus'), "EntityGeneratorBook::getStatus() missing.");
|
2011-02-03 01:21:42 +03:00
|
|
|
$this->assertTrue(method_exists($metadata->namespace . '\EntityGeneratorBook', 'setAuthor'), "EntityGeneratorBook::setAuthor() missing.");
|
|
|
|
$this->assertTrue(method_exists($metadata->namespace . '\EntityGeneratorBook', 'getAuthor'), "EntityGeneratorBook::getAuthor() missing.");
|
|
|
|
$this->assertTrue(method_exists($metadata->namespace . '\EntityGeneratorBook', 'getComments'), "EntityGeneratorBook::getComments() missing.");
|
2012-05-27 22:31:01 +04:00
|
|
|
$this->assertTrue(method_exists($metadata->namespace . '\EntityGeneratorBook', 'addComment'), "EntityGeneratorBook::addComment() missing.");
|
2012-07-04 23:03:50 +04:00
|
|
|
$this->assertTrue(method_exists($metadata->namespace . '\EntityGeneratorBook', 'removeComment'), "EntityGeneratorBook::removeComment() missing.");
|
2014-09-12 22:29:37 +04:00
|
|
|
$this->assertTrue(method_exists($metadata->namespace . '\EntityGeneratorBook', 'setIsbn'), "EntityGeneratorBook::setIsbn() missing.");
|
|
|
|
$this->assertTrue(method_exists($metadata->namespace . '\EntityGeneratorBook', 'getIsbn'), "EntityGeneratorBook::getIsbn() missing.");
|
|
|
|
|
|
|
|
$reflClass = new \ReflectionClass($metadata->name);
|
|
|
|
|
|
|
|
$this->assertCount(6, $reflClass->getProperties());
|
|
|
|
$this->assertCount(15, $reflClass->getMethods());
|
2011-12-20 01:56:19 +04:00
|
|
|
|
2012-04-01 20:29:49 +04:00
|
|
|
$this->assertEquals('published', $book->getStatus());
|
2012-04-01 21:59:21 +04:00
|
|
|
|
|
|
|
$book->setName('Jonathan H. Wage');
|
2010-03-19 00:38:42 +03:00
|
|
|
$this->assertEquals('Jonathan H. Wage', $book->getName());
|
|
|
|
|
2014-06-19 12:00:40 +04:00
|
|
|
$reflMethod = new \ReflectionMethod($metadata->name, 'addComment');
|
|
|
|
$addCommentParameters = $reflMethod->getParameters();
|
|
|
|
$this->assertEquals('comment', $addCommentParameters[0]->getName());
|
|
|
|
|
|
|
|
$reflMethod = new \ReflectionMethod($metadata->name, 'removeComment');
|
|
|
|
$removeCommentParameters = $reflMethod->getParameters();
|
|
|
|
$this->assertEquals('comment', $removeCommentParameters[0]->getName());
|
|
|
|
|
2010-03-20 01:38:45 +03:00
|
|
|
$author = new EntityGeneratorAuthor();
|
|
|
|
$book->setAuthor($author);
|
|
|
|
$this->assertEquals($author, $book->getAuthor());
|
2010-03-19 00:38:42 +03:00
|
|
|
|
2010-03-20 01:38:45 +03:00
|
|
|
$comment = new EntityGeneratorComment();
|
2012-05-27 22:31:01 +04:00
|
|
|
$book->addComment($comment);
|
2011-02-03 01:30:16 +03:00
|
|
|
$this->assertInstanceOf('Doctrine\Common\Collections\ArrayCollection', $book->getComments());
|
|
|
|
$this->assertEquals(new \Doctrine\Common\Collections\ArrayCollection(array($comment)), $book->getComments());
|
2012-07-04 23:03:50 +04:00
|
|
|
$book->removeComment($comment);
|
|
|
|
$this->assertEquals(new \Doctrine\Common\Collections\ArrayCollection(array()), $book->getComments());
|
2014-09-12 22:29:37 +04:00
|
|
|
|
|
|
|
$this->newInstance($isbnMetadata);
|
|
|
|
$isbn = new $isbnMetadata->name();
|
|
|
|
|
|
|
|
$book->setIsbn($isbn);
|
|
|
|
$this->assertSame($isbn, $book->getIsbn());
|
|
|
|
|
|
|
|
$reflMethod = new \ReflectionMethod($metadata->name, 'setIsbn');
|
|
|
|
$reflParameters = $reflMethod->getParameters();
|
|
|
|
$this->assertEquals($isbnMetadata->name, $reflParameters[0]->getClass()->name);
|
2010-03-19 01:35:16 +03:00
|
|
|
}
|
|
|
|
|
2011-02-03 01:21:42 +03:00
|
|
|
public function testEntityUpdatingWorks()
|
2010-03-19 01:35:16 +03:00
|
|
|
{
|
2014-09-12 22:29:37 +04:00
|
|
|
$metadata = $this->generateBookEntityFixture(array('isbn' => $this->generateIsbnEmbeddableFixture()));
|
|
|
|
|
2010-03-20 01:38:45 +03:00
|
|
|
$metadata->mapField(array('fieldName' => 'test', 'type' => 'string'));
|
2011-12-20 01:56:19 +04:00
|
|
|
|
2014-09-12 22:29:37 +04:00
|
|
|
$testEmbeddableMetadata = $this->generateTestEmbeddableFixture();
|
|
|
|
$this->mapEmbedded('testEmbedded', $metadata, $testEmbeddableMetadata);
|
|
|
|
|
2011-02-03 01:21:42 +03:00
|
|
|
$this->_generator->writeEntityClass($metadata, $this->_tmpDir);
|
2010-03-19 01:35:16 +03:00
|
|
|
|
2011-05-13 06:05:45 +04:00
|
|
|
$this->assertFileExists($this->_tmpDir . "/" . $this->_namespace . "/EntityGeneratorBook.php~");
|
2010-03-20 01:38:45 +03:00
|
|
|
|
2011-02-03 01:21:42 +03:00
|
|
|
$book = $this->newInstance($metadata);
|
|
|
|
$reflClass = new \ReflectionClass($metadata->name);
|
2010-03-19 01:35:16 +03:00
|
|
|
|
2011-02-03 01:21:42 +03:00
|
|
|
$this->assertTrue($reflClass->hasProperty('name'), "Regenerating keeps property 'name'.");
|
|
|
|
$this->assertTrue($reflClass->hasProperty('status'), "Regenerating keeps property 'status'.");
|
|
|
|
$this->assertTrue($reflClass->hasProperty('id'), "Regenerating keeps property 'id'.");
|
2014-09-12 22:29:37 +04:00
|
|
|
$this->assertTrue($reflClass->hasProperty('isbn'), "Regenerating keeps property 'isbn'.");
|
2011-02-03 01:21:42 +03:00
|
|
|
|
|
|
|
$this->assertTrue($reflClass->hasProperty('test'), "Check for property test failed.");
|
2012-01-13 17:14:28 +04:00
|
|
|
$this->assertTrue($reflClass->getProperty('test')->isProtected(), "Check for protected property test failed.");
|
2014-09-12 22:29:37 +04:00
|
|
|
$this->assertTrue($reflClass->hasProperty('testEmbedded'), "Check for property testEmbedded failed.");
|
|
|
|
$this->assertTrue($reflClass->getProperty('testEmbedded')->isProtected(), "Check for protected property testEmbedded failed.");
|
2011-02-03 01:21:42 +03:00
|
|
|
$this->assertTrue($reflClass->hasMethod('getTest'), "Check for method 'getTest' failed.");
|
|
|
|
$this->assertTrue($reflClass->getMethod('getTest')->isPublic(), "Check for public visibility of method 'getTest' failed.");
|
2014-09-12 22:29:37 +04:00
|
|
|
$this->assertTrue($reflClass->hasMethod('setTest'), "Check for method 'setTest' failed.");
|
|
|
|
$this->assertTrue($reflClass->getMethod('setTest')->isPublic(), "Check for public visibility of method 'setTest' failed.");
|
|
|
|
$this->assertTrue($reflClass->hasMethod('getTestEmbedded'), "Check for method 'getTestEmbedded' failed.");
|
|
|
|
$this->assertTrue(
|
|
|
|
$reflClass->getMethod('getTestEmbedded')->isPublic(),
|
|
|
|
"Check for public visibility of method 'getTestEmbedded' failed."
|
|
|
|
);
|
|
|
|
$this->assertTrue($reflClass->hasMethod('setTestEmbedded'), "Check for method 'setTestEmbedded' failed.");
|
|
|
|
$this->assertTrue(
|
|
|
|
$reflClass->getMethod('setTestEmbedded')->isPublic(),
|
|
|
|
"Check for public visibility of method 'setTestEmbedded' failed."
|
|
|
|
);
|
2010-08-28 18:29:08 +04:00
|
|
|
}
|
|
|
|
|
2014-06-05 17:58:54 +04:00
|
|
|
/**
|
|
|
|
* @group DDC-3152
|
|
|
|
*/
|
|
|
|
public function testDoesNotRegenerateExistingMethodsWithDifferentCase()
|
|
|
|
{
|
2014-09-12 22:29:37 +04:00
|
|
|
$metadata = $this->generateBookEntityFixture(array('isbn' => $this->generateIsbnEmbeddableFixture()));
|
2014-06-05 17:58:54 +04:00
|
|
|
|
|
|
|
// Workaround to change existing fields case (just to simulate the use case)
|
|
|
|
$metadata->fieldMappings['status']['fieldName'] = 'STATUS';
|
2014-09-12 22:29:37 +04:00
|
|
|
$metadata->embeddedClasses['ISBN'] = $metadata->embeddedClasses['isbn'];
|
|
|
|
unset($metadata->embeddedClasses['isbn']);
|
2014-06-05 17:58:54 +04:00
|
|
|
|
|
|
|
// Should not throw a PHP fatal error
|
|
|
|
$this->_generator->writeEntityClass($metadata, $this->_tmpDir);
|
|
|
|
|
|
|
|
$this->assertFileExists($this->_tmpDir . "/" . $this->_namespace . "/EntityGeneratorBook.php~");
|
|
|
|
|
|
|
|
$this->newInstance($metadata);
|
|
|
|
$reflClass = new \ReflectionClass($metadata->name);
|
|
|
|
|
|
|
|
$this->assertTrue($reflClass->hasProperty('status'));
|
|
|
|
$this->assertTrue($reflClass->hasProperty('STATUS'));
|
2014-09-12 22:29:37 +04:00
|
|
|
$this->assertTrue($reflClass->hasProperty('isbn'));
|
|
|
|
$this->assertTrue($reflClass->hasProperty('ISBN'));
|
2014-06-05 17:58:54 +04:00
|
|
|
$this->assertTrue($reflClass->hasMethod('getStatus'));
|
|
|
|
$this->assertTrue($reflClass->hasMethod('setStatus'));
|
2014-09-12 22:29:37 +04:00
|
|
|
$this->assertTrue($reflClass->hasMethod('getIsbn'));
|
|
|
|
$this->assertTrue($reflClass->hasMethod('setIsbn'));
|
2014-06-05 17:58:54 +04:00
|
|
|
}
|
|
|
|
|
2012-11-06 03:53:07 +04:00
|
|
|
/**
|
|
|
|
* @group DDC-2121
|
|
|
|
*/
|
|
|
|
public function testMethodDocBlockShouldStartWithBackSlash()
|
|
|
|
{
|
2014-09-12 22:29:37 +04:00
|
|
|
$embeddedMetadata = $this->generateIsbnEmbeddableFixture();
|
|
|
|
$metadata = $this->generateBookEntityFixture(array('isbn' => $embeddedMetadata));
|
|
|
|
$book = $this->newInstance($metadata);
|
2012-11-06 03:53:07 +04:00
|
|
|
|
|
|
|
$this->assertPhpDocVarType('\Doctrine\Common\Collections\Collection', new \ReflectionProperty($book, 'comments'));
|
|
|
|
$this->assertPhpDocReturnType('\Doctrine\Common\Collections\Collection', new \ReflectionMethod($book, 'getComments'));
|
|
|
|
$this->assertPhpDocParamType('\Doctrine\Tests\ORM\Tools\EntityGeneratorComment', new \ReflectionMethod($book, 'addComment'));
|
|
|
|
$this->assertPhpDocParamType('\Doctrine\Tests\ORM\Tools\EntityGeneratorComment', new \ReflectionMethod($book, 'removeComment'));
|
|
|
|
|
|
|
|
$this->assertPhpDocVarType('\Doctrine\Tests\ORM\Tools\EntityGeneratorAuthor', new \ReflectionProperty($book, 'author'));
|
|
|
|
$this->assertPhpDocReturnType('\Doctrine\Tests\ORM\Tools\EntityGeneratorAuthor', new \ReflectionMethod($book, 'getAuthor'));
|
|
|
|
$this->assertPhpDocParamType('\Doctrine\Tests\ORM\Tools\EntityGeneratorAuthor', new \ReflectionMethod($book, 'setAuthor'));
|
2014-09-12 22:29:37 +04:00
|
|
|
|
|
|
|
$expectedClassName = '\\' . $embeddedMetadata->name;
|
|
|
|
$this->assertPhpDocVarType($expectedClassName, new \ReflectionProperty($book, 'isbn'));
|
|
|
|
$this->assertPhpDocReturnType($expectedClassName, new \ReflectionMethod($book, 'getIsbn'));
|
|
|
|
$this->assertPhpDocParamType($expectedClassName, new \ReflectionMethod($book, 'setIsbn'));
|
2012-11-06 03:53:07 +04:00
|
|
|
}
|
|
|
|
|
2011-02-03 01:21:42 +03:00
|
|
|
public function testEntityExtendsStdClass()
|
2010-08-28 18:29:08 +04:00
|
|
|
{
|
2011-02-03 01:21:42 +03:00
|
|
|
$this->_generator->setClassToExtend('stdClass');
|
|
|
|
$metadata = $this->generateBookEntityFixture();
|
|
|
|
|
|
|
|
$book = $this->newInstance($metadata);
|
|
|
|
$this->assertInstanceOf('stdClass', $book);
|
2014-09-12 22:29:37 +04:00
|
|
|
|
|
|
|
$metadata = $this->generateIsbnEmbeddableFixture();
|
|
|
|
$isbn = $this->newInstance($metadata);
|
|
|
|
$this->assertInstanceOf('stdClass', $isbn);
|
2011-02-03 01:21:42 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testLifecycleCallbacks()
|
|
|
|
{
|
|
|
|
$metadata = $this->generateBookEntityFixture();
|
|
|
|
|
|
|
|
$book = $this->newInstance($metadata);
|
|
|
|
$reflClass = new \ReflectionClass($metadata->name);
|
|
|
|
|
|
|
|
$this->assertTrue($reflClass->hasMethod('loading'), "Check for postLoad lifecycle callback.");
|
|
|
|
$this->assertTrue($reflClass->hasMethod('willBeRemoved'), "Check for preRemove lifecycle callback.");
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testLoadMetadata()
|
|
|
|
{
|
2014-09-12 22:29:37 +04:00
|
|
|
$embeddedMetadata = $this->generateIsbnEmbeddableFixture();
|
|
|
|
$metadata = $this->generateBookEntityFixture(array('isbn' => $embeddedMetadata));
|
2011-02-03 01:21:42 +03:00
|
|
|
|
|
|
|
$book = $this->newInstance($metadata);
|
|
|
|
|
2014-09-12 22:29:37 +04:00
|
|
|
$reflectionService = new RuntimeReflectionService();
|
|
|
|
|
2014-09-10 18:41:49 +04:00
|
|
|
$cm = new ClassMetadata($metadata->name);
|
2014-09-12 22:29:37 +04:00
|
|
|
$cm->initializeReflection($reflectionService);
|
2012-01-03 00:32:18 +04:00
|
|
|
|
2011-05-25 02:26:20 +04:00
|
|
|
$driver = $this->createAnnotationDriver();
|
2011-02-03 01:21:42 +03:00
|
|
|
$driver->loadMetadataForClass($cm->name, $cm);
|
|
|
|
|
|
|
|
$this->assertEquals($cm->columnNames, $metadata->columnNames);
|
|
|
|
$this->assertEquals($cm->getTableName(), $metadata->getTableName());
|
|
|
|
$this->assertEquals($cm->lifecycleCallbacks, $metadata->lifecycleCallbacks);
|
|
|
|
$this->assertEquals($cm->identifier, $metadata->identifier);
|
|
|
|
$this->assertEquals($cm->idGenerator, $metadata->idGenerator);
|
|
|
|
$this->assertEquals($cm->customRepositoryClassName, $metadata->customRepositoryClassName);
|
2014-09-12 22:29:37 +04:00
|
|
|
$this->assertEquals($cm->embeddedClasses, $metadata->embeddedClasses);
|
|
|
|
$this->assertEquals($cm->isEmbeddedClass, $metadata->isEmbeddedClass);
|
2013-05-09 12:55:12 +04:00
|
|
|
|
|
|
|
$this->assertEquals(ClassMetadataInfo::FETCH_EXTRA_LAZY, $cm->associationMappings['comments']['fetch']);
|
2014-09-12 22:29:37 +04:00
|
|
|
|
|
|
|
$isbn = $this->newInstance($embeddedMetadata);
|
|
|
|
|
|
|
|
$cm = new ClassMetadata($embeddedMetadata->name);
|
|
|
|
$cm->initializeReflection($reflectionService);
|
|
|
|
|
|
|
|
$driver->loadMetadataForClass($cm->name, $cm);
|
|
|
|
|
|
|
|
$this->assertEquals($cm->columnNames, $embeddedMetadata->columnNames);
|
|
|
|
$this->assertEquals($cm->embeddedClasses, $embeddedMetadata->embeddedClasses);
|
|
|
|
$this->assertEquals($cm->isEmbeddedClass, $embeddedMetadata->isEmbeddedClass);
|
2011-02-03 01:21:42 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testLoadPrefixedMetadata()
|
|
|
|
{
|
2011-10-15 22:44:25 +04:00
|
|
|
$this->_generator->setAnnotationPrefix('ORM\\');
|
2014-09-12 22:29:37 +04:00
|
|
|
$embeddedMetadata = $this->generateIsbnEmbeddableFixture();
|
|
|
|
$metadata = $this->generateBookEntityFixture(array('isbn' => $embeddedMetadata));
|
2011-02-03 01:21:42 +03:00
|
|
|
|
2014-09-10 18:41:49 +04:00
|
|
|
$reader = new AnnotationReader();
|
|
|
|
$driver = new AnnotationDriver($reader, array());
|
2011-02-03 01:21:42 +03:00
|
|
|
|
|
|
|
$book = $this->newInstance($metadata);
|
|
|
|
|
2014-09-12 22:29:37 +04:00
|
|
|
$reflectionService = new RuntimeReflectionService();
|
|
|
|
|
2014-09-10 18:41:49 +04:00
|
|
|
$cm = new ClassMetadata($metadata->name);
|
2014-09-12 22:29:37 +04:00
|
|
|
$cm->initializeReflection($reflectionService);
|
2012-01-03 00:32:18 +04:00
|
|
|
|
2011-02-03 01:21:42 +03:00
|
|
|
$driver->loadMetadataForClass($cm->name, $cm);
|
2010-08-28 18:29:08 +04:00
|
|
|
|
2011-02-03 01:21:42 +03:00
|
|
|
$this->assertEquals($cm->columnNames, $metadata->columnNames);
|
|
|
|
$this->assertEquals($cm->getTableName(), $metadata->getTableName());
|
|
|
|
$this->assertEquals($cm->lifecycleCallbacks, $metadata->lifecycleCallbacks);
|
|
|
|
$this->assertEquals($cm->identifier, $metadata->identifier);
|
|
|
|
$this->assertEquals($cm->idGenerator, $metadata->idGenerator);
|
|
|
|
$this->assertEquals($cm->customRepositoryClassName, $metadata->customRepositoryClassName);
|
2014-09-12 22:29:37 +04:00
|
|
|
|
|
|
|
$isbn = $this->newInstance($embeddedMetadata);
|
|
|
|
|
|
|
|
$cm = new ClassMetadata($embeddedMetadata->name);
|
|
|
|
$cm->initializeReflection($reflectionService);
|
|
|
|
|
|
|
|
$driver->loadMetadataForClass($cm->name, $cm);
|
|
|
|
|
|
|
|
$this->assertEquals($cm->columnNames, $embeddedMetadata->columnNames);
|
|
|
|
$this->assertEquals($cm->embeddedClasses, $embeddedMetadata->embeddedClasses);
|
|
|
|
$this->assertEquals($cm->isEmbeddedClass, $embeddedMetadata->isEmbeddedClass);
|
2010-03-19 00:38:42 +03:00
|
|
|
}
|
2011-04-30 12:42:38 +04:00
|
|
|
|
2014-09-10 18:40:17 +04:00
|
|
|
/**
|
|
|
|
* @group DDC-3272
|
|
|
|
*/
|
|
|
|
public function testMappedSuperclassAnnotationGeneration()
|
|
|
|
{
|
2014-09-10 18:57:35 +04:00
|
|
|
$metadata = new ClassMetadataInfo($this->_namespace . '\EntityGeneratorBook');
|
2014-09-10 18:40:17 +04:00
|
|
|
$metadata->namespace = $this->_namespace;
|
|
|
|
$metadata->isMappedSuperclass = true;
|
|
|
|
|
|
|
|
$this->_generator->setAnnotationPrefix('ORM\\');
|
|
|
|
$this->_generator->writeEntityClass($metadata, $this->_tmpDir);
|
2014-09-10 18:57:35 +04:00
|
|
|
$this->newInstance($metadata); // force instantiation (causes autoloading to kick in)
|
2014-09-10 18:40:17 +04:00
|
|
|
|
2014-09-10 18:41:49 +04:00
|
|
|
$driver = new AnnotationDriver(new AnnotationReader(), array());
|
2014-09-10 18:57:35 +04:00
|
|
|
$cm = new ClassMetadata($metadata->name);
|
2014-09-10 18:40:17 +04:00
|
|
|
|
2014-09-10 18:57:35 +04:00
|
|
|
$cm->initializeReflection(new RuntimeReflectionService);
|
2014-09-10 18:40:17 +04:00
|
|
|
$driver->loadMetadataForClass($cm->name, $cm);
|
|
|
|
|
|
|
|
$this->assertTrue($cm->isMappedSuperclass);
|
|
|
|
}
|
|
|
|
|
2011-04-30 12:42:38 +04:00
|
|
|
/**
|
|
|
|
* @dataProvider getParseTokensInEntityFileData
|
|
|
|
*/
|
|
|
|
public function testParseTokensInEntityFile($php, $classes)
|
|
|
|
{
|
|
|
|
$r = new \ReflectionObject($this->_generator);
|
2012-04-01 20:29:49 +04:00
|
|
|
$m = $r->getMethod('parseTokensInEntityFile');
|
2011-04-30 12:42:38 +04:00
|
|
|
$m->setAccessible(true);
|
|
|
|
|
2012-04-01 20:29:49 +04:00
|
|
|
$p = $r->getProperty('staticReflection');
|
2011-04-30 12:42:38 +04:00
|
|
|
$p->setAccessible(true);
|
|
|
|
|
|
|
|
$ret = $m->invoke($this->_generator, $php);
|
|
|
|
$this->assertEquals($classes, array_keys($p->getValue($this->_generator)));
|
|
|
|
}
|
|
|
|
|
2012-04-19 03:39:21 +04:00
|
|
|
/**
|
|
|
|
* @group DDC-1784
|
|
|
|
*/
|
|
|
|
public function testGenerateEntityWithSequenceGenerator()
|
|
|
|
{
|
|
|
|
$metadata = new ClassMetadataInfo($this->_namespace . '\DDC1784Entity');
|
|
|
|
$metadata->namespace = $this->_namespace;
|
|
|
|
$metadata->mapField(array('fieldName' => 'id', 'type' => 'integer', 'id' => true));
|
|
|
|
$metadata->setIdGeneratorType(ClassMetadataInfo::GENERATOR_TYPE_SEQUENCE);
|
|
|
|
$metadata->setSequenceGeneratorDefinition(array(
|
|
|
|
'sequenceName' => 'DDC1784_ID_SEQ',
|
|
|
|
'allocationSize' => 1,
|
|
|
|
'initialValue' => 2
|
|
|
|
));
|
|
|
|
$this->_generator->writeEntityClass($metadata, $this->_tmpDir);
|
|
|
|
|
|
|
|
$filename = $this->_tmpDir . DIRECTORY_SEPARATOR
|
|
|
|
. $this->_namespace . DIRECTORY_SEPARATOR . 'DDC1784Entity.php';
|
2013-03-31 03:47:45 +04:00
|
|
|
|
2012-04-19 03:39:21 +04:00
|
|
|
$this->assertFileExists($filename);
|
|
|
|
require_once $filename;
|
|
|
|
|
|
|
|
|
|
|
|
$reflection = new \ReflectionProperty($metadata->name, 'id');
|
|
|
|
$docComment = $reflection->getDocComment();
|
|
|
|
|
|
|
|
$this->assertContains('@Id', $docComment);
|
|
|
|
$this->assertContains('@Column(name="id", type="integer")', $docComment);
|
|
|
|
$this->assertContains('@GeneratedValue(strategy="SEQUENCE")', $docComment);
|
|
|
|
$this->assertContains('@SequenceGenerator(sequenceName="DDC1784_ID_SEQ", allocationSize=1, initialValue=2)', $docComment);
|
|
|
|
}
|
|
|
|
|
2012-10-20 22:37:13 +04:00
|
|
|
/**
|
|
|
|
* @group DDC-2079
|
|
|
|
*/
|
|
|
|
public function testGenerateEntityWithMultipleInverseJoinColumns()
|
|
|
|
{
|
|
|
|
$metadata = new ClassMetadataInfo($this->_namespace . '\DDC2079Entity');
|
|
|
|
$metadata->namespace = $this->_namespace;
|
|
|
|
$metadata->mapField(array('fieldName' => 'id', 'type' => 'integer', 'id' => true));
|
|
|
|
$metadata->setIdGeneratorType(ClassMetadataInfo::GENERATOR_TYPE_SEQUENCE);
|
|
|
|
$metadata->mapManyToMany(array(
|
|
|
|
'fieldName' => 'centroCustos',
|
|
|
|
'targetEntity' => 'DDC2079CentroCusto',
|
|
|
|
'joinTable' => array(
|
|
|
|
'name' => 'unidade_centro_custo',
|
|
|
|
'joinColumns' => array(
|
|
|
|
array('name' => 'idorcamento', 'referencedColumnName' => 'idorcamento'),
|
|
|
|
array('name' => 'idunidade', 'referencedColumnName' => 'idunidade')
|
|
|
|
),
|
|
|
|
'inverseJoinColumns' => array(
|
|
|
|
array('name' => 'idcentrocusto', 'referencedColumnName' => 'idcentrocusto'),
|
|
|
|
array('name' => 'idpais', 'referencedColumnName' => 'idpais'),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
));
|
|
|
|
$this->_generator->writeEntityClass($metadata, $this->_tmpDir);
|
|
|
|
|
|
|
|
$filename = $this->_tmpDir . DIRECTORY_SEPARATOR
|
|
|
|
. $this->_namespace . DIRECTORY_SEPARATOR . 'DDC2079Entity.php';
|
|
|
|
|
|
|
|
$this->assertFileExists($filename);
|
|
|
|
require_once $filename;
|
|
|
|
|
2012-10-20 22:44:09 +04:00
|
|
|
$property = new \ReflectionProperty($metadata->name, 'centroCustos');
|
|
|
|
$docComment = $property->getDocComment();
|
2013-03-31 03:47:45 +04:00
|
|
|
|
2012-10-20 22:37:13 +04:00
|
|
|
//joinColumns
|
|
|
|
$this->assertContains('@JoinColumn(name="idorcamento", referencedColumnName="idorcamento"),', $docComment);
|
|
|
|
$this->assertContains('@JoinColumn(name="idunidade", referencedColumnName="idunidade")', $docComment);
|
|
|
|
//inverseJoinColumns
|
|
|
|
$this->assertContains('@JoinColumn(name="idcentrocusto", referencedColumnName="idcentrocusto"),', $docComment);
|
|
|
|
$this->assertContains('@JoinColumn(name="idpais", referencedColumnName="idpais")', $docComment);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2012-11-27 20:29:02 +04:00
|
|
|
/**
|
|
|
|
* @group DDC-2172
|
|
|
|
*/
|
|
|
|
public function testGetInheritanceTypeString()
|
|
|
|
{
|
|
|
|
$reflection = new \ReflectionClass('\Doctrine\ORM\Mapping\ClassMetadata');
|
|
|
|
$method = new \ReflectionMethod($this->_generator, 'getInheritanceTypeString');
|
|
|
|
$constants = $reflection->getConstants();
|
|
|
|
$pattern = '/^INHERITANCE_TYPE_/';
|
|
|
|
|
|
|
|
$method->setAccessible(true);
|
|
|
|
|
|
|
|
foreach ($constants as $name => $value) {
|
2012-11-27 20:38:18 +04:00
|
|
|
if( ! preg_match($pattern, $name)) {
|
|
|
|
continue;
|
2012-11-27 20:29:02 +04:00
|
|
|
}
|
|
|
|
|
2012-11-27 20:38:18 +04:00
|
|
|
$expected = preg_replace($pattern, '', $name);
|
|
|
|
$actual = $method->invoke($this->_generator, $value);
|
2012-11-27 20:29:02 +04:00
|
|
|
|
|
|
|
$this->assertEquals($expected, $actual);
|
|
|
|
}
|
|
|
|
|
2012-11-27 20:38:18 +04:00
|
|
|
$this->setExpectedException('\InvalidArgumentException', 'Invalid provided InheritanceType: INVALID');
|
|
|
|
$method->invoke($this->_generator, 'INVALID');
|
2012-11-27 20:29:02 +04:00
|
|
|
}
|
|
|
|
|
2012-11-27 20:38:18 +04:00
|
|
|
/**
|
|
|
|
* @group DDC-2172
|
|
|
|
*/
|
2012-11-27 20:29:02 +04:00
|
|
|
public function testGetChangeTrackingPolicyString()
|
|
|
|
{
|
|
|
|
$reflection = new \ReflectionClass('\Doctrine\ORM\Mapping\ClassMetadata');
|
|
|
|
$method = new \ReflectionMethod($this->_generator, 'getChangeTrackingPolicyString');
|
|
|
|
$constants = $reflection->getConstants();
|
|
|
|
$pattern = '/^CHANGETRACKING_/';
|
|
|
|
|
|
|
|
$method->setAccessible(true);
|
|
|
|
|
|
|
|
foreach ($constants as $name => $value) {
|
2012-11-27 20:38:18 +04:00
|
|
|
if( ! preg_match($pattern, $name)) {
|
|
|
|
continue;
|
2012-11-27 20:29:02 +04:00
|
|
|
}
|
|
|
|
|
2012-11-27 20:38:18 +04:00
|
|
|
$expected = preg_replace($pattern, '', $name);
|
|
|
|
$actual = $method->invoke($this->_generator, $value);
|
2012-11-27 20:29:02 +04:00
|
|
|
|
|
|
|
$this->assertEquals($expected, $actual);
|
|
|
|
}
|
|
|
|
|
2012-11-27 20:38:18 +04:00
|
|
|
$this->setExpectedException('\InvalidArgumentException', 'Invalid provided ChangeTrackingPolicy: INVALID');
|
|
|
|
$method->invoke($this->_generator, 'INVALID');
|
2012-11-27 20:29:02 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @group DDC-2172
|
|
|
|
*/
|
|
|
|
public function testGetIdGeneratorTypeString()
|
|
|
|
{
|
|
|
|
$reflection = new \ReflectionClass('\Doctrine\ORM\Mapping\ClassMetadata');
|
|
|
|
$method = new \ReflectionMethod($this->_generator, 'getIdGeneratorTypeString');
|
|
|
|
$constants = $reflection->getConstants();
|
|
|
|
$pattern = '/^GENERATOR_TYPE_/';
|
|
|
|
|
|
|
|
$method->setAccessible(true);
|
|
|
|
|
|
|
|
foreach ($constants as $name => $value) {
|
2012-11-27 20:38:18 +04:00
|
|
|
if( ! preg_match($pattern, $name)) {
|
|
|
|
continue;
|
2012-11-27 20:29:02 +04:00
|
|
|
}
|
|
|
|
|
2012-11-27 20:38:18 +04:00
|
|
|
$expected = preg_replace($pattern, '', $name);
|
|
|
|
$actual = $method->invoke($this->_generator, $value);
|
2012-11-27 20:29:02 +04:00
|
|
|
|
|
|
|
$this->assertEquals($expected, $actual);
|
|
|
|
}
|
|
|
|
|
2012-11-27 20:38:18 +04:00
|
|
|
$this->setExpectedException('\InvalidArgumentException', 'Invalid provided IdGeneratorType: INVALID');
|
|
|
|
$method->invoke($this->_generator, 'INVALID');
|
2012-11-27 20:29:02 +04:00
|
|
|
}
|
|
|
|
|
2012-04-01 20:29:49 +04:00
|
|
|
/**
|
2012-04-01 21:59:21 +04:00
|
|
|
* @dataProvider getEntityTypeAliasDataProvider
|
|
|
|
*
|
2012-04-01 20:29:49 +04:00
|
|
|
* @group DDC-1694
|
|
|
|
*/
|
2012-04-01 21:59:21 +04:00
|
|
|
public function testEntityTypeAlias(array $field)
|
2012-04-01 20:29:49 +04:00
|
|
|
{
|
2012-04-01 21:59:21 +04:00
|
|
|
$metadata = $this->generateEntityTypeFixture($field);
|
|
|
|
$path = $this->_tmpDir . '/'. $this->_namespace . '/EntityType.php';
|
|
|
|
|
|
|
|
$this->assertFileExists($path);
|
|
|
|
require_once $path;
|
2012-04-01 20:29:49 +04:00
|
|
|
|
2012-04-01 21:59:21 +04:00
|
|
|
$entity = new $metadata->name;
|
|
|
|
$reflClass = new \ReflectionClass($metadata->name);
|
2013-03-31 03:47:45 +04:00
|
|
|
|
2012-04-01 21:59:21 +04:00
|
|
|
$type = $field['phpType'];
|
|
|
|
$name = $field['fieldName'];
|
|
|
|
$value = $field['value'];
|
|
|
|
$getter = "get" . ucfirst($name);
|
|
|
|
$setter = "set" . ucfirst($name);
|
|
|
|
|
|
|
|
$this->assertPhpDocVarType($type, $reflClass->getProperty($name));
|
|
|
|
$this->assertPhpDocParamType($type, $reflClass->getMethod($setter));
|
|
|
|
$this->assertPhpDocReturnType($type, $reflClass->getMethod($getter));
|
|
|
|
|
|
|
|
$this->assertSame($entity, $entity->{$setter}($value));
|
|
|
|
$this->assertEquals($value, $entity->{$getter}());
|
|
|
|
}
|
2012-04-19 03:39:21 +04:00
|
|
|
|
2013-03-31 03:47:45 +04:00
|
|
|
/**
|
|
|
|
* @group DDC-2372
|
|
|
|
*/
|
|
|
|
public function testTraitPropertiesAndMethodsAreNotDuplicated()
|
|
|
|
{
|
2013-04-19 16:49:32 +04:00
|
|
|
$cmf = new ClassMetadataFactory();
|
|
|
|
$em = $this->_getTestEntityManager();
|
|
|
|
$cmf->setEntityManager($em);
|
2013-03-31 03:47:45 +04:00
|
|
|
|
2013-04-19 16:49:32 +04:00
|
|
|
$user = new DDC2372User();
|
|
|
|
$metadata = $cmf->getMetadataFor(get_class($user));
|
|
|
|
$metadata->name = $this->_namespace . "\DDC2372User";
|
|
|
|
$metadata->namespace = $this->_namespace;
|
2013-03-31 03:47:45 +04:00
|
|
|
|
2013-04-19 16:49:32 +04:00
|
|
|
$this->_generator->writeEntityClass($metadata, $this->_tmpDir);
|
2013-03-31 03:47:45 +04:00
|
|
|
|
2013-04-19 16:49:32 +04:00
|
|
|
$this->assertFileExists($this->_tmpDir . "/" . $this->_namespace . "/DDC2372User.php");
|
|
|
|
require $this->_tmpDir . "/" . $this->_namespace . "/DDC2372User.php";
|
2013-03-31 03:47:45 +04:00
|
|
|
|
2013-04-19 16:49:32 +04:00
|
|
|
$reflClass = new \ReflectionClass($metadata->name);
|
2013-03-31 03:47:45 +04:00
|
|
|
|
2013-08-20 14:15:17 +04:00
|
|
|
$this->assertSame($reflClass->hasProperty('address'), false);
|
|
|
|
$this->assertSame($reflClass->hasMethod('setAddress'), false);
|
|
|
|
$this->assertSame($reflClass->hasMethod('getAddress'), false);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @group DDC-2372
|
|
|
|
*/
|
|
|
|
public function testTraitPropertiesAndMethodsAreNotDuplicatedInChildClasses()
|
|
|
|
{
|
|
|
|
$cmf = new ClassMetadataFactory();
|
|
|
|
$em = $this->_getTestEntityManager();
|
|
|
|
$cmf->setEntityManager($em);
|
|
|
|
|
|
|
|
$user = new DDC2372Admin();
|
|
|
|
$metadata = $cmf->getMetadataFor(get_class($user));
|
|
|
|
$metadata->name = $this->_namespace . "\DDC2372Admin";
|
|
|
|
$metadata->namespace = $this->_namespace;
|
|
|
|
|
|
|
|
$this->_generator->writeEntityClass($metadata, $this->_tmpDir);
|
|
|
|
|
|
|
|
$this->assertFileExists($this->_tmpDir . "/" . $this->_namespace . "/DDC2372Admin.php");
|
|
|
|
require $this->_tmpDir . "/" . $this->_namespace . "/DDC2372Admin.php";
|
|
|
|
|
|
|
|
$reflClass = new \ReflectionClass($metadata->name);
|
|
|
|
|
2013-04-19 16:49:32 +04:00
|
|
|
$this->assertSame($reflClass->hasProperty('address'), false);
|
|
|
|
$this->assertSame($reflClass->hasMethod('setAddress'), false);
|
|
|
|
$this->assertSame($reflClass->hasMethod('getAddress'), false);
|
2013-03-31 03:47:45 +04:00
|
|
|
}
|
|
|
|
|
2014-08-03 18:02:33 +04:00
|
|
|
/**
|
|
|
|
* @group DDC-1590
|
|
|
|
*/
|
|
|
|
public function testMethodsAndPropertiesAreNotDuplicatedInChildClasses()
|
|
|
|
{
|
|
|
|
$cmf = new ClassMetadataFactory();
|
|
|
|
$em = $this->_getTestEntityManager();
|
|
|
|
|
|
|
|
$cmf->setEntityManager($em);
|
|
|
|
|
|
|
|
$ns = $this->_namespace;
|
|
|
|
$nsdir = $this->_tmpDir . '/' . $ns;
|
|
|
|
|
|
|
|
$content = str_replace(
|
|
|
|
'namespace Doctrine\Tests\Models\DDC1590',
|
2014-08-04 21:18:26 +04:00
|
|
|
'namespace ' . $ns,
|
2014-08-03 18:02:33 +04:00
|
|
|
file_get_contents(__DIR__ . '/../../Models/DDC1590/DDC1590User.php')
|
|
|
|
);
|
|
|
|
|
|
|
|
$fname = $nsdir . "/DDC1590User.php";
|
|
|
|
file_put_contents($fname, $content);
|
|
|
|
require $fname;
|
|
|
|
|
|
|
|
|
|
|
|
$metadata = $cmf->getMetadataFor($ns . '\DDC1590User');
|
|
|
|
$this->_generator->writeEntityClass($metadata, $this->_tmpDir);
|
|
|
|
|
|
|
|
// class DDC1590User extends DDC1590Entity { ... }
|
|
|
|
$source = file_get_contents($fname);
|
|
|
|
|
|
|
|
// class _DDC1590User extends DDC1590Entity { ... }
|
|
|
|
$source2 = str_replace('class DDC1590User', 'class _DDC1590User', $source);
|
2014-08-04 21:18:26 +04:00
|
|
|
$fname2 = $nsdir . "/_DDC1590User.php";
|
2014-08-03 18:02:33 +04:00
|
|
|
file_put_contents($fname2, $source2);
|
|
|
|
require $fname2;
|
|
|
|
|
|
|
|
// class __DDC1590User { ... }
|
|
|
|
$source3 = str_replace('class DDC1590User extends DDC1590Entity', 'class __DDC1590User', $source);
|
2014-08-04 21:18:26 +04:00
|
|
|
$fname3 = $nsdir . "/__DDC1590User.php";
|
2014-08-03 18:02:33 +04:00
|
|
|
file_put_contents($fname3, $source3);
|
|
|
|
require $fname3;
|
|
|
|
|
|
|
|
|
|
|
|
// class _DDC1590User extends DDC1590Entity { ... }
|
|
|
|
$rc2 = new \ReflectionClass($ns.'\_DDC1590User');
|
|
|
|
|
2014-08-09 14:27:38 +04:00
|
|
|
$this->assertTrue($rc2->hasProperty('name'));
|
|
|
|
$this->assertTrue($rc2->hasProperty('id'));
|
|
|
|
$this->assertTrue($rc2->hasProperty('created_at'));
|
2014-08-03 18:02:33 +04:00
|
|
|
|
2014-08-09 14:27:38 +04:00
|
|
|
$this->assertTrue($rc2->hasMethod('getName'));
|
|
|
|
$this->assertTrue($rc2->hasMethod('setName'));
|
|
|
|
$this->assertTrue($rc2->hasMethod('getId'));
|
|
|
|
$this->assertFalse($rc2->hasMethod('setId'));
|
|
|
|
$this->assertTrue($rc2->hasMethod('getCreatedAt'));
|
|
|
|
$this->assertTrue($rc2->hasMethod('setCreatedAt'));
|
2014-08-03 18:02:33 +04:00
|
|
|
|
|
|
|
|
|
|
|
// class __DDC1590User { ... }
|
|
|
|
$rc3 = new \ReflectionClass($ns.'\__DDC1590User');
|
|
|
|
|
2014-08-09 14:27:38 +04:00
|
|
|
$this->assertTrue($rc3->hasProperty('name'));
|
|
|
|
$this->assertFalse($rc3->hasProperty('id'));
|
|
|
|
$this->assertFalse($rc3->hasProperty('created_at'));
|
2014-08-03 18:02:33 +04:00
|
|
|
|
2014-08-09 14:27:38 +04:00
|
|
|
$this->assertTrue($rc3->hasMethod('getName'));
|
|
|
|
$this->assertTrue($rc3->hasMethod('setName'));
|
|
|
|
$this->assertFalse($rc3->hasMethod('getId'));
|
|
|
|
$this->assertFalse($rc3->hasMethod('setId'));
|
|
|
|
$this->assertFalse($rc3->hasMethod('getCreatedAt'));
|
|
|
|
$this->assertFalse($rc3->hasMethod('setCreatedAt'));
|
2014-08-03 18:02:33 +04:00
|
|
|
}
|
2014-09-12 22:29:37 +04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @group DDC-3304
|
|
|
|
*/
|
|
|
|
public function testGeneratedMutableEmbeddablesClass()
|
|
|
|
{
|
|
|
|
$embeddedMetadata = $this->generateTestEmbeddableFixture();
|
|
|
|
$metadata = $this->generateIsbnEmbeddableFixture(array('test' => $embeddedMetadata));
|
|
|
|
|
|
|
|
$isbn = $this->newInstance($metadata);
|
|
|
|
|
|
|
|
$this->assertTrue(class_exists($metadata->name), "Class does not exist.");
|
|
|
|
$this->assertFalse(method_exists($metadata->name, '__construct'), "EntityGeneratorIsbn::__construct present.");
|
|
|
|
$this->assertTrue(method_exists($metadata->name, 'getPrefix'), "EntityGeneratorIsbn::getPrefix() missing.");
|
|
|
|
$this->assertTrue(method_exists($metadata->name, 'setPrefix'), "EntityGeneratorIsbn::setPrefix() missing.");
|
|
|
|
$this->assertTrue(method_exists($metadata->name, 'getGroupNumber'), "EntityGeneratorIsbn::getGroupNumber() missing.");
|
|
|
|
$this->assertTrue(method_exists($metadata->name, 'setGroupNumber'), "EntityGeneratorIsbn::setGroupNumber() missing.");
|
|
|
|
$this->assertTrue(method_exists($metadata->name, 'getPublisherNumber'), "EntityGeneratorIsbn::getPublisherNumber() missing.");
|
|
|
|
$this->assertTrue(method_exists($metadata->name, 'setPublisherNumber'), "EntityGeneratorIsbn::setPublisherNumber() missing.");
|
|
|
|
$this->assertTrue(method_exists($metadata->name, 'getTitleNumber'), "EntityGeneratorIsbn::getTitleNumber() missing.");
|
|
|
|
$this->assertTrue(method_exists($metadata->name, 'setTitleNumber'), "EntityGeneratorIsbn::setTitleNumber() missing.");
|
|
|
|
$this->assertTrue(method_exists($metadata->name, 'getCheckDigit'), "EntityGeneratorIsbn::getCheckDigit() missing.");
|
|
|
|
$this->assertTrue(method_exists($metadata->name, 'setCheckDigit'), "EntityGeneratorIsbn::setCheckDigit() missing.");
|
|
|
|
$this->assertTrue(method_exists($metadata->name, 'getTest'), "EntityGeneratorIsbn::getTest() missing.");
|
|
|
|
$this->assertTrue(method_exists($metadata->name, 'setTest'), "EntityGeneratorIsbn::setTest() missing.");
|
|
|
|
|
|
|
|
$isbn->setPrefix(978);
|
|
|
|
$this->assertSame(978, $isbn->getPrefix());
|
|
|
|
|
|
|
|
$this->newInstance($embeddedMetadata);
|
|
|
|
$test = new $embeddedMetadata->name();
|
|
|
|
|
|
|
|
$isbn->setTest($test);
|
|
|
|
$this->assertSame($test, $isbn->getTest());
|
|
|
|
|
|
|
|
$reflMethod = new \ReflectionMethod($metadata->name, 'setTest');
|
|
|
|
$reflParameters = $reflMethod->getParameters();
|
|
|
|
$this->assertEquals($embeddedMetadata->name, $reflParameters[0]->getClass()->name);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @group DDC-3304
|
|
|
|
*/
|
|
|
|
public function testGeneratedImmutableEmbeddablesClass()
|
|
|
|
{
|
|
|
|
$this->_generator->setEmbeddablesImmutable(true);
|
|
|
|
$embeddedMetadata = $this->generateTestEmbeddableFixture();
|
|
|
|
$metadata = $this->generateIsbnEmbeddableFixture(array('test' => $embeddedMetadata));
|
|
|
|
|
|
|
|
$this->loadEntityClass($embeddedMetadata);
|
|
|
|
$this->loadEntityClass($metadata);
|
|
|
|
|
|
|
|
$this->assertTrue(class_exists($metadata->name), "Class does not exist.");
|
|
|
|
$this->assertTrue(method_exists($metadata->name, '__construct'), "EntityGeneratorIsbn::__construct missing.");
|
|
|
|
$this->assertTrue(method_exists($metadata->name, 'getPrefix'), "EntityGeneratorIsbn::getPrefix() missing.");
|
|
|
|
$this->assertFalse(method_exists($metadata->name, 'setPrefix'), "EntityGeneratorIsbn::setPrefix() present.");
|
|
|
|
$this->assertTrue(method_exists($metadata->name, 'getGroupNumber'), "EntityGeneratorIsbn::getGroupNumber() missing.");
|
|
|
|
$this->assertFalse(method_exists($metadata->name, 'setGroupNumber'), "EntityGeneratorIsbn::setGroupNumber() present.");
|
|
|
|
$this->assertTrue(method_exists($metadata->name, 'getPublisherNumber'), "EntityGeneratorIsbn::getPublisherNumber() missing.");
|
|
|
|
$this->assertFalse(method_exists($metadata->name, 'setPublisherNumber'), "EntityGeneratorIsbn::setPublisherNumber() present.");
|
|
|
|
$this->assertTrue(method_exists($metadata->name, 'getTitleNumber'), "EntityGeneratorIsbn::getTitleNumber() missing.");
|
|
|
|
$this->assertFalse(method_exists($metadata->name, 'setTitleNumber'), "EntityGeneratorIsbn::setTitleNumber() present.");
|
|
|
|
$this->assertTrue(method_exists($metadata->name, 'getCheckDigit'), "EntityGeneratorIsbn::getCheckDigit() missing.");
|
|
|
|
$this->assertFalse(method_exists($metadata->name, 'setCheckDigit'), "EntityGeneratorIsbn::setCheckDigit() present.");
|
|
|
|
$this->assertTrue(method_exists($metadata->name, 'getTest'), "EntityGeneratorIsbn::getTest() missing.");
|
|
|
|
$this->assertFalse(method_exists($metadata->name, 'setTest'), "EntityGeneratorIsbn::setTest() present.");
|
|
|
|
|
|
|
|
$test = new $embeddedMetadata->name(1, new \DateTime());
|
|
|
|
$isbn = new $metadata->name($test, 978, 3, 12, 732320, 83);
|
|
|
|
|
|
|
|
$reflMethod = new \ReflectionMethod($isbn, '__construct');
|
|
|
|
$reflParameters = $reflMethod->getParameters();
|
|
|
|
|
|
|
|
$this->assertCount(6, $reflParameters);
|
|
|
|
|
|
|
|
$this->assertSame($embeddedMetadata->name, $reflParameters[0]->getClass()->name);
|
|
|
|
$this->assertSame('test', $reflParameters[0]->getName());
|
|
|
|
$this->assertFalse($reflParameters[0]->isOptional());
|
|
|
|
|
|
|
|
$this->assertSame('prefix', $reflParameters[1]->getName());
|
|
|
|
$this->assertFalse($reflParameters[1]->isOptional());
|
|
|
|
|
|
|
|
$this->assertSame('groupNumber', $reflParameters[2]->getName());
|
|
|
|
$this->assertFalse($reflParameters[2]->isOptional());
|
|
|
|
|
|
|
|
$this->assertSame('publisherNumber', $reflParameters[3]->getName());
|
|
|
|
$this->assertFalse($reflParameters[3]->isOptional());
|
|
|
|
|
|
|
|
$this->assertSame('titleNumber', $reflParameters[4]->getName());
|
|
|
|
$this->assertFalse($reflParameters[4]->isOptional());
|
|
|
|
|
|
|
|
$this->assertSame('checkDigit', $reflParameters[5]->getName());
|
|
|
|
$this->assertFalse($reflParameters[5]->isOptional());
|
|
|
|
|
|
|
|
$reflMethod = new \ReflectionMethod($test, '__construct');
|
|
|
|
$reflParameters = $reflMethod->getParameters();
|
|
|
|
|
|
|
|
$this->assertCount(4, $reflParameters);
|
|
|
|
|
|
|
|
$this->assertSame('field1', $reflParameters[0]->getName());
|
|
|
|
$this->assertFalse($reflParameters[0]->isOptional());
|
|
|
|
|
|
|
|
$this->assertSame('DateTime', $reflParameters[1]->getClass()->name);
|
|
|
|
$this->assertSame('field3', $reflParameters[1]->getName());
|
|
|
|
$this->assertFalse($reflParameters[1]->isOptional());
|
|
|
|
|
|
|
|
$this->assertSame('field2', $reflParameters[2]->getName());
|
|
|
|
$this->assertTrue($reflParameters[2]->isOptional());
|
|
|
|
|
|
|
|
$this->assertSame('DateTime', $reflParameters[3]->getClass()->name);
|
|
|
|
$this->assertSame('field4', $reflParameters[3]->getName());
|
|
|
|
$this->assertTrue($reflParameters[3]->isOptional());
|
|
|
|
}
|
|
|
|
|
2012-04-01 21:59:21 +04:00
|
|
|
/**
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function getEntityTypeAliasDataProvider()
|
|
|
|
{
|
2012-04-01 22:09:23 +04:00
|
|
|
return array(
|
|
|
|
array(array(
|
2012-04-01 21:59:21 +04:00
|
|
|
'fieldName' => 'datetimetz',
|
|
|
|
'phpType' => '\\DateTime',
|
|
|
|
'dbType' => 'datetimetz',
|
|
|
|
'value' => new \DateTime
|
2012-04-01 22:09:23 +04:00
|
|
|
)),
|
|
|
|
array(array(
|
2012-04-01 21:59:21 +04:00
|
|
|
'fieldName' => 'datetime',
|
|
|
|
'phpType' => '\\DateTime',
|
|
|
|
'dbType' => 'datetime',
|
|
|
|
'value' => new \DateTime
|
2012-04-01 22:09:23 +04:00
|
|
|
)),
|
|
|
|
array(array(
|
2013-03-31 03:47:45 +04:00
|
|
|
'fieldName' => 'date',
|
2012-04-01 21:59:21 +04:00
|
|
|
'phpType' => '\\DateTime',
|
|
|
|
'dbType' => 'date',
|
|
|
|
'value' => new \DateTime
|
2012-04-01 22:09:23 +04:00
|
|
|
)),
|
|
|
|
array(array(
|
2013-03-31 03:47:45 +04:00
|
|
|
'fieldName' => 'time',
|
2012-04-01 21:59:21 +04:00
|
|
|
'phpType' => '\DateTime',
|
|
|
|
'dbType' => 'time',
|
|
|
|
'value' => new \DateTime
|
2012-04-01 22:09:23 +04:00
|
|
|
)),
|
|
|
|
array(array(
|
2013-03-31 03:47:45 +04:00
|
|
|
'fieldName' => 'object',
|
2012-04-01 21:59:21 +04:00
|
|
|
'phpType' => '\stdClass',
|
|
|
|
'dbType' => 'object',
|
|
|
|
'value' => new \stdClass()
|
2012-04-01 22:09:23 +04:00
|
|
|
)),
|
|
|
|
array(array(
|
2013-03-31 03:47:45 +04:00
|
|
|
'fieldName' => 'bigint',
|
2012-04-01 21:59:21 +04:00
|
|
|
'phpType' => 'integer',
|
|
|
|
'dbType' => 'bigint',
|
|
|
|
'value' => 11
|
2012-04-01 22:09:23 +04:00
|
|
|
)),
|
|
|
|
array(array(
|
2013-03-31 03:47:45 +04:00
|
|
|
'fieldName' => 'smallint',
|
2012-04-01 21:59:21 +04:00
|
|
|
'phpType' => 'integer',
|
2012-04-01 22:09:23 +04:00
|
|
|
'dbType' => 'smallint',
|
2012-04-01 21:59:21 +04:00
|
|
|
'value' => 22
|
2012-04-01 22:09:23 +04:00
|
|
|
)),
|
|
|
|
array(array(
|
2013-03-31 03:47:45 +04:00
|
|
|
'fieldName' => 'text',
|
2012-04-01 21:59:21 +04:00
|
|
|
'phpType' => 'string',
|
|
|
|
'dbType' => 'text',
|
|
|
|
'value' => 'text'
|
2012-04-01 22:09:23 +04:00
|
|
|
)),
|
|
|
|
array(array(
|
2013-03-31 03:47:45 +04:00
|
|
|
'fieldName' => 'blob',
|
2012-04-01 21:59:21 +04:00
|
|
|
'phpType' => 'string',
|
|
|
|
'dbType' => 'blob',
|
|
|
|
'value' => 'blob'
|
2012-04-01 22:09:23 +04:00
|
|
|
)),
|
|
|
|
array(array(
|
|
|
|
'fieldName' => 'decimal',
|
2013-08-03 17:44:02 +04:00
|
|
|
'phpType' => 'string',
|
2012-04-01 22:09:23 +04:00
|
|
|
'dbType' => 'decimal',
|
2013-08-06 18:23:15 +04:00
|
|
|
'value' => '12.34'
|
2012-04-01 21:59:21 +04:00
|
|
|
),
|
|
|
|
));
|
2012-04-01 20:29:49 +04:00
|
|
|
}
|
2012-04-01 21:59:21 +04:00
|
|
|
|
2011-04-30 12:42:38 +04:00
|
|
|
public function getParseTokensInEntityFileData()
|
|
|
|
{
|
|
|
|
return array(
|
|
|
|
array(
|
|
|
|
'<?php namespace Foo\Bar; class Baz {}',
|
|
|
|
array('Foo\Bar\Baz'),
|
|
|
|
),
|
|
|
|
array(
|
|
|
|
'<?php namespace Foo\Bar; use Foo; class Baz {}',
|
|
|
|
array('Foo\Bar\Baz'),
|
|
|
|
),
|
|
|
|
array(
|
|
|
|
'<?php namespace /*Comment*/ Foo\Bar; /** Foo */class /* Comment */ Baz {}',
|
|
|
|
array('Foo\Bar\Baz'),
|
|
|
|
),
|
|
|
|
array(
|
|
|
|
'
|
|
|
|
<?php namespace
|
|
|
|
/*Comment*/
|
|
|
|
Foo\Bar
|
|
|
|
;
|
|
|
|
|
|
|
|
/** Foo */
|
|
|
|
class
|
|
|
|
/* Comment */
|
|
|
|
Baz {}
|
|
|
|
',
|
|
|
|
array('Foo\Bar\Baz'),
|
|
|
|
),
|
2015-01-14 13:56:54 +03:00
|
|
|
array(
|
|
|
|
'
|
|
|
|
<?php namespace Foo\Bar; class Baz {
|
|
|
|
public static function someMethod(){
|
|
|
|
return self::class;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
',
|
|
|
|
array('Foo\Bar\Baz'),
|
|
|
|
),
|
2011-04-30 12:42:38 +04:00
|
|
|
);
|
|
|
|
}
|
2012-04-01 20:29:49 +04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @param string $type
|
|
|
|
* @param \ReflectionProperty $property
|
|
|
|
*/
|
|
|
|
private function assertPhpDocVarType($type, \ReflectionProperty $property)
|
|
|
|
{
|
|
|
|
$this->assertEquals(1, preg_match('/@var\s+([^\s]+)/',$property->getDocComment(), $matches));
|
|
|
|
$this->assertEquals($type, $matches[1]);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param string $type
|
|
|
|
* @param \ReflectionProperty $method
|
|
|
|
*/
|
|
|
|
private function assertPhpDocReturnType($type, \ReflectionMethod $method)
|
|
|
|
{
|
|
|
|
$this->assertEquals(1, preg_match('/@return\s+([^\s]+)/', $method->getDocComment(), $matches));
|
|
|
|
$this->assertEquals($type, $matches[1]);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param string $type
|
|
|
|
* @param \ReflectionProperty $method
|
|
|
|
*/
|
|
|
|
private function assertPhpDocParamType($type, \ReflectionMethod $method)
|
|
|
|
{
|
|
|
|
$this->assertEquals(1, preg_match('/@param\s+([^\s]+)/', $method->getDocComment(), $matches));
|
|
|
|
$this->assertEquals($type, $matches[1]);
|
|
|
|
}
|
2010-03-20 01:38:45 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
class EntityGeneratorAuthor {}
|
2012-01-03 00:32:18 +04:00
|
|
|
class EntityGeneratorComment {}
|