3 namespace Doctrine\Tests\ORM\Functional\SchemaTool;
5 use Doctrine\ORM\Tools;
8 require_once __DIR__ . '/../../../TestInit.php';
11 * WARNING: This test should be run as last test! It can affect others very easily!
13 class DDC214Test extends \Doctrine\Tests\OrmFunctionalTestCase
15 private $classes = array();
16 private $schemaTool = null;
18 public function setUp() {
21 $conn = $this->_em->getConnection();
23 if (strpos($conn->getDriver()->getName(), "sqlite") !== false) {
24 $this->markTestSkipped('SQLite does not support ALTER TABLE statements.');
26 $this->schemaTool = new Tools\SchemaTool($this->_em);
32 public function testCmsAddressModel()
34 $this->classes = array(
35 'Doctrine\Tests\Models\CMS\CmsUser',
36 'Doctrine\Tests\Models\CMS\CmsPhonenumber',
37 'Doctrine\Tests\Models\CMS\CmsAddress',
38 'Doctrine\Tests\Models\CMS\CmsGroup',
39 'Doctrine\Tests\Models\CMS\CmsArticle',
40 'Doctrine\Tests\Models\CMS\CmsEmail',
43 $this->assertCreatedSchemaNeedsNoUpdates($this->classes);
49 public function testCompanyModel()
51 $this->classes = array(
52 'Doctrine\Tests\Models\Company\CompanyPerson',
53 'Doctrine\Tests\Models\Company\CompanyEmployee',
54 'Doctrine\Tests\Models\Company\CompanyManager',
55 'Doctrine\Tests\Models\Company\CompanyOrganization',
56 'Doctrine\Tests\Models\Company\CompanyEvent',
57 'Doctrine\Tests\Models\Company\CompanyAuction',
58 'Doctrine\Tests\Models\Company\CompanyRaffle',
59 'Doctrine\Tests\Models\Company\CompanyCar'
62 $this->assertCreatedSchemaNeedsNoUpdates($this->classes);
65 public function assertCreatedSchemaNeedsNoUpdates($classes)
67 $classMetadata = array();
68 foreach ($classes AS $class) {
69 $classMetadata[] = $this->_em->getClassMetadata($class);
73 $this->schemaTool->createSchema($classMetadata);
74 } catch(\Exception $e) {
75 // was already created
78 $sm = $this->_em->getConnection()->getSchemaManager();
80 $fromSchema = $sm->createSchema();
81 $toSchema = $this->schemaTool->getSchemaFromMetadata($classMetadata);
83 $comparator = new \Doctrine\DBAL\Schema\Comparator();
84 $schemaDiff = $comparator->compare($fromSchema, $toSchema);
86 $sql = $schemaDiff->toSql($this->_em->getConnection()->getDatabasePlatform());
87 $sql = array_filter($sql, function($sql) { return strpos($sql, 'DROP') === false; });
89 $this->assertEquals(0, count($sql), "SQL: " . implode(PHP_EOL, $sql));