PlatformDiffTest.php 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980
  1. <?php
  2. namespace Test\PhpDevCommunity\PaperORM;
  3. use PhpDevCommunity\PaperORM\EntityManager;
  4. use PhpDevCommunity\PaperORM\Mapping\Column\BoolColumn;
  5. use PhpDevCommunity\PaperORM\Mapping\Column\PrimaryKeyColumn;
  6. use PhpDevCommunity\PaperORM\Mapping\Column\StringColumn;
  7. use PhpDevCommunity\UniTester\TestCase;
  8. use Test\PhpDevCommunity\PaperORM\Helper\DataBaseHelperTest;
  9. class PlatformDiffTest extends TestCase
  10. {
  11. protected function setUp(): void
  12. {
  13. }
  14. protected function tearDown(): void
  15. {
  16. }
  17. protected function execute(): void
  18. {
  19. foreach (DataBaseHelperTest::drivers() as $name => $params) {
  20. $em = new EntityManager($params);
  21. $this->executeTest($em);
  22. $em->getConnection()->close();
  23. }
  24. }
  25. private function executeTest(EntityManager $em)
  26. {
  27. $platform = $em->getPlatform();
  28. $platform->createDatabaseIfNotExists();
  29. $platform->dropDatabase();
  30. $platform->createDatabaseIfNotExists();
  31. $columns = [
  32. new PrimaryKeyColumn('id'),
  33. new StringColumn('firstname'),
  34. new StringColumn('lastname'),
  35. new StringColumn('email'),
  36. new StringColumn('password'),
  37. (new BoolColumn('is_active'))->bindProperty('active'),
  38. ];
  39. $rows = $platform->createTable('user', $columns);
  40. // var_dump($rows);
  41. // exit();
  42. $diff = $platform->diff('user', $columns, [] );
  43. $this->assertEmpty($diff->getColumnsToAdd());
  44. $this->assertEmpty($diff->getColumnsToUpdate());
  45. $this->assertEmpty($diff->getColumnsToDelete());
  46. $columns[3] = new StringColumn('username');
  47. $diff = $platform->diff('user', $columns, [] );
  48. $this->assertTrue(count($diff->getColumnsToAdd()) == 1);
  49. $this->assertTrue(count($diff->getColumnsToDelete()) == 1);
  50. $this->assertEmpty($diff->getColumnsToUpdate());
  51. $platform->dropTable('user');
  52. $platform->createTable('user', $columns, [] );
  53. $columns[3] = new StringColumn( 'username', 100);
  54. $diff = $platform->diff('user', $columns, [] );
  55. $this->assertTrue(count($diff->getColumnsToUpdate()) == 1);
  56. $this->assertEmpty($diff->getColumnsToAdd());
  57. $this->assertEmpty($diff->getColumnsToDelete());
  58. $diff = $platform->diff('user2', $columns, [] );
  59. $this->assertTrue(count($diff->getColumnsToAdd()) == 6);
  60. }
  61. }