Passed
Pull Request — 2.6 (#7889)
by Antonio J.
07:56
created

getColumnCollationDeclarationSQL()   A

Complexity

Conditions 2
Paths 2

Size

Total Lines 7
Code Lines 3

Duplication

Lines 0
Ratio 0 %

Importance

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