Refactored DDC-671 model to become a first-class modelset, we dont have one with mapped superclass yet.
This commit is contained in:
parent
7dc8ef1db9
commit
39f732ab91
10 changed files with 159 additions and 100 deletions
|
@ -0,0 +1,49 @@
|
||||||
|
<?php
|
||||||
|
/*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||||
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||||
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||||
|
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
||||||
|
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
||||||
|
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
||||||
|
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
||||||
|
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
||||||
|
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
||||||
|
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*
|
||||||
|
* This software consists of voluntary contributions made by many individuals
|
||||||
|
* and is licensed under the LGPL. For more information, see
|
||||||
|
* <http://www.doctrine-project.org>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace Doctrine\Tests\Models\DirectoryTree;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @MappedSuperclass
|
||||||
|
*/
|
||||||
|
abstract class AbstractContentItem
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* @Id @Column(type="integer") @GeneratedValue
|
||||||
|
*/
|
||||||
|
private $id;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @ManyToOne(targetEntity="Directory")
|
||||||
|
*/
|
||||||
|
protected $parentDirectory;
|
||||||
|
|
||||||
|
/** @column(type="string") */
|
||||||
|
protected $name;
|
||||||
|
|
||||||
|
public function __get($name)
|
||||||
|
{
|
||||||
|
return $this->$name;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function __set($name, $value)
|
||||||
|
{
|
||||||
|
$this->$name = $value;
|
||||||
|
}
|
||||||
|
}
|
39
tests/Doctrine/Tests/Models/DirectoryTree/Directory.php
Normal file
39
tests/Doctrine/Tests/Models/DirectoryTree/Directory.php
Normal file
|
@ -0,0 +1,39 @@
|
||||||
|
<?php
|
||||||
|
/*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||||
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||||
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||||
|
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
||||||
|
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
||||||
|
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
||||||
|
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
||||||
|
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
||||||
|
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
||||||
|
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*
|
||||||
|
* This software consists of voluntary contributions made by many individuals
|
||||||
|
* and is licensed under the LGPL. For more information, see
|
||||||
|
* <http://www.doctrine-project.org>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace Doctrine\Tests\Models\DirectoryTree;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @Entity
|
||||||
|
*/
|
||||||
|
class Directory extends AbstractContentItem
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* @OneToMany(targetEntity="Directory", mappedBy="parent")
|
||||||
|
*/
|
||||||
|
protected $subDirectories;
|
||||||
|
/**
|
||||||
|
* @OneToMany(targetEntity="File", mappedBy="parent")
|
||||||
|
*/
|
||||||
|
protected $containedFiles;
|
||||||
|
/**
|
||||||
|
* @Column(type="string")
|
||||||
|
*/
|
||||||
|
protected $path;
|
||||||
|
}
|
30
tests/Doctrine/Tests/Models/DirectoryTree/File.php
Normal file
30
tests/Doctrine/Tests/Models/DirectoryTree/File.php
Normal file
|
@ -0,0 +1,30 @@
|
||||||
|
<?php
|
||||||
|
/*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||||
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||||
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||||
|
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
||||||
|
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
||||||
|
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
||||||
|
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
||||||
|
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
||||||
|
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
||||||
|
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*
|
||||||
|
* This software consists of voluntary contributions made by many individuals
|
||||||
|
* and is licensed under the LGPL. For more information, see
|
||||||
|
* <http://www.doctrine-project.org>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
namespace Doctrine\Tests\Models\DirectoryTree;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @Entity
|
||||||
|
*/
|
||||||
|
class File extends AbstractContentItem
|
||||||
|
{
|
||||||
|
/** @Column(type="string") */
|
||||||
|
protected $extension = "html";
|
||||||
|
}
|
|
@ -459,48 +459,3 @@ class User
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
abstract class AbstractContentItem
|
|
||||||
{
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Doctrine2 entity id
|
|
||||||
* @var integer
|
|
||||||
*/
|
|
||||||
private $id;
|
|
||||||
/**
|
|
||||||
* The parent directory
|
|
||||||
* @var Directory
|
|
||||||
*/
|
|
||||||
protected $parentDirectory;
|
|
||||||
/**
|
|
||||||
* Filename (without extension) or directory name
|
|
||||||
* @var string
|
|
||||||
*/
|
|
||||||
protected $name;
|
|
||||||
}
|
|
||||||
|
|
||||||
class Directory extends AbstractContentItem
|
|
||||||
{
|
|
||||||
|
|
||||||
protected $subDirectories;
|
|
||||||
/**
|
|
||||||
* This is a collection of files that are contained in this Directory. Files, for example, could be Pages, but even other files
|
|
||||||
* like media files (css, images etc) are possible.
|
|
||||||
*
|
|
||||||
* @var \Doctrine\Common\Collections\Collection
|
|
||||||
* @access protected
|
|
||||||
*/
|
|
||||||
protected $containedFiles;
|
|
||||||
/**
|
|
||||||
* @var string
|
|
||||||
*/
|
|
||||||
protected $url;
|
|
||||||
}
|
|
||||||
|
|
||||||
class Page extends AbstractContentItem
|
|
||||||
{
|
|
||||||
|
|
||||||
protected $extension = "html";
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
|
@ -117,25 +117,20 @@ class AnnotationDriverTest extends AbstractMappingDriverTest
|
||||||
*/
|
*/
|
||||||
public function testJoinTablesWithMappedSuperclassForAnnotationDriver()
|
public function testJoinTablesWithMappedSuperclassForAnnotationDriver()
|
||||||
{
|
{
|
||||||
|
$annotationDriver = $this->_loadDriver();
|
||||||
|
$annotationDriver->addPaths(array(__DIR__ . '/../../Models/DirectoryTree/'));
|
||||||
|
|
||||||
$em = $this->_getTestEntityManager();
|
$em = $this->_getTestEntityManager();
|
||||||
$em->getConfiguration()->setMetadataDriverImpl($this->_loadDriver());
|
$em->getConfiguration()->setMetadataDriverImpl($annotationDriver);
|
||||||
|
$factory = new \Doctrine\ORM\Mapping\ClassMetadataFactory($em);
|
||||||
|
|
||||||
$classPage = $em->getClassMetadata('Doctrine\Tests\ORM\Mapping\Page');
|
$classPage = new ClassMetadata('Doctrine\Tests\Models\DirectoryTree\File');
|
||||||
$this->assertEquals('Doctrine\Tests\ORM\Mapping\Page', $classPage->associationMappings['parentDirectory']['sourceEntity']);
|
$classPage = $factory->getMetadataFor('Doctrine\Tests\Models\DirectoryTree\File');
|
||||||
$classDirectory = $em->getClassMetadata('Doctrine\Tests\ORM\Mapping\Directory');
|
$this->assertEquals('Doctrine\Tests\Models\DirectoryTree\File', $classPage->associationMappings['parentDirectory']['sourceEntity']);
|
||||||
$this->assertEquals('Doctrine\Tests\ORM\Mapping\Directory', $classDirectory->associationMappings['parentDirectory']['sourceEntity']);
|
|
||||||
|
|
||||||
$dql = "SELECT f FROM Doctrine\Tests\ORM\Mapping\Page f JOIN f.parentDirectory d " .
|
$classDirectory = new ClassMetadata('Doctrine\Tests\Models\DirectoryTree\Directory');
|
||||||
"WHERE (d.url = :url) AND (f.extension = :extension)";
|
$classDirectory = $factory->getMetadataFor('Doctrine\Tests\Models\DirectoryTree\Directory');
|
||||||
|
$this->assertEquals('Doctrine\Tests\Models\DirectoryTree\Directory', $classDirectory->associationMappings['parentDirectory']['sourceEntity']);
|
||||||
$query = $em->createQuery($dql)
|
|
||||||
->setParameter('url', "test")
|
|
||||||
->setParameter('extension', "extension");
|
|
||||||
|
|
||||||
$this->assertEquals(
|
|
||||||
'SELECT c0_.id AS id0, c0_.extension AS extension1, c0_.parent_directory_id AS parent_directory_id2 FROM core_content_pages c0_ INNER JOIN core_content_directories c1_ ON c0_.parent_directory_id = c1_.id WHERE (c1_.url = ?) AND (c0_.extension = ?)',
|
|
||||||
$query->getSql()
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -26,25 +26,20 @@ class YamlMappingDriverTest extends AbstractMappingDriverTest
|
||||||
*/
|
*/
|
||||||
public function testJoinTablesWithMappedSuperclassForYamlDriver()
|
public function testJoinTablesWithMappedSuperclassForYamlDriver()
|
||||||
{
|
{
|
||||||
|
$yamlDriver = $this->_loadDriver();
|
||||||
|
$yamlDriver->addPaths(array(__DIR__ . DIRECTORY_SEPARATOR . 'yaml'));
|
||||||
|
|
||||||
$em = $this->_getTestEntityManager();
|
$em = $this->_getTestEntityManager();
|
||||||
$em->getConfiguration()->setMetadataDriverImpl($this->_loadDriver());
|
$em->getConfiguration()->setMetadataDriverImpl($yamlDriver);
|
||||||
|
$factory = new \Doctrine\ORM\Mapping\ClassMetadataFactory($em);
|
||||||
|
|
||||||
$classPage = $em->getClassMetadata('Doctrine\Tests\ORM\Mapping\Page');
|
$classPage = new ClassMetadata('Doctrine\Tests\Models\DirectoryTree\File');
|
||||||
$this->assertEquals('Doctrine\Tests\ORM\Mapping\Page', $classPage->associationMappings['parentDirectory']['sourceEntity']);
|
$classPage = $factory->getMetadataFor('Doctrine\Tests\Models\DirectoryTree\File');
|
||||||
$classDirectory = $em->getClassMetadata('Doctrine\Tests\ORM\Mapping\Directory');
|
$this->assertEquals('Doctrine\Tests\Models\DirectoryTree\File', $classPage->associationMappings['parentDirectory']['sourceEntity']);
|
||||||
$this->assertEquals('Doctrine\Tests\ORM\Mapping\Directory', $classDirectory->associationMappings['parentDirectory']['sourceEntity']);
|
|
||||||
|
|
||||||
$dql = "SELECT f FROM Doctrine\Tests\ORM\Mapping\Page f JOIN f.parentDirectory d " .
|
$classDirectory = new ClassMetadata('Doctrine\Tests\Models\DirectoryTree\Directory');
|
||||||
"WHERE (d.url = :url) AND (f.extension = :extension)";
|
$classDirectory = $factory->getMetadataFor('Doctrine\Tests\Models\DirectoryTree\Directory');
|
||||||
|
$this->assertEquals('Doctrine\Tests\Models\DirectoryTree\Directory', $classDirectory->associationMappings['parentDirectory']['sourceEntity']);
|
||||||
$query = $em->createQuery($dql)
|
|
||||||
->setParameter('url', "test")
|
|
||||||
->setParameter('extension', "extension");
|
|
||||||
|
|
||||||
$this->assertEquals(
|
|
||||||
'SELECT c0_.id AS id0, c0_.extension AS extension1, c0_.parent_directory_id AS parent_directory_id2 FROM core_content_pages c0_ INNER JOIN core_content_directories c1_ ON c0_.parent_directory_id = c1_.id WHERE (c1_.url = ?) AND (c0_.extension = ?)',
|
|
||||||
$query->getSql()
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,14 @@
|
||||||
|
Doctrine\Tests\Models\DirectoryTree\AbstractContentItem:
|
||||||
|
type: mappedSuperclass
|
||||||
|
id:
|
||||||
|
id:
|
||||||
|
type: integer
|
||||||
|
unsigned: true
|
||||||
|
generator:
|
||||||
|
strategy: AUTO
|
||||||
|
fields:
|
||||||
|
name:
|
||||||
|
type: string
|
||||||
|
manyToOne:
|
||||||
|
parentDirectory:
|
||||||
|
targetEntity: Doctrine\Tests\Models\DirectoryTree\Directory
|
|
@ -1,17 +1,16 @@
|
||||||
Doctrine\Tests\ORM\Mapping\Directory:
|
Doctrine\Tests\Models\DirectoryTree\Directory:
|
||||||
type: entity
|
type: entity
|
||||||
table: core_content_directories
|
|
||||||
fields:
|
fields:
|
||||||
url:
|
path:
|
||||||
type: string
|
type: string
|
||||||
length: 255
|
length: 255
|
||||||
oneToMany:
|
oneToMany:
|
||||||
subDirectories:
|
subDirectories:
|
||||||
targetEntity: Doctrine\Tests\ORM\Mapping\Directory
|
targetEntity: Doctrine\Tests\Models\DirectoryTree\Directory
|
||||||
mappedBy: parentDirectory
|
mappedBy: parentDirectory
|
||||||
cascade:
|
cascade:
|
||||||
[ all ]
|
[ all ]
|
||||||
containedFiles:
|
containedFiles:
|
||||||
targetEntity: Doctrine\Tests\ORM\Mapping\Page
|
targetEntity: Doctrine\Tests\Models\DirectoryTree\File
|
||||||
mappedBy: parentDirectory
|
mappedBy: parentDirectory
|
||||||
cascade: [ remove ]
|
cascade: [ remove ]
|
|
@ -1,6 +1,5 @@
|
||||||
Doctrine\Tests\ORM\Mapping\Page:
|
Doctrine\Tests\Models\DirectoryTree\File:
|
||||||
type: entity
|
type: entity
|
||||||
table: core_content_pages
|
|
||||||
fields:
|
fields:
|
||||||
extension:
|
extension:
|
||||||
type: string
|
type: string
|
|
@ -1,16 +0,0 @@
|
||||||
Doctrine\Tests\ORM\Mapping\AbstractContentItem:
|
|
||||||
type: mappedSuperclass
|
|
||||||
id:
|
|
||||||
id:
|
|
||||||
type: integer
|
|
||||||
unsigned: true
|
|
||||||
generator:
|
|
||||||
strategy: AUTO
|
|
||||||
fields:
|
|
||||||
# FilesystemIdentifier
|
|
||||||
manyToOne:
|
|
||||||
parentDirectory:
|
|
||||||
targetEntity: Doctrine\Tests\ORM\Mapping\Directory
|
|
||||||
joinColumn:
|
|
||||||
name: parent_directory_id
|
|
||||||
referencedColumnName: id
|
|
Loading…
Add table
Reference in a new issue