| 1 |  |  | <?php | 
            
                                                                                                            
                            
            
                                    
            
            
                | 2 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 3 |  |  | namespace Doctrine\Tests\ORM\Functional\SchemaTool; | 
            
                                                                                                            
                            
            
                                    
            
            
                | 4 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 5 |  |  | use Doctrine\ORM\Tools\SchemaTool; | 
            
                                                                                                            
                            
            
                                    
            
            
                | 6 |  |  | use Doctrine\Tests\OrmFunctionalTestCase; | 
            
                                                                                                            
                            
            
                                    
            
            
                | 7 |  |  | use Doctrine\Tests\Models; | 
            
                                                                                                            
                            
            
                                    
            
            
                | 8 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 9 |  |  | class MySqlSchemaToolTest extends OrmFunctionalTestCase | 
            
                                                                                                            
                            
            
                                    
            
            
                | 10 |  |  | { | 
            
                                                                                                            
                            
            
                                    
            
            
                | 11 |  |  |     protected function setUp() { | 
            
                                                                                                            
                            
            
                                    
            
            
                | 12 |  |  |         parent::setUp(); | 
            
                                                                                                            
                            
            
                                    
            
            
                | 13 |  |  |         if ($this->_em->getConnection()->getDatabasePlatform()->getName() !== 'mysql') { | 
            
                                                                                                            
                            
            
                                    
            
            
                | 14 |  |  |             $this->markTestSkipped('The ' . __CLASS__ .' requires the use of mysql.'); | 
            
                                                                                                            
                            
            
                                    
            
            
                | 15 |  |  |         } | 
            
                                                                                                            
                            
            
                                    
            
            
                | 16 |  |  |     } | 
            
                                                                                                            
                            
            
                                    
            
            
                | 17 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 18 |  |  |     public function testGetCreateSchemaSql() | 
            
                                                                                                            
                            
            
                                    
            
            
                | 19 |  |  |     { | 
            
                                                                                                            
                            
            
                                    
            
            
                | 20 |  |  |         $classes = [ | 
            
                                                                                                            
                            
            
                                    
            
            
                | 21 |  |  |             $this->_em->getClassMetadata(Models\CMS\CmsGroup::class), | 
            
                                                                                                            
                            
            
                                    
            
            
                | 22 |  |  |             $this->_em->getClassMetadata(Models\CMS\CmsUser::class), | 
            
                                                                                                            
                            
            
                                    
            
            
                | 23 |  |  |             $this->_em->getClassMetadata(Models\CMS\CmsTag::class), | 
            
                                                                                                            
                            
            
                                    
            
            
                | 24 |  |  |             $this->_em->getClassMetadata(Models\CMS\CmsAddress::class), | 
            
                                                                                                            
                            
            
                                    
            
            
                | 25 |  |  |             $this->_em->getClassMetadata(Models\CMS\CmsEmail::class), | 
            
                                                                                                            
                            
            
                                    
            
            
                | 26 |  |  |             $this->_em->getClassMetadata(Models\CMS\CmsPhonenumber::class), | 
            
                                                                                                            
                            
            
                                    
            
            
                | 27 |  |  |         ]; | 
            
                                                                                                            
                            
            
                                    
            
            
                | 28 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 29 |  |  |         $tool = new SchemaTool($this->_em); | 
            
                                                                                                            
                            
            
                                    
            
            
                | 30 |  |  |         $sql = $tool->getCreateSchemaSql($classes); | 
            
                                                                                                            
                            
            
                                    
            
            
                | 31 |  |  |         $collation = $this->getColumnCollationDeclarationSQL('utf8_unicode_ci'); | 
            
                                                                                                            
                            
            
                                    
            
            
                | 32 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 33 |  |  |         $this->assertEquals("CREATE TABLE cms_groups (id INT AUTO_INCREMENT NOT NULL, name VARCHAR(50) NOT NULL, PRIMARY KEY(id)) DEFAULT CHARACTER SET utf8 " . $collation . " ENGINE = InnoDB", $sql[0]); | 
            
                                                                                                            
                            
            
                                    
            
            
                | 34 |  |  |         $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 " . $collation . " ENGINE = InnoDB", $sql[1]); | 
            
                                                                                                            
                            
            
                                    
            
            
                | 35 |  |  |         $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 " . $collation . " ENGINE = InnoDB", $sql[2]); | 
            
                                                                                                            
                            
            
                                    
            
            
                | 36 |  |  |         $this->assertEquals("CREATE TABLE cms_users_tags (user_id INT NOT NULL, tag_id INT NOT NULL, INDEX IDX_93F5A1ADA76ED395 (user_id), INDEX IDX_93F5A1ADBAD26311 (tag_id), PRIMARY KEY(user_id, tag_id)) DEFAULT CHARACTER SET utf8 " . $collation . " ENGINE = InnoDB", $sql[3]); | 
            
                                                                                                            
                            
            
                                    
            
            
                | 37 |  |  |         $this->assertEquals("CREATE TABLE cms_tags (id INT AUTO_INCREMENT NOT NULL, tag_name VARCHAR(50) DEFAULT NULL, PRIMARY KEY(id)) DEFAULT CHARACTER SET utf8 " . $collation . " ENGINE = InnoDB", $sql[4]); | 
            
                                                                                                            
                            
            
                                    
            
            
                | 38 |  |  |         $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 " . $collation . " ENGINE = InnoDB", $sql[5]); | 
            
                                                                                                            
                            
            
                                    
            
            
                | 39 |  |  |         $this->assertEquals("CREATE TABLE cms_emails (id INT AUTO_INCREMENT NOT NULL, email VARCHAR(250) NOT NULL, PRIMARY KEY(id)) DEFAULT CHARACTER SET utf8 " . $collation . " ENGINE = InnoDB", $sql[6]); | 
            
                                                                                                            
                            
            
                                    
            
            
                | 40 |  |  |         $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 " . $collation . " ENGINE = InnoDB", $sql[7]); | 
            
                                                                                                            
                            
            
                                    
            
            
                | 41 |  |  |         $this->assertEquals("ALTER TABLE cms_users ADD CONSTRAINT FK_3AF03EC5A832C1C9 FOREIGN KEY (email_id) REFERENCES cms_emails (id)", $sql[8]); | 
            
                                                                                                            
                            
            
                                    
            
            
                | 42 |  |  |         $this->assertEquals("ALTER TABLE cms_users_groups ADD CONSTRAINT FK_7EA9409AA76ED395 FOREIGN KEY (user_id) REFERENCES cms_users (id)", $sql[9]); | 
            
                                                                                                            
                            
            
                                    
            
            
                | 43 |  |  |         $this->assertEquals("ALTER TABLE cms_users_groups ADD CONSTRAINT FK_7EA9409AFE54D947 FOREIGN KEY (group_id) REFERENCES cms_groups (id)", $sql[10]); | 
            
                                                                                                            
                            
            
                                    
            
            
                | 44 |  |  |         $this->assertEquals("ALTER TABLE cms_users_tags ADD CONSTRAINT FK_93F5A1ADA76ED395 FOREIGN KEY (user_id) REFERENCES cms_users (id)", $sql[11]); | 
            
                                                                                                            
                            
            
                                    
            
            
                | 45 |  |  |         $this->assertEquals("ALTER TABLE cms_users_tags ADD CONSTRAINT FK_93F5A1ADBAD26311 FOREIGN KEY (tag_id) REFERENCES cms_tags (id)", $sql[12]); | 
            
                                                                                                            
                            
            
                                    
            
            
                | 46 |  |  |         $this->assertEquals("ALTER TABLE cms_addresses ADD CONSTRAINT FK_ACAC157BA76ED395 FOREIGN KEY (user_id) REFERENCES cms_users (id)", $sql[13]); | 
            
                                                                                                            
                            
            
                                    
            
            
                | 47 |  |  |         $this->assertEquals("ALTER TABLE cms_phonenumbers ADD CONSTRAINT FK_F21F790FA76ED395 FOREIGN KEY (user_id) REFERENCES cms_users (id)", $sql[14]); | 
            
                                                                                                            
                            
            
                                    
            
            
                | 48 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 49 |  |  |         $this->assertEquals(15, count($sql)); | 
            
                                                                                                            
                            
            
                                    
            
            
                | 50 |  |  |     } | 
            
                                                                                                            
                            
            
                                    
            
            
                | 51 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 52 |  |  |     private function getColumnCollationDeclarationSQL(string $collation) : string | 
            
                                                                                                            
                            
            
                                    
            
            
                | 53 |  |  |     { | 
            
                                                                                                            
                            
            
                                    
            
            
                | 54 |  |  |         if (method_exists($this->_em->getConnection()->getDatabasePlatform(), 'getColumnCollationDeclarationSQL')) { | 
            
                                                                                                            
                            
            
                                    
            
            
                | 55 |  |  |             return $this->_em->getConnection()->getDatabasePlatform()->getColumnCollationDeclarationSQL($collation); | 
            
                                                                                                            
                            
            
                                    
            
            
                | 56 |  |  |         } | 
            
                                                                                                            
                            
            
                                    
            
            
                | 57 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 58 |  |  |         return sprintf('COLLATE %s', $collation); | 
            
                                                                                                            
                            
            
                                    
            
            
                | 59 |  |  |     } | 
            
                                                                                                            
                                                                
            
                                    
            
            
                | 60 |  |  |  | 
            
                                                                        
                            
            
                                    
            
            
                | 61 |  |  |     public function testGetCreateSchemaSql2() | 
            
                                                                        
                            
            
                                    
            
            
                | 62 |  |  |     { | 
            
                                                                        
                            
            
                                    
            
            
                | 63 |  |  |         $classes = [ | 
            
                                                                        
                            
            
                                    
            
            
                | 64 |  |  |             $this->_em->getClassMetadata(Models\Generic\DecimalModel::class) | 
            
                                                                        
                            
            
                                    
            
            
                | 65 |  |  |         ]; | 
            
                                                                        
                            
            
                                    
            
            
                | 66 |  |  |  | 
            
                                                                        
                            
            
                                    
            
            
                | 67 |  |  |         $tool = new SchemaTool($this->_em); | 
            
                                                                        
                            
            
                                    
            
            
                | 68 |  |  |         $sql = $tool->getCreateSchemaSql($classes); | 
            
                                                                        
                            
            
                                    
            
            
                | 69 |  |  |         $collation = $this->getColumnCollationDeclarationSQL('utf8_unicode_ci'); | 
            
                                                                        
                            
            
                                    
            
            
                | 70 |  |  |  | 
            
                                                                        
                            
            
                                    
            
            
                | 71 |  |  |         $this->assertEquals(1, count($sql)); | 
            
                                                                        
                            
            
                                    
            
            
                | 72 |  |  |         $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 " . $collation . " ENGINE = InnoDB", $sql[0]); | 
            
                                                                                                            
                            
            
                                    
            
            
                | 73 |  |  |     } | 
            
                                                                                                            
                            
            
                                    
            
            
                | 74 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 75 |  |  |     public function testGetCreateSchemaSql3() | 
            
                                                                                                            
                            
            
                                    
            
            
                | 76 |  |  |     { | 
            
                                                                                                            
                            
            
                                    
            
            
                | 77 |  |  |         $classes = [ | 
            
                                                                                                            
                            
            
                                    
            
            
                | 78 |  |  |             $this->_em->getClassMetadata(Models\Generic\BooleanModel::class) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 79 |  |  |         ]; | 
            
                                                                                                            
                            
            
                                    
            
            
                | 80 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 81 |  |  |         $tool = new SchemaTool($this->_em); | 
            
                                                                                                            
                            
            
                                    
            
            
                | 82 |  |  |         $sql = $tool->getCreateSchemaSql($classes); | 
            
                                                                                                            
                            
            
                                    
            
            
                | 83 |  |  |         $collation = $this->getColumnCollationDeclarationSQL('utf8_unicode_ci'); | 
            
                                                                                                            
                            
            
                                    
            
            
                | 84 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 85 |  |  |         $this->assertEquals(1, count($sql)); | 
            
                                                                                                            
                            
            
                                    
            
            
                | 86 |  |  |         $this->assertEquals("CREATE TABLE boolean_model (id INT AUTO_INCREMENT NOT NULL, booleanField TINYINT(1) NOT NULL, PRIMARY KEY(id)) DEFAULT CHARACTER SET utf8 " . $collation . " ENGINE = InnoDB", $sql[0]); | 
            
                                                                                                            
                            
            
                                    
            
            
                | 87 |  |  |     } | 
            
                                                                                                            
                            
            
                                    
            
            
                | 88 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 89 |  |  |     /** | 
            
                                                                                                            
                            
            
                                    
            
            
                | 90 |  |  |      * @group DBAL-204 | 
            
                                                                                                            
                            
            
                                    
            
            
                | 91 |  |  |      */ | 
            
                                                                                                            
                            
            
                                    
            
            
                | 92 |  |  |     public function testGetCreateSchemaSql4() | 
            
                                                                                                            
                            
            
                                    
            
            
                | 93 |  |  |     { | 
            
                                                                                                            
                            
            
                                    
            
            
                | 94 |  |  |         $classes = [ | 
            
                                                                                                            
                            
            
                                    
            
            
                | 95 |  |  |             $this->_em->getClassMetadata(MysqlSchemaNamespacedEntity::class) | 
            
                                                                                                            
                            
            
                                    
            
            
                | 96 |  |  |         ]; | 
            
                                                                                                            
                            
            
                                    
            
            
                | 97 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 98 |  |  |         $tool = new SchemaTool($this->_em); | 
            
                                                                                                            
                            
            
                                    
            
            
                | 99 |  |  |         $sql = $tool->getCreateSchemaSql($classes); | 
            
                                                                                                            
                            
            
                                    
            
            
                | 100 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 101 |  |  |         $this->assertEquals(0, count($sql)); | 
            
                                                                                                            
                            
            
                                    
            
            
                | 102 |  |  |     } | 
            
                                                                                                            
                            
            
                                    
            
            
                | 103 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 104 |  |  | } | 
            
                                                                                                            
                            
            
                                    
            
            
                | 105 |  |  |  | 
            
                                                                                                            
                            
            
                                    
            
            
                | 106 |  |  | /** | 
            
                                                                                                            
                            
            
                                    
            
            
                | 107 |  |  |  * @Entity | 
            
                                                                                                            
                            
            
                                    
            
            
                | 108 |  |  |  * @Table("namespace.entity") | 
            
                                                                                                            
                            
            
                                    
            
            
                | 109 |  |  |  */ | 
            
                                                                                                            
                            
            
                                    
            
            
                | 110 |  |  | class MysqlSchemaNamespacedEntity | 
            
                                                                                                            
                            
            
                                    
            
            
                | 111 |  |  | { | 
            
                                                                                                            
                            
            
                                    
            
            
                | 112 |  |  |     /** @Column(type="integer") @Id @GeneratedValue */ | 
            
                                                                                                            
                            
            
                                    
            
            
                | 113 |  |  |     public $id; | 
            
                                                                                                            
                            
            
                                    
            
            
                | 114 |  |  | } | 
            
                                                                                                            
                                                                
            
                                    
            
            
                | 115 |  |  |  | 
            
                                                        
            
                                    
            
            
                | 116 |  |  |  |