DatabaseTransactionsManagerTest.php 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166
  1. <?php
  2. namespace Illuminate\Tests\Database;
  3. use Illuminate\Database\DatabaseTransactionsManager;
  4. use PHPUnit\Framework\TestCase;
  5. class DatabaseTransactionsManagerTest extends TestCase
  6. {
  7. public function testBeginningTransactions()
  8. {
  9. $manager = (new DatabaseTransactionsManager);
  10. $manager->begin('default', 1);
  11. $manager->begin('default', 2);
  12. $manager->begin('admin', 1);
  13. $this->assertCount(3, $manager->getTransactions());
  14. $this->assertSame('default', $manager->getTransactions()[0]->connection);
  15. $this->assertEquals(1, $manager->getTransactions()[0]->level);
  16. $this->assertSame('default', $manager->getTransactions()[1]->connection);
  17. $this->assertEquals(2, $manager->getTransactions()[1]->level);
  18. $this->assertSame('admin', $manager->getTransactions()[2]->connection);
  19. $this->assertEquals(1, $manager->getTransactions()[2]->level);
  20. }
  21. public function testRollingBackTransactions()
  22. {
  23. $manager = (new DatabaseTransactionsManager);
  24. $manager->begin('default', 1);
  25. $manager->begin('default', 2);
  26. $manager->begin('admin', 1);
  27. $manager->rollback('default', 1);
  28. $this->assertCount(2, $manager->getTransactions());
  29. $this->assertSame('default', $manager->getTransactions()[0]->connection);
  30. $this->assertEquals(1, $manager->getTransactions()[0]->level);
  31. $this->assertSame('admin', $manager->getTransactions()[1]->connection);
  32. $this->assertEquals(1, $manager->getTransactions()[1]->level);
  33. }
  34. public function testRollingBackTransactionsAllTheWay()
  35. {
  36. $manager = (new DatabaseTransactionsManager);
  37. $manager->begin('default', 1);
  38. $manager->begin('default', 2);
  39. $manager->begin('admin', 1);
  40. $manager->rollback('default', 0);
  41. $this->assertCount(1, $manager->getTransactions());
  42. $this->assertSame('admin', $manager->getTransactions()[0]->connection);
  43. $this->assertEquals(1, $manager->getTransactions()[0]->level);
  44. }
  45. public function testCommittingTransactions()
  46. {
  47. $manager = (new DatabaseTransactionsManager);
  48. $manager->begin('default', 1);
  49. $manager->begin('default', 2);
  50. $manager->begin('admin', 1);
  51. $manager->commit('default');
  52. $this->assertCount(1, $manager->getTransactions());
  53. $this->assertSame('admin', $manager->getTransactions()[0]->connection);
  54. $this->assertEquals(1, $manager->getTransactions()[0]->level);
  55. }
  56. public function testCallbacksAreAddedToTheCurrentTransaction()
  57. {
  58. $callbacks = [];
  59. $manager = (new DatabaseTransactionsManager);
  60. $manager->begin('default', 1);
  61. $manager->addCallback(function () use (&$callbacks) {
  62. });
  63. $manager->begin('default', 2);
  64. $manager->begin('admin', 1);
  65. $manager->addCallback(function () use (&$callbacks) {
  66. });
  67. $this->assertCount(1, $manager->getTransactions()[0]->getCallbacks());
  68. $this->assertCount(0, $manager->getTransactions()[1]->getCallbacks());
  69. $this->assertCount(1, $manager->getTransactions()[2]->getCallbacks());
  70. }
  71. public function testCommittingTransactionsExecutesCallbacks()
  72. {
  73. $callbacks = [];
  74. $manager = (new DatabaseTransactionsManager);
  75. $manager->begin('default', 1);
  76. $manager->addCallback(function () use (&$callbacks) {
  77. $callbacks[] = ['default', 1];
  78. });
  79. $manager->begin('default', 2);
  80. $manager->addCallback(function () use (&$callbacks) {
  81. $callbacks[] = ['default', 2];
  82. });
  83. $manager->begin('admin', 1);
  84. $manager->commit('default');
  85. $this->assertCount(2, $callbacks);
  86. $this->assertEquals(['default', 1], $callbacks[0]);
  87. $this->assertEquals(['default', 2], $callbacks[1]);
  88. }
  89. public function testCommittingExecutesOnlyCallbacksOfTheConnection()
  90. {
  91. $callbacks = [];
  92. $manager = (new DatabaseTransactionsManager);
  93. $manager->begin('default', 1);
  94. $manager->addCallback(function () use (&$callbacks) {
  95. $callbacks[] = ['default', 1];
  96. });
  97. $manager->begin('default', 2);
  98. $manager->begin('admin', 1);
  99. $manager->addCallback(function () use (&$callbacks) {
  100. $callbacks[] = ['admin', 1];
  101. });
  102. $manager->commit('default');
  103. $this->assertCount(1, $callbacks);
  104. $this->assertEquals(['default', 1], $callbacks[0]);
  105. }
  106. public function testCallbackIsExecutedIfNoTransactions()
  107. {
  108. $callbacks = [];
  109. $manager = (new DatabaseTransactionsManager);
  110. $manager->addCallback(function () use (&$callbacks) {
  111. $callbacks[] = ['default', 1];
  112. });
  113. $this->assertCount(1, $callbacks);
  114. $this->assertEquals(['default', 1], $callbacks[0]);
  115. }
  116. }