DDC214Test.php 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. <?php
  2. namespace Doctrine\Tests\ORM\Functional\SchemaTool;
  3. use Doctrine\ORM\Tools;
  4. require_once __DIR__ . '/../../../TestInit.php';
  5. /**
  6. * WARNING: This test should be run as last test! It can affect others very easily!
  7. */
  8. class DDC214Test extends \Doctrine\Tests\OrmFunctionalTestCase
  9. {
  10. private $classes = array();
  11. private $schemaTool = null;
  12. public function setUp() {
  13. parent::setUp();
  14. $conn = $this->_em->getConnection();
  15. if (strpos($conn->getDriver()->getName(), "sqlite") !== false) {
  16. $this->markTestSkipped('SQLite does not support ALTER TABLE statements.');
  17. }
  18. $this->schemaTool = new Tools\SchemaTool($this->_em);
  19. }
  20. /**
  21. * @group DDC-214
  22. */
  23. public function testCmsAddressModel()
  24. {
  25. $this->classes = array(
  26. 'Doctrine\Tests\Models\CMS\CmsUser',
  27. 'Doctrine\Tests\Models\CMS\CmsPhonenumber',
  28. 'Doctrine\Tests\Models\CMS\CmsAddress',
  29. 'Doctrine\Tests\Models\CMS\CmsGroup',
  30. 'Doctrine\Tests\Models\CMS\CmsArticle'
  31. );
  32. $this->assertCreatedSchemaNeedsNoUpdates($this->classes);
  33. }
  34. /**
  35. * @group DDC-214
  36. */
  37. public function testCompanyModel()
  38. {
  39. $this->classes = array(
  40. 'Doctrine\Tests\Models\Company\CompanyPerson',
  41. 'Doctrine\Tests\Models\Company\CompanyEmployee',
  42. 'Doctrine\Tests\Models\Company\CompanyManager',
  43. 'Doctrine\Tests\Models\Company\CompanyOrganization',
  44. 'Doctrine\Tests\Models\Company\CompanyEvent',
  45. 'Doctrine\Tests\Models\Company\CompanyAuction',
  46. 'Doctrine\Tests\Models\Company\CompanyRaffle',
  47. 'Doctrine\Tests\Models\Company\CompanyCar'
  48. );
  49. $this->assertCreatedSchemaNeedsNoUpdates($this->classes);
  50. }
  51. public function assertCreatedSchemaNeedsNoUpdates($classes)
  52. {
  53. $classMetadata = array();
  54. foreach ($classes AS $class) {
  55. $classMetadata[] = $this->_em->getClassMetadata($class);
  56. }
  57. try {
  58. $this->schemaTool->createSchema($classMetadata);
  59. } catch(\Exception $e) {
  60. // was already created
  61. }
  62. $sm = $this->_em->getConnection()->getSchemaManager();
  63. $fromSchema = $sm->createSchema();
  64. $toSchema = $this->schemaTool->getSchemaFromMetadata($classMetadata);
  65. $comparator = new \Doctrine\DBAL\Schema\Comparator();
  66. $schemaDiff = $comparator->compare($fromSchema, $toSchema);
  67. $sql = $schemaDiff->toSql($this->_em->getConnection()->getDatabasePlatform());
  68. $sql = array_filter($sql, function($sql) { return strpos($sql, 'DROP') === false; });
  69. $this->assertEquals(0, count($sql), "SQL: " . implode(PHP_EOL, $sql));
  70. }
  71. }