TimestampableTest.php 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163
  1. <?php
  2. namespace Gedmo\Timestampable;
  3. use Doctrine\Common\Util\Debug,
  4. Timestampable\Fixture\Article,
  5. Timestampable\Fixture\Comment,
  6. Timestampable\Fixture\Type;
  7. /**
  8. * These are tests for Timestampable behavior
  9. *
  10. * @author Gediminas Morkevicius <gediminas.morkevicius@gmail.com>
  11. * @package Gedmo.Timestampable
  12. * @link http://www.gediminasm.org
  13. * @license MIT License (http://www.opensource.org/licenses/mit-license.php)
  14. */
  15. class TimestampableTest extends \PHPUnit_Framework_TestCase
  16. {
  17. const TEST_ENTITY_ARTICLE = "Timestampable\Fixture\Article";
  18. const TEST_ENTITY_COMMENT = "Timestampable\Fixture\Comment";
  19. const TEST_ENTITY_TYPE = "Timestampable\Fixture\Type";
  20. private $em;
  21. public function setUp()
  22. {
  23. $config = new \Doctrine\ORM\Configuration();
  24. $config->setMetadataCacheImpl(new \Doctrine\Common\Cache\ArrayCache);
  25. $config->setQueryCacheImpl(new \Doctrine\Common\Cache\ArrayCache);
  26. $config->setProxyDir(__DIR__ . '/Proxy');
  27. $config->setProxyNamespace('Gedmo\Timestampable\Proxies');
  28. $config->setMetadataDriverImpl($config->newDefaultAnnotationDriver());
  29. $conn = array(
  30. 'driver' => 'pdo_sqlite',
  31. 'memory' => true,
  32. );
  33. //$config->setSQLLogger(new \Doctrine\DBAL\Logging\EchoSQLLogger());
  34. $evm = new \Doctrine\Common\EventManager();
  35. $timestampableListener = new TimestampableListener();
  36. $evm->addEventSubscriber($timestampableListener);
  37. $this->em = \Doctrine\ORM\EntityManager::create($conn, $config, $evm);
  38. $schemaTool = new \Doctrine\ORM\Tools\SchemaTool($this->em);
  39. $schemaTool->dropSchema(array());
  40. $schemaTool->createSchema(array(
  41. $this->em->getClassMetadata(self::TEST_ENTITY_ARTICLE),
  42. $this->em->getClassMetadata(self::TEST_ENTITY_COMMENT),
  43. $this->em->getClassMetadata(self::TEST_ENTITY_TYPE)
  44. ));
  45. }
  46. public function testTimestampable()
  47. {
  48. $sport = new Article();
  49. $sport->setTitle('Sport');
  50. $this->assertTrue($sport instanceof Timestampable);
  51. $sportComment = new Comment();
  52. $sportComment->setMessage('hello');
  53. $sportComment->setArticle($sport);
  54. $sportComment->setStatus(0);
  55. $this->assertTrue($sportComment instanceof Timestampable);
  56. $date = new \DateTime('now');
  57. $this->em->persist($sport);
  58. $this->em->persist($sportComment);
  59. $this->em->flush();
  60. $this->em->clear();
  61. $sport = $this->em->getRepository(self::TEST_ENTITY_ARTICLE)->findOneByTitle('Sport');
  62. $this->assertEquals(
  63. $date->format('Y-m-d 00:00:00'),
  64. $sport->getCreated()->format('Y-m-d H:i:s')
  65. );
  66. $this->assertEquals(
  67. $date->format('Y-m-d H:i:s'),
  68. $sport->getUpdated()->format('Y-m-d H:i:s')
  69. );
  70. $this->assertEquals(null, $sport->getPublished());
  71. $sportComment = $this->em->getRepository(self::TEST_ENTITY_COMMENT)->findOneByMessage('hello');
  72. $this->assertEquals(
  73. $date->format('H:i:s'),
  74. $sportComment->getModified()->format('H:i:s')
  75. );
  76. $this->assertEquals(null, $sportComment->getClosed());
  77. sleep(1);
  78. $sportComment->setStatus(1);
  79. $published = new Type();
  80. $published->setTitle('Published');
  81. $sport->setTitle('Updated');
  82. $sport->setType($published);
  83. $date = new \DateTime('now');
  84. $this->em->persist($sport);
  85. $this->em->persist($published);
  86. $this->em->persist($sportComment);
  87. $this->em->flush();
  88. $this->em->clear();
  89. $sportComment = $this->em->getRepository(self::TEST_ENTITY_COMMENT)->findOneByMessage('hello');
  90. $this->assertEquals(
  91. $date->format('Y-m-d H:i:s'),
  92. $sportComment->getClosed()->format('Y-m-d H:i:s')
  93. );
  94. $sport = $this->em->getRepository(self::TEST_ENTITY_ARTICLE)->findOneByTitle('Updated');
  95. $this->assertEquals(
  96. $date->format('Y-m-d H:i:s'),
  97. $sport->getUpdated()->format('Y-m-d H:i:s')
  98. );
  99. $this->assertEquals(
  100. $date->format('Y-m-d H:i:s'),
  101. $sport->getPublished()->format('Y-m-d H:i:s')
  102. );
  103. }
  104. public function testForcedValues()
  105. {
  106. $sport = new Article();
  107. $sport->setTitle('sport forced');
  108. $sport->setCreated(new \DateTime('2000-01-01'));
  109. $sport->setUpdated(new \DateTime('2000-01-01 12:00:00'));
  110. $this->em->persist($sport);
  111. $this->em->flush();
  112. $this->em->clear();
  113. $repo = $this->em->getRepository(self::TEST_ENTITY_ARTICLE);
  114. $sport = $repo->findOneByTitle('sport forced');
  115. $this->assertEquals(
  116. '2000-01-01',
  117. $sport->getCreated()->format('Y-m-d')
  118. );
  119. $this->assertEquals(
  120. '2000-01-01 12:00:00',
  121. $sport->getUpdated()->format('Y-m-d H:i:s')
  122. );
  123. $published = new Type();
  124. $published->setTitle('Published');
  125. $sport->setType($published);
  126. $sport->setPublished(new \DateTime('2000-01-01 12:00:00'));
  127. $this->em->persist($sport);
  128. $this->em->persist($published);
  129. $this->em->flush();
  130. $this->em->clear();
  131. $sport = $repo->findOneByTitle('sport forced');
  132. $this->assertEquals(
  133. '2000-01-01 12:00:00',
  134. $sport->getPublished()->format('Y-m-d H:i:s')
  135. );
  136. }
  137. }