Rajout de doctrine/orm
[zf2.biz/galerie.git] / vendor / doctrine / orm / tests / Doctrine / Tests / ORM / Functional / SchemaTool / MySqlSchemaToolTest.php
1 <?php
2
3 namespace Doctrine\Tests\ORM\Functional\SchemaTool;
4
5 use Doctrine\ORM\Tools\SchemaTool,
6     Doctrine\ORM\Mapping\ClassMetadata;
7
8 require_once __DIR__ . '/../../../TestInit.php';
9
10 class MySqlSchemaToolTest extends \Doctrine\Tests\OrmFunctionalTestCase
11 {
12     protected function setUp() {
13         parent::setUp();
14         if ($this->_em->getConnection()->getDatabasePlatform()->getName() !== 'mysql') {
15             $this->markTestSkipped('The ' . __CLASS__ .' requires the use of mysql.');
16         }
17     }
18
19     public function testGetCreateSchemaSql()
20     {
21         $classes = array(
22             $this->_em->getClassMetadata('Doctrine\Tests\Models\CMS\CmsGroup'),
23             $this->_em->getClassMetadata('Doctrine\Tests\Models\CMS\CmsUser'),
24             $this->_em->getClassMetadata('Doctrine\Tests\Models\CMS\CmsAddress'),
25             $this->_em->getClassMetadata('Doctrine\Tests\Models\CMS\CmsEmail'),
26             $this->_em->getClassMetadata('Doctrine\Tests\Models\CMS\CmsPhonenumber'),
27         );
28
29         $tool = new SchemaTool($this->_em);
30         $sql = $tool->getCreateSchemaSql($classes);
31
32         $this->assertEquals("CREATE TABLE cms_groups (id INT AUTO_INCREMENT NOT NULL, name VARCHAR(50) NOT NULL, PRIMARY KEY(id)) DEFAULT CHARACTER SET utf8 COLLATE utf8_unicode_ci ENGINE = InnoDB", $sql[0]);
33         $this->assertEquals("CREATE TABLE cms_users (id INT AUTO_INCREMENT NOT NULL, email_id INT DEFAULT NULL, status VARCHAR(50) DEFAULT NULL, username VARCHAR(255) NOT NULL, name VARCHAR(255) NOT NULL, UNIQUE INDEX UNIQ_3AF03EC5F85E0677 (username), UNIQUE INDEX UNIQ_3AF03EC5A832C1C9 (email_id), PRIMARY KEY(id)) DEFAULT CHARACTER SET utf8 COLLATE utf8_unicode_ci ENGINE = InnoDB", $sql[1]);
34         $this->assertEquals("CREATE TABLE cms_users_groups (user_id INT NOT NULL, group_id INT NOT NULL, INDEX IDX_7EA9409AA76ED395 (user_id), INDEX IDX_7EA9409AFE54D947 (group_id), PRIMARY KEY(user_id, group_id)) DEFAULT CHARACTER SET utf8 COLLATE utf8_unicode_ci ENGINE = InnoDB", $sql[2]);
35         $this->assertEquals("CREATE TABLE cms_addresses (id INT AUTO_INCREMENT NOT NULL, user_id INT DEFAULT NULL, country VARCHAR(50) NOT NULL, zip VARCHAR(50) NOT NULL, city VARCHAR(50) NOT NULL, UNIQUE INDEX UNIQ_ACAC157BA76ED395 (user_id), PRIMARY KEY(id)) DEFAULT CHARACTER SET utf8 COLLATE utf8_unicode_ci ENGINE = InnoDB", $sql[3]);
36         $this->assertEquals("CREATE TABLE cms_emails (id INT AUTO_INCREMENT NOT NULL, email VARCHAR(250) NOT NULL, PRIMARY KEY(id)) DEFAULT CHARACTER SET utf8 COLLATE utf8_unicode_ci ENGINE = InnoDB", $sql[4]);
37         $this->assertEquals("CREATE TABLE cms_phonenumbers (phonenumber VARCHAR(50) NOT NULL, user_id INT DEFAULT NULL, INDEX IDX_F21F790FA76ED395 (user_id), PRIMARY KEY(phonenumber)) DEFAULT CHARACTER SET utf8 COLLATE utf8_unicode_ci ENGINE = InnoDB", $sql[5]);
38         $this->assertEquals("ALTER TABLE cms_users ADD CONSTRAINT FK_3AF03EC5A832C1C9 FOREIGN KEY (email_id) REFERENCES cms_emails (id)", $sql[6]);
39         $this->assertEquals("ALTER TABLE cms_users_groups ADD CONSTRAINT FK_7EA9409AA76ED395 FOREIGN KEY (user_id) REFERENCES cms_users (id)", $sql[7]);
40         $this->assertEquals("ALTER TABLE cms_users_groups ADD CONSTRAINT FK_7EA9409AFE54D947 FOREIGN KEY (group_id) REFERENCES cms_groups (id)", $sql[8]);
41         $this->assertEquals("ALTER TABLE cms_addresses ADD CONSTRAINT FK_ACAC157BA76ED395 FOREIGN KEY (user_id) REFERENCES cms_users (id)", $sql[9]);
42         $this->assertEquals("ALTER TABLE cms_phonenumbers ADD CONSTRAINT FK_F21F790FA76ED395 FOREIGN KEY (user_id) REFERENCES cms_users (id)", $sql[10]);
43
44         $this->assertEquals(11, count($sql));
45     }
46
47     public function testGetCreateSchemaSql2()
48     {
49         $classes = array(
50             $this->_em->getClassMetadata('Doctrine\Tests\Models\Generic\DecimalModel')
51         );
52
53         $tool = new SchemaTool($this->_em);
54         $sql = $tool->getCreateSchemaSql($classes);
55
56         $this->assertEquals(1, count($sql));
57         $this->assertEquals("CREATE TABLE decimal_model (id INT AUTO_INCREMENT NOT NULL, `decimal` NUMERIC(5, 2) NOT NULL, `high_scale` NUMERIC(14, 4) NOT NULL, PRIMARY KEY(id)) DEFAULT CHARACTER SET utf8 COLLATE utf8_unicode_ci ENGINE = InnoDB", $sql[0]);
58     }
59
60     public function testGetCreateSchemaSql3()
61     {
62         $classes = array(
63             $this->_em->getClassMetadata('Doctrine\Tests\Models\Generic\BooleanModel')
64         );
65
66         $tool = new SchemaTool($this->_em);
67         $sql = $tool->getCreateSchemaSql($classes);
68
69         $this->assertEquals(1, count($sql));
70         $this->assertEquals("CREATE TABLE boolean_model (id INT AUTO_INCREMENT NOT NULL, booleanField TINYINT(1) NOT NULL, PRIMARY KEY(id)) DEFAULT CHARACTER SET utf8 COLLATE utf8_unicode_ci ENGINE = InnoDB", $sql[0]);
71     }
72
73     /**
74      * @group DBAL-204
75      */
76     public function testGetCreateSchemaSql4()
77     {
78         $classes = array(
79             $this->_em->getClassMetadata(__NAMESPACE__ . '\\MysqlSchemaNamespacedEntity')
80         );
81
82         $tool = new SchemaTool($this->_em);
83         $sql = $tool->getCreateSchemaSql($classes);
84
85         $this->assertEquals(0, count($sql));
86     }
87
88 }
89
90 /**
91  * @Entity
92  * @Table("namespace.entity")
93  */
94 class MysqlSchemaNamespacedEntity
95 {
96     /** @Column(type="integer") @Id @GeneratedValue */
97     public $id;
98 }
99