1
0
mirror of synced 2025-01-19 15:01:40 +03:00
doctrine2/tests/Doctrine/Tests/ORM/Tools/SchemaValidatorTest.php

523 lines
12 KiB
PHP
Raw Normal View History

<?php
namespace Doctrine\Tests\ORM\Tools;
use Doctrine\ORM\Tools\SchemaValidator;
class SchemaValidatorTest extends \Doctrine\Tests\OrmTestCase
{
/**
* @var EntityManager
*/
private $em = null;
/**
* @var SchemaValidator
*/
private $validator = null;
public function setUp()
{
$this->em = $this->_getTestEntityManager();
$this->validator = new SchemaValidator($this->em);
}
public function testCmsModelSet()
{
$this->em->getConfiguration()->getMetadataDriverImpl()->addPaths(array(
__DIR__ . "/../../Models/CMS"
));
$this->validator->validateMapping();
}
public function testCompanyModelSet()
{
$this->em->getConfiguration()->getMetadataDriverImpl()->addPaths(array(
__DIR__ . "/../../Models/Company"
));
$this->validator->validateMapping();
}
public function testECommerceModelSet()
{
$this->em->getConfiguration()->getMetadataDriverImpl()->addPaths(array(
__DIR__ . "/../../Models/ECommerce"
));
$this->validator->validateMapping();
}
public function testForumModelSet()
{
$this->em->getConfiguration()->getMetadataDriverImpl()->addPaths(array(
__DIR__ . "/../../Models/Forum"
));
$this->validator->validateMapping();
}
public function testNavigationModelSet()
{
$this->em->getConfiguration()->getMetadataDriverImpl()->addPaths(array(
__DIR__ . "/../../Models/Navigation"
));
$this->validator->validateMapping();
}
public function testRoutingModelSet()
{
$this->em->getConfiguration()->getMetadataDriverImpl()->addPaths(array(
__DIR__ . "/../../Models/Routing"
));
$this->validator->validateMapping();
}
/**
* @group DDC-1439
*/
public function testInvalidManyToManyJoinColumnSchema()
{
$class1 = $this->em->getClassMetadata(__NAMESPACE__ . '\InvalidEntity1');
$class2 = $this->em->getClassMetadata(__NAMESPACE__ . '\InvalidEntity2');
$ce = $this->validator->validateClass($class1);
$this->assertEquals(
array(
"The inverse join columns of the many-to-many table 'Entity1Entity2' have to contain to ALL identifier columns of the target entity 'Doctrine\Tests\ORM\Tools\InvalidEntity2', however 'key4' are missing.",
"The join columns of the many-to-many table 'Entity1Entity2' have to contain to ALL identifier columns of the source entity 'Doctrine\Tests\ORM\Tools\InvalidEntity1', however 'key2' are missing."
),
$ce
);
}
/**
* @group DDC-1439
*/
public function testInvalidToOneJoinColumnSchema()
{
$class1 = $this->em->getClassMetadata(__NAMESPACE__ . '\InvalidEntity1');
$class2 = $this->em->getClassMetadata(__NAMESPACE__ . '\InvalidEntity2');
$ce = $this->validator->validateClass($class2);
$this->assertEquals(
array(
"The referenced column name 'id' has to be a primary key column on the target entity class 'Doctrine\Tests\ORM\Tools\InvalidEntity1'.",
2014-04-11 22:26:24 +00:00
"The join columns of the association 'assoc' have to match to ALL identifier columns of the target entity 'Doctrine\Tests\ORM\Tools\InvalidEntity1', however 'key1, key2' are missing."
),
$ce
);
}
2012-01-16 22:31:14 -05:00
/**
* @group DDC-1587
*/
public function testValidOneToOneAsIdentifierSchema()
{
$class1 = $this->em->getClassMetadata(__NAMESPACE__ . '\DDC1587ValidEntity2');
$class2 = $this->em->getClassMetadata(__NAMESPACE__ . '\DDC1587ValidEntity1');
$ce = $this->validator->validateClass($class1);
$this->assertEquals(array(), $ce);
}
/**
* @group DDC-1649
*/
public function testInvalidTripleAssociationAsKeyMapping()
{
$classThree = $this->em->getClassMetadata(__NAMESPACE__ . '\DDC1649Three');
$ce = $this->validator->validateClass($classThree);
$this->assertEquals(Array(
"Cannot map association 'Doctrine\Tests\ORM\Tools\DDC1649Three#two as identifier, because the target entity 'Doctrine\Tests\ORM\Tools\DDC1649Two' also maps an association as identifier.",
"The referenced column name 'id' has to be a primary key column on the target entity class 'Doctrine\Tests\ORM\Tools\DDC1649Two'."
), $ce);
}
/**
* @group DDC-3274
*/
public function testInvalidBiDirectionalRelationMappingMissingInversedByAttribute()
{
$class = $this->em->getClassMetadata(__NAMESPACE__ . '\DDC3274One');
$ce = $this->validator->validateClass($class);
$this->assertEquals(
array(
"The field Doctrine\Tests\ORM\Tools\DDC3274One#two is on the inverse side of a bi-directional " .
"relationship, but the specified mappedBy association on the target-entity " .
"Doctrine\Tests\ORM\Tools\DDC3274Two#one does not contain the required 'inversedBy=\"two\"' attribute."
),
$ce
);
}
/**
* @group DDC-3322
*/
public function testInvalidOrderByInvalidField()
{
$class = $this->em->getClassMetadata(__NAMESPACE__ . '\DDC3322One');
$ce = $this->validator->validateClass($class);
$this->assertEquals(
array(
"The association Doctrine\Tests\ORM\Tools\DDC3322One#invalidAssoc is ordered by a foreign field " .
"invalidField that is not a field on the target entity Doctrine\Tests\ORM\Tools\DDC3322ValidEntity1."
),
$ce
);
}
/**
* @group DDC-3322
*/
public function testInvalidOrderByCollectionValuedAssociation()
{
$class = $this->em->getClassMetadata(__NAMESPACE__ . '\DDC3322Two');
$ce = $this->validator->validateClass($class);
$this->assertEquals(
array(
"The association Doctrine\Tests\ORM\Tools\DDC3322Two#invalidAssoc is ordered by a field oneToMany " .
"on Doctrine\Tests\ORM\Tools\DDC3322ValidEntity1 that is a collection-valued association."
),
$ce
);
}
/**
* @group DDC-3322
*/
public function testInvalidOrderByAssociationInverseSide()
{
$class = $this->em->getClassMetadata(__NAMESPACE__ . '\DDC3322Three');
$ce = $this->validator->validateClass($class);
$this->assertEquals(
array(
"The association Doctrine\Tests\ORM\Tools\DDC3322Three#invalidAssoc is ordered by a field oneToOneInverse " .
"on Doctrine\Tests\ORM\Tools\DDC3322ValidEntity1 that is the inverse side of an association."
),
$ce
);
}
}
/**
* @Entity
*/
class InvalidEntity1
{
/**
* @Id @Column
*/
protected $key1;
/**
* @Id @Column
*/
protected $key2;
/**
* @ManyToMany (targetEntity="InvalidEntity2")
* @JoinTable (name="Entity1Entity2",
* joinColumns={@JoinColumn(name="key1", referencedColumnName="key1")},
* inverseJoinColumns={@JoinColumn(name="key3", referencedColumnName="key3")}
* )
*/
protected $entity2;
}
/**
* @Entity
*/
class InvalidEntity2
{
/**
* @Id @Column
*/
protected $key3;
/**
* @Id @Column
*/
protected $key4;
/**
* @ManyToOne(targetEntity="InvalidEntity1")
*/
protected $assoc;
}
2012-01-16 22:31:14 -05:00
/**
* @Entity(repositoryClass="Entity\Repository\Agent")
* @Table(name="agent")
*/
class DDC1587ValidEntity1
{
/**
* @var int
*
* @Id @GeneratedValue
* @Column(name="pk", type="integer")
*/
private $pk;
/**
* @var string
*
* @Column(name="name", type="string", length=32)
*/
private $name;
/**
* @var Identifier
*
* @OneToOne(targetEntity="DDC1587ValidEntity2", cascade={"all"}, mappedBy="agent")
* @JoinColumn(name="pk", referencedColumnName="pk_agent")
*/
private $identifier;
}
/**
* @Entity
* @Table
*/
class DDC1587ValidEntity2
{
/**
* @var DDC1587ValidEntity1
*
* @Id
* @OneToOne(targetEntity="DDC1587ValidEntity1", inversedBy="identifier")
* @JoinColumn(name="pk_agent", referencedColumnName="pk", nullable=false)
*/
private $agent;
/**
* @var string
*
* @Column(name="num", type="string", length=16, nullable=true)
*/
private $num;
}
/**
* @Entity
*/
class DDC1649One
{
/**
* @Id @Column @GeneratedValue
*/
public $id;
}
/**
* @Entity
*/
class DDC1649Two
{
/** @Id @ManyToOne(targetEntity="DDC1649One")@JoinColumn(name="id", referencedColumnName="id") */
public $one;
}
/**
* @Entity
*/
class DDC1649Three
{
/** @Id @ManyToOne(targetEntity="DDC1649Two") @JoinColumn(name="id",
* referencedColumnName="id") */
private $two;
}
/**
* @Entity
*/
class DDC3274One
{
/**
* @Id @Column @GeneratedValue
*/
private $id;
/**
* @OneToMany(targetEntity="DDC3274Two", mappedBy="one")
*/
private $two;
}
/**
* @Entity
*/
class DDC3274Two
{
/**
* @Id
* @ManyToOne(targetEntity="DDC3274One")
*/
private $one;
}
/**
* @Entity
*/
class DDC3322ValidEntity1
{
/**
* @Id @Column @GeneratedValue
*/
private $id;
/**
* @ManyToOne(targetEntity="DDC3322One", inversedBy="validAssoc")
*/
private $oneValid;
/**
* @ManyToOne(targetEntity="DDC3322One", inversedBy="invalidAssoc")
*/
private $oneInvalid;
/**
* @ManyToOne(targetEntity="DDC3322Two", inversedBy="validAssoc")
*/
private $twoValid;
/**
* @ManyToOne(targetEntity="DDC3322Two", inversedBy="invalidAssoc")
*/
private $twoInvalid;
/**
* @ManyToOne(targetEntity="DDC3322Three", inversedBy="validAssoc")
*/
private $threeValid;
/**
* @ManyToOne(targetEntity="DDC3322Three", inversedBy="invalidAssoc")
*/
private $threeInvalid;
/**
* @OneToMany(targetEntity="DDC3322ValidEntity2", mappedBy="manyToOne")
*/
private $oneToMany;
/**
* @ManyToOne(targetEntity="DDC3322ValidEntity2", inversedBy="oneToMany")
*/
private $manyToOne;
/**
* @OneToOne(targetEntity="DDC3322ValidEntity2", mappedBy="oneToOneOwning")
*/
private $oneToOneInverse;
/**
* @OneToOne(targetEntity="DDC3322ValidEntity2", inversedBy="oneToOneInverse")
*/
private $oneToOneOwning;
}
/**
* @Entity
*/
class DDC3322ValidEntity2
{
/**
* @Id @Column @GeneratedValue
*/
private $id;
/**
* @ManyToOne(targetEntity="DDC3322ValidEntity1", inversedBy="oneToMany")
*/
private $manyToOne;
/**
* @OneToMany(targetEntity="DDC3322ValidEntity1", mappedBy="manyToOne")
*/
private $oneToMany;
/**
* @OneToOne(targetEntity="DDC3322ValidEntity1", inversedBy="oneToOneInverse")
*/
private $oneToOneOwning;
/**
* @OneToOne(targetEntity="DDC3322ValidEntity1", mappedBy="oneToOneOwning")
*/
private $oneToOneInverse;
}
/**
* @Entity
*/
class DDC3322One
{
/**
* @Id @Column @GeneratedValue
*/
private $id;
/**
* @OneToMany(targetEntity="DDC3322ValidEntity1", mappedBy="oneValid")
* @OrderBy({"id" = "ASC"})
*/
private $validAssoc;
/**
* @OneToMany(targetEntity="DDC3322ValidEntity1", mappedBy="oneInvalid")
* @OrderBy({"invalidField" = "ASC"})
*/
private $invalidAssoc;
}
/**
* @Entity
*/
class DDC3322Two
{
/**
* @Id @Column @GeneratedValue
*/
private $id;
/**
* @OneToMany(targetEntity="DDC3322ValidEntity1", mappedBy="twoValid")
* @OrderBy({"manyToOne" = "ASC"})
*/
private $validAssoc;
/**
* @OneToMany(targetEntity="DDC3322ValidEntity1", mappedBy="twoInvalid")
* @OrderBy({"oneToMany" = "ASC"})
*/
private $invalidAssoc;
}
/**
* @Entity
*/
class DDC3322Three
{
/**
* @Id @Column @GeneratedValue
*/
private $id;
/**
* @OneToMany(targetEntity="DDC3322ValidEntity1", mappedBy="threeValid")
* @OrderBy({"oneToOneOwning" = "ASC"})
*/
private $validAssoc;
/**
* @OneToMany(targetEntity="DDC3322ValidEntity1", mappedBy="threeInvalid")
* @OrderBy({"oneToOneInverse" = "ASC"})
*/
private $invalidAssoc;
}