PersonalTranslationTest.php 8.0KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256
  1. <?php
  2. namespace Gedmo\Translatable;
  3. use Doctrine\Common\EventManager;
  4. use Doctrine\ORM\Query;
  5. use Gedmo\Translatable\TranslatableListener;
  6. use Gedmo\Translatable\Query\TreeWalker\TranslationWalker;
  7. use Tool\BaseTestCaseORM;
  8. use Translatable\Fixture\Personal\Article;
  9. use Translatable\Fixture\Personal\PersonalArticleTranslation;
  10. /**
  11. * These are tests for translatable behavior
  12. *
  13. * @author Gediminas Morkevicius <gediminas.morkevicius@gmail.com>
  14. * @package Gedmo.Translatable
  15. * @link http://www.gediminasm.org
  16. * @license MIT License (http://www.opensource.org/licenses/mit-license.php)
  17. */
  18. class PersonalTranslationTest extends BaseTestCaseORM
  19. {
  20. const ARTICLE = 'Translatable\Fixture\Personal\Article';
  21. const TRANSLATION = 'Translatable\Fixture\Personal\PersonalArticleTranslation';
  22. const TREE_WALKER_TRANSLATION = 'Gedmo\\Translatable\\Query\\TreeWalker\\TranslationWalker';
  23. private $translatableListener;
  24. protected function setUp()
  25. {
  26. parent::setUp();
  27. $evm = new EventManager;
  28. $this->translatableListener = new TranslatableListener();
  29. $this->translatableListener->setTranslatableLocale('en');
  30. $this->translatableListener->setDefaultLocale('en');
  31. $evm->addEventSubscriber($this->translatableListener);
  32. $conn = array(
  33. 'driver' => 'pdo_mysql',
  34. 'host' => '127.0.0.1',
  35. 'dbname' => 'test',
  36. 'user' => 'root',
  37. 'password' => 'nimda'
  38. );
  39. //$this->getMockCustomEntityManager($conn, $evm);
  40. $this->getMockSqliteEntityManager($evm);
  41. }
  42. /**
  43. * @test
  44. */
  45. function shouldPersistDefaultLocaleTranslationIfRequired()
  46. {
  47. $this->translatableListener->setPersistDefaultLocaleTranslation(true);
  48. $this->populate();
  49. $article = $this->em->find(self::ARTICLE, array('id' => 1));
  50. $translations = $article->getTranslations();
  51. $this->assertCount(3, $translations);
  52. }
  53. /**
  54. * @test
  55. */
  56. function shouldCreateTranslations()
  57. {
  58. $this->populate();
  59. $article = $this->em->find(self::ARTICLE, array('id' => 1));
  60. $translations = $article->getTranslations();
  61. $this->assertCount(2, $translations);
  62. }
  63. /**
  64. * @test
  65. */
  66. function shouldTranslateTheRecord()
  67. {
  68. $this->populate();
  69. $this->translatableListener->setTranslatableLocale('lt');
  70. $this->startQueryLog();
  71. $article = $this->em->find(self::ARTICLE, array('id' => 1));
  72. $sqlQueriesExecuted = $this->queryAnalyzer->getExecutedQueries();
  73. $this->assertCount(2, $sqlQueriesExecuted);
  74. $this->assertEquals('SELECT t0.id AS id1, t0.locale AS locale2, t0.field AS field3, t0.content AS content4, t0.object_id AS object_id5 FROM article_translations t0 WHERE t0.object_id = 1', $sqlQueriesExecuted[1]);
  75. $this->assertEquals('lt', $article->getTitle());
  76. }
  77. /**
  78. * @test
  79. */
  80. function shouldCascadeDeletionsByForeignKeyConstraints()
  81. {
  82. if ($this->em->getConnection()->getDatabasePlatform()->getName() == 'sqlite') {
  83. $this->markTestSkipped('Foreign key constraints does not map in sqlite.');
  84. }
  85. $this->populate();
  86. $this->em->createQuery('DELETE FROM '.self::ARTICLE.' a')->getSingleScalarResult();
  87. $trans = $this->em->getRepository(self::TRANSLATION)->findAll();
  88. $this->assertCount(0, $trans);
  89. }
  90. /**
  91. * @test
  92. */
  93. function shouldOverrideTranslationInEntityBeingTranslated()
  94. {
  95. $this->translatableListener->setDefaultLocale('de');
  96. $article = new Article;
  97. $article->setTitle('override');
  98. $enTranslation = new PersonalArticleTranslation;
  99. $enTranslation
  100. ->setField('title')
  101. ->setContent('en')
  102. ->setObject($article)
  103. ->setLocale('en')
  104. ;
  105. $this->em->persist($enTranslation);
  106. $this->em->persist($article);
  107. $this->em->flush();
  108. $trans = $this->em->createQuery('SELECT t FROM '.self::TRANSLATION.' t')->getArrayResult();
  109. $this->assertCount(1, $trans);
  110. $this->assertEquals('override', $trans[0]['content']);
  111. }
  112. /**
  113. * Covers issue #438
  114. * @test
  115. */
  116. function shouldPersistDefaultLocaleValue()
  117. {
  118. $this->translatableListener->setTranslatableLocale('de');
  119. $article = new Article;
  120. $article->setTitle('de');
  121. $deTranslation = new PersonalArticleTranslation;
  122. $deTranslation
  123. ->setField('title')
  124. ->setContent('de')
  125. ->setObject($article)
  126. ->setLocale('de')
  127. ;
  128. $this->em->persist($deTranslation);
  129. $enTranslation = new PersonalArticleTranslation;
  130. $enTranslation
  131. ->setField('title')
  132. ->setContent('en')
  133. ->setObject($article)
  134. ->setLocale('en')
  135. ;
  136. $this->em->persist($enTranslation);
  137. $this->em->persist($article);
  138. $this->em->flush();
  139. $this->translatableListener->setTranslatableLocale('en');
  140. $articles = $this->em->createQuery('SELECT t FROM '.self::ARTICLE.' t')->getArrayResult();
  141. $this->assertEquals('en', $articles[0]['title']);
  142. $trans = $this->em->createQuery('SELECT t FROM '.self::TRANSLATION.' t')->getArrayResult();
  143. $this->assertCount(2, $trans);
  144. foreach ($trans as $item){
  145. $this->assertEquals($item['locale'], $item['content']);
  146. }
  147. }
  148. /**
  149. * @test
  150. */
  151. function shouldFindFromIdentityMap()
  152. {
  153. $article = new Article;
  154. $article->setTitle('en');
  155. $ltTranslation = new PersonalArticleTranslation;
  156. $ltTranslation
  157. ->setField('title')
  158. ->setContent('lt')
  159. ->setObject($article)
  160. ->setLocale('lt')
  161. ;
  162. $this->em->persist($ltTranslation);
  163. $this->em->persist($article);
  164. $this->em->flush();
  165. $this->startQueryLog();
  166. $this->translatableListener->setTranslatableLocale('lt');
  167. $article->setTitle('change lt');
  168. $this->em->persist($article);
  169. $this->em->flush();
  170. $sqlQueriesExecuted = $this->queryAnalyzer->getExecutedQueries();
  171. $this->assertCount(3, $sqlQueriesExecuted); // one update, transaction start - commit
  172. $this->assertEquals("UPDATE article_translations SET content = 'change lt' WHERE id = 1", $sqlQueriesExecuted[1]);
  173. }
  174. /**
  175. * @test
  176. */
  177. function shouldBeAbleToUseTranslationQueryHint()
  178. {
  179. $this->populate();
  180. $dql = 'SELECT a.title FROM ' . self::ARTICLE . ' a';
  181. $query = $this
  182. ->em->createQuery($dql)
  183. ->setHint(Query::HINT_CUSTOM_OUTPUT_WALKER, self::TREE_WALKER_TRANSLATION)
  184. ->setHint(TranslatableListener::HINT_TRANSLATABLE_LOCALE, 'lt')
  185. ;
  186. $this->startQueryLog();
  187. $result = $query->getArrayResult();
  188. $this->assertCount(1, $result);
  189. $this->assertEquals('lt', $result[0]['title']);
  190. $sqlQueriesExecuted = $this->queryAnalyzer->getExecutedQueries();
  191. $this->assertCount(1, $sqlQueriesExecuted);
  192. $this->assertEquals("SELECT t1_.content AS title0 FROM Article a0_ LEFT JOIN article_translations t1_ ON t1_.locale = 'lt' AND t1_.field = 'title' AND t1_.object_id = a0_.id", $sqlQueriesExecuted[0]);
  193. }
  194. private function populate()
  195. {
  196. $article = new Article;
  197. $article->setTitle('en');
  198. $this->em->persist($article);
  199. $this->em->flush();
  200. $this->translatableListener->setTranslatableLocale('de');
  201. $article->setTitle('de');
  202. $ltTranslation = new PersonalArticleTranslation;
  203. $ltTranslation
  204. ->setField('title')
  205. ->setContent('lt')
  206. ->setObject($article)
  207. ->setLocale('lt')
  208. ;
  209. $this->em->persist($ltTranslation);
  210. $this->em->persist($article);
  211. $this->em->flush();
  212. $this->em->clear();
  213. }
  214. protected function getUsedEntityFixtures()
  215. {
  216. return array(
  217. self::ARTICLE,
  218. self::TRANSLATION
  219. );
  220. }
  221. }