2
0

PersistAndFlushTest.php 9.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255
  1. <?php
  2. namespace Test\PhpDevCommunity\PaperORM;
  3. use PhpDevCommunity\PaperORM\EntityManager;
  4. use PhpDevCommunity\PaperORM\Expression\Expr;
  5. use PhpDevCommunity\PaperORM\PaperConfiguration;
  6. use PhpDevCommunity\PaperORM\Proxy\ProxyInterface;
  7. use PhpDevCommunity\PaperORM\Tools\IDBuilder;
  8. use PhpDevCommunity\UniTester\TestCase;
  9. use Test\PhpDevCommunity\PaperORM\Entity\CommentTest;
  10. use Test\PhpDevCommunity\PaperORM\Entity\InvoiceTest;
  11. use Test\PhpDevCommunity\PaperORM\Entity\PostTest;
  12. use Test\PhpDevCommunity\PaperORM\Entity\UserTest;
  13. use Test\PhpDevCommunity\PaperORM\Helper\DataBaseHelperTest;
  14. class PersistAndFlushTest extends TestCase
  15. {
  16. protected function setUp(): void
  17. {
  18. }
  19. protected function tearDown(): void
  20. {
  21. }
  22. protected function execute(): void
  23. {
  24. foreach (DataBaseHelperTest::drivers() as $params) {
  25. $em = EntityManager::createFromConfig(PaperConfiguration::fromArray($params));
  26. DataBaseHelperTest::init($em);
  27. $this->testInsert($em);
  28. $this->testInsertAndUpdate($em);
  29. $this->testUpdate($em);
  30. $this->testUpdateJoinColumn($em);
  31. $this->testDelete($em);
  32. $em->getConnection()->close();
  33. }
  34. }
  35. private function testInsert(EntityManager $em): void
  36. {
  37. $user = new UserTest();
  38. $this->assertNull($user->getId());
  39. $this->assertNull($user->getToken());
  40. $user->setFirstname('John');
  41. $user->setLastname('Doe');
  42. $user->setPassword('secret');
  43. $user->setEmail('Xq5qI@example.com');
  44. $user->setActive(true);
  45. $em->persist($user);
  46. $em->flush();
  47. $this->assertStringLength($user->getToken(), 32);
  48. $this->assertNotNull($user->getId());
  49. $this->assertInstanceOf(\DateTimeInterface::class, $user->getCreatedAt());
  50. $this->assertInstanceOf(\DateTimeInterface::class, $user->getCreatedAt());
  51. $em->clear();
  52. $post = new PostTest();
  53. $post->setUser($user);
  54. $post->setTitle('Hello World !, it\'s me');
  55. $post->setContent('Hello World !');
  56. $this->assertNull($post->getSlug());
  57. $em->persist($post);
  58. $em->flush();
  59. $this->assertStrictEquals('hello-world-it-s-me', $post->getSlug());
  60. $em->clear();
  61. $post = new PostTest();
  62. $post->setUser($user);
  63. $post->setTitle('Hello World !, it\'s me');
  64. $post->setContent('Hello World !');
  65. $post->setSlug('my-slug');
  66. $em->persist($post);
  67. $em->flush();
  68. $this->assertStrictEquals('my-slug', $post->getSlug());
  69. $em->clear();
  70. $comment = new CommentTest();
  71. $this->assertNull($comment->getUuid());
  72. $comment->setPost($post);
  73. $comment->setBody("my comment");
  74. $em->persist($comment);
  75. $em->flush();
  76. $this->assertNotNull($comment->getUuid());
  77. $uuid = $comment->getUuid();
  78. $em->clear();
  79. $comment = $em->getRepository(CommentTest::class)
  80. ->findOneBy(['uuid' => $uuid])
  81. ->with('post.user')
  82. ->toReadOnlyObject()
  83. ;
  84. $this->assertNotNull($comment);
  85. $this->assertEquals($uuid, $comment->getUuid());
  86. $this->assertInstanceOf(CommentTest::class, $comment);
  87. $this->assertNotNull($comment->getUuid());
  88. $this->assertNotNull($comment->getPost());
  89. $this->assertInstanceOf(PostTest::class, $comment->getPost());
  90. $this->assertNotNull($comment->getPost()->getId());
  91. $this->assertNotNull($comment->getPost()->getUser());
  92. $this->assertInstanceOf(UserTest::class, $comment->getPost()->getUser());
  93. $this->assertNotNull($comment->getPost()->getUser()->getId());
  94. $keyNumber = 'invoice.number.'.IDBuilder::generate('INV-{YYYY}-');
  95. $keyCode = 'invoice.code';
  96. $em->sequence()->reset($keyNumber);
  97. $em->sequence()->reset($keyCode);
  98. $em->sequence()->increment($keyCode);
  99. for ($i = 0; $i < 10; $i++) {
  100. $peekNumber = $em->sequence()->peek($keyNumber);
  101. $peekCode = $em->sequence()->peek($keyCode);
  102. $invoice = new InvoiceTest();
  103. $this->assertEmpty($invoice->getCode());
  104. $this->assertEmpty($invoice->getNumber());
  105. $em->persist($invoice);
  106. $em->flush();
  107. $this->assertNotEmpty($invoice->getCode());
  108. $this->assertNotEmpty($invoice->getNumber());
  109. $this->assertEquals($em->sequence()->peek($keyNumber), $peekNumber + 1);
  110. $this->assertEquals($em->sequence()->peek($keyCode), $peekCode + 1);
  111. }
  112. $this->assertEquals(11, $em->sequence()->peek($keyNumber));
  113. $this->assertEquals(12, $em->sequence()->peek($keyCode));
  114. }
  115. private function testInsertAndUpdate(EntityManager $em): void
  116. {
  117. $user = new UserTest();
  118. $this->assertNull($user->getToken());
  119. $user->setFirstname('John');
  120. $user->setLastname('Doe');
  121. $user->setPassword('secret');
  122. $user->setEmail('Xq5qI@example.com');
  123. $user->setActive(true);
  124. $em->persist($user);
  125. $em->flush();
  126. $token = $user->getToken();
  127. $this->assertNotNull($token);
  128. $this->assertNotNull($user->getId());
  129. $this->assertInstanceOf(\DateTimeInterface::class, $user->getCreatedAt());
  130. $user->setLastname('TOTO');
  131. $em->persist($user);
  132. $em->flush();
  133. $em->clear();
  134. $this->assertEquals($token, $user->getToken());
  135. }
  136. private function testUpdate(EntityManager $em): void
  137. {
  138. $userRepository = $em->getRepository(UserTest::class);
  139. $user = $userRepository->findBy()->first()->orderBy('id')->toObject();
  140. $this->assertInstanceOf(ProxyInterface::class, $user);
  141. $this->assertInstanceOf(UserTest::class, $user);
  142. $this->assertStrictEquals(UserTest::class, $user->__getParentClass());
  143. /**
  144. * @var ProxyInterface|UserTest $user
  145. */
  146. $user->setActive(false);
  147. $user->setLastname('TOTO');
  148. $this->assertStrictEquals(2, count($user->__getPropertiesModified()));
  149. $em->persist($user);
  150. $em->flush();
  151. $user = null;
  152. $em->clear();
  153. $user = $userRepository->findBy()->first()->orderBy('id')->toObject();
  154. $this->assertInstanceOf(ProxyInterface::class, $user);
  155. $this->assertInstanceOf(UserTest::class, $user);
  156. /**
  157. * @var ProxyInterface|UserTest $user
  158. */
  159. $this->assertStrictEquals(0, count($user->__getPropertiesModified()));
  160. $this->assertFalse($user->isActive());
  161. $this->assertStrictEquals('TOTO', $user->getLastname());
  162. }
  163. private function testUpdateJoinColumn(EntityManager $em)
  164. {
  165. $userRepository = $em->getRepository(UserTest::class);
  166. $postRepository = $em->getRepository(PostTest::class);
  167. $post = $postRepository->findBy()->first()
  168. ->where(Expr::isNotNull('user'))
  169. ->with(UserTest::class)
  170. ->toObject();
  171. $this->assertInstanceOf(ProxyInterface::class, $post);
  172. $this->assertInstanceOf(PostTest::class, $post);
  173. $this->assertInstanceOf(UserTest::class, $post->getUser());
  174. $this->assertStrictEquals(1, $post->getUser()->getId());
  175. $user2 = $userRepository->find(2)
  176. ->with(PostTest::class)
  177. ->toObject();
  178. $this->assertStrictEquals(2, count($user2->getPosts()->toArray()));
  179. foreach ($user2->getPosts()->toArray() as $postItem) {
  180. $this->assertInstanceOf(ProxyInterface::class, $postItem);
  181. $this->assertInstanceOf(PostTest::class, $postItem);
  182. }
  183. $post->setUser($user2);
  184. $em->persist($post);
  185. $em->flush();
  186. $user2 = $userRepository->find(2)
  187. ->with(PostTest::class)
  188. ->toObject();
  189. $this->assertStrictEquals(3, count($user2->getPosts()->toArray()));
  190. $user1 = $userRepository->find(1)->with(PostTest::class)->toObject();
  191. $this->assertStrictEquals(1, count($user1->getPosts()->toArray()));
  192. }
  193. private function testDelete(EntityManager $em)
  194. {
  195. $user = $em->getRepository(UserTest::class)->find(1)->toObject();
  196. $this->assertInstanceOf(ProxyInterface::class, $user);
  197. $this->assertInstanceOf(UserTest::class, $user);
  198. $em->remove($user);
  199. $em->flush();
  200. $this->assertFalse($user->__isInitialized());
  201. $posts = $user->getPosts();
  202. $ids = [];
  203. foreach ($posts as $post) {
  204. $ids[] = $post->getId();
  205. $em->remove($post);
  206. $em->flush();
  207. $this->assertFalse($post->__isInitialized());
  208. }
  209. $user = $em->getRepository(UserTest::class)->find(1)->toObject();
  210. $this->assertNull($user);
  211. foreach ($ids as $idPost) {
  212. $postToDelete = $em->getRepository(PostTest::class)->find($idPost)->toObject();
  213. $this->assertNull($postToDelete);
  214. }
  215. }
  216. }