PostgreSqlSchemaToolTest.php 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  1. <?php
  2. namespace Doctrine\Tests\ORM\Functional\SchemaTool;
  3. use Doctrine\ORM\Tools\SchemaTool,
  4. Doctrine\ORM\Mapping\ClassMetadata;
  5. require_once __DIR__ . '/../../../TestInit.php';
  6. class PostgreSqlSchemaToolTest extends \Doctrine\Tests\OrmFunctionalTestCase
  7. {
  8. protected function setUp() {
  9. parent::setUp();
  10. if ($this->_em->getConnection()->getDatabasePlatform()->getName() !== 'postgresql') {
  11. $this->markTestSkipped('The ' . __CLASS__ .' requires the use of postgresql.');
  12. }
  13. }
  14. public function testPostgresMetadataSequenceIncrementedBy10()
  15. {
  16. $address = $this->_em->getClassMetadata('Doctrine\Tests\Models\CMS\CmsAddress');
  17. $this->assertEquals(1, $address->sequenceGeneratorDefinition['allocationSize']);
  18. }
  19. public function testGetCreateSchemaSql()
  20. {
  21. $classes = array(
  22. $this->_em->getClassMetadata('Doctrine\Tests\Models\CMS\CmsAddress'),
  23. $this->_em->getClassMetadata('Doctrine\Tests\Models\CMS\CmsUser'),
  24. $this->_em->getClassMetadata('Doctrine\Tests\Models\CMS\CmsPhonenumber'),
  25. );
  26. $tool = new SchemaTool($this->_em);
  27. $sql = $tool->getCreateSchemaSql($classes);
  28. $sqlCount = count($sql);
  29. $this->assertEquals("CREATE TABLE cms_addresses (id INT NOT NULL, user_id INT DEFAULT NULL, country VARCHAR(50) NOT NULL, zip VARCHAR(50) NOT NULL, city VARCHAR(50) NOT NULL, PRIMARY KEY(id))", array_shift($sql));
  30. $this->assertEquals("CREATE UNIQUE INDEX UNIQ_ACAC157BA76ED395 ON cms_addresses (user_id)", array_shift($sql));
  31. $this->assertEquals("CREATE TABLE cms_users (id INT NOT NULL, email_id INT DEFAULT NULL, status VARCHAR(50) DEFAULT NULL, username VARCHAR(255) NOT NULL, name VARCHAR(255) NOT NULL, PRIMARY KEY(id))", array_shift($sql));
  32. $this->assertEquals("CREATE UNIQUE INDEX UNIQ_3AF03EC5F85E0677 ON cms_users (username)", array_shift($sql));
  33. $this->assertEquals("CREATE UNIQUE INDEX UNIQ_3AF03EC5A832C1C9 ON cms_users (email_id)", array_shift($sql));
  34. $this->assertEquals("CREATE TABLE cms_users_groups (user_id INT NOT NULL, group_id INT NOT NULL, PRIMARY KEY(user_id, group_id))", array_shift($sql));
  35. $this->assertEquals("CREATE INDEX IDX_7EA9409AA76ED395 ON cms_users_groups (user_id)", array_shift($sql));
  36. $this->assertEquals("CREATE INDEX IDX_7EA9409AFE54D947 ON cms_users_groups (group_id)", array_shift($sql));
  37. $this->assertEquals("CREATE TABLE cms_phonenumbers (phonenumber VARCHAR(50) NOT NULL, user_id INT DEFAULT NULL, PRIMARY KEY(phonenumber))", array_shift($sql));
  38. $this->assertEquals("CREATE INDEX IDX_F21F790FA76ED395 ON cms_phonenumbers (user_id)", array_shift($sql));
  39. $this->assertEquals("CREATE SEQUENCE cms_addresses_id_seq INCREMENT BY 1 MINVALUE 1 START 1", array_shift($sql));
  40. $this->assertEquals("CREATE SEQUENCE cms_users_id_seq INCREMENT BY 1 MINVALUE 1 START 1", array_shift($sql));
  41. $this->assertEquals("ALTER TABLE cms_addresses ADD CONSTRAINT FK_ACAC157BA76ED395 FOREIGN KEY (user_id) REFERENCES cms_users (id) NOT DEFERRABLE INITIALLY IMMEDIATE", array_shift($sql));
  42. $this->assertEquals("ALTER TABLE cms_users ADD CONSTRAINT FK_3AF03EC5A832C1C9 FOREIGN KEY (email_id) REFERENCES cms_emails (id) NOT DEFERRABLE INITIALLY IMMEDIATE", array_shift($sql));
  43. $this->assertEquals("ALTER TABLE cms_users_groups ADD CONSTRAINT FK_7EA9409AA76ED395 FOREIGN KEY (user_id) REFERENCES cms_users (id) NOT DEFERRABLE INITIALLY IMMEDIATE", array_shift($sql));
  44. $this->assertEquals("ALTER TABLE cms_users_groups ADD CONSTRAINT FK_7EA9409AFE54D947 FOREIGN KEY (group_id) REFERENCES cms_groups (id) NOT DEFERRABLE INITIALLY IMMEDIATE", array_shift($sql));
  45. $this->assertEquals("ALTER TABLE cms_phonenumbers ADD CONSTRAINT FK_F21F790FA76ED395 FOREIGN KEY (user_id) REFERENCES cms_users (id) NOT DEFERRABLE INITIALLY IMMEDIATE", array_shift($sql));
  46. $this->assertEquals(array(), $sql, "SQL Array should be empty now.");
  47. $this->assertEquals(17, $sqlCount, "Total of 17 queries should be executed");
  48. }
  49. public function testGetCreateSchemaSql2()
  50. {
  51. $classes = array(
  52. $this->_em->getClassMetadata('Doctrine\Tests\Models\Generic\DecimalModel')
  53. );
  54. $tool = new SchemaTool($this->_em);
  55. $sql = $tool->getCreateSchemaSql($classes);
  56. $this->assertEquals(2, count($sql));
  57. $this->assertEquals('CREATE TABLE decimal_model (id INT NOT NULL, "decimal" NUMERIC(5, 2) NOT NULL, "high_scale" NUMERIC(14, 4) NOT NULL, PRIMARY KEY(id))', $sql[0]);
  58. $this->assertEquals("CREATE SEQUENCE decimal_model_id_seq INCREMENT BY 1 MINVALUE 1 START 1", $sql[1]);
  59. }
  60. public function testGetCreateSchemaSql3()
  61. {
  62. $classes = array(
  63. $this->_em->getClassMetadata('Doctrine\Tests\Models\Generic\BooleanModel')
  64. );
  65. $tool = new SchemaTool($this->_em);
  66. $sql = $tool->getCreateSchemaSql($classes);
  67. $this->assertEquals(2, count($sql));
  68. $this->assertEquals("CREATE TABLE boolean_model (id INT NOT NULL, booleanField BOOLEAN NOT NULL, PRIMARY KEY(id))", $sql[0]);
  69. $this->assertEquals("CREATE SEQUENCE boolean_model_id_seq INCREMENT BY 1 MINVALUE 1 START 1", $sql[1]);
  70. }
  71. public function testGetDropSchemaSql()
  72. {
  73. $classes = array(
  74. $this->_em->getClassMetadata('Doctrine\Tests\Models\CMS\CmsAddress'),
  75. $this->_em->getClassMetadata('Doctrine\Tests\Models\CMS\CmsUser'),
  76. $this->_em->getClassMetadata('Doctrine\Tests\Models\CMS\CmsPhonenumber'),
  77. );
  78. $tool = new SchemaTool($this->_em);
  79. $sql = $tool->getDropSchemaSQL($classes);
  80. $this->assertEquals(14, count($sql));
  81. $dropSequenceSQLs = 0;
  82. foreach ($sql AS $stmt) {
  83. if (strpos($stmt, "DROP SEQUENCE") === 0) {
  84. $dropSequenceSQLs++;
  85. }
  86. }
  87. $this->assertEquals(4, $dropSequenceSQLs, "Expect 4 sequences to be dropped.");
  88. }
  89. }