Issue138Test.php 2.7KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. <?php
  2. namespace Gedmo\Translatable;
  3. use Doctrine\Common\EventManager;
  4. use Tool\BaseTestCaseORM;
  5. use Translatable\Fixture\Issue138\Article;
  6. use Gedmo\Translatable\Query\TreeWalker\TranslationWalker;
  7. use Doctrine\ORM\Query;
  8. /**
  9. * These are tests for translatable behavior
  10. *
  11. * @author Gediminas Morkevicius <gediminas.morkevicius@gmail.com>
  12. * @package Gedmo.Translatable
  13. * @link http://www.gediminasm.org
  14. * @license MIT License (http://www.opensource.org/licenses/mit-license.php)
  15. */
  16. class Issue138Test extends BaseTestCaseORM
  17. {
  18. const ARTICLE = 'Translatable\\Fixture\\Issue138\\Article';
  19. const TRANSLATION = 'Gedmo\\Translatable\\Entity\\Translation';
  20. const TREE_WALKER_TRANSLATION = 'Gedmo\\Translatable\\Query\\TreeWalker\\TranslationWalker';
  21. private $translatableListener;
  22. protected function setUp()
  23. {
  24. parent::setUp();
  25. $evm = new EventManager;
  26. $this->translatableListener = new TranslatableListener();
  27. $this->translatableListener->setTranslatableLocale('en');
  28. $this->translatableListener->setDefaultLocale('en');
  29. $this->translatableListener->setTranslationFallback(true);
  30. $evm->addEventSubscriber($this->translatableListener);
  31. $this->getMockSqliteEntityManager($evm);
  32. }
  33. public function testIssue138()
  34. {
  35. $this->populate();
  36. $dql = 'SELECT a FROM ' . self::ARTICLE . ' a';
  37. $dql .= " WHERE a.title LIKE '%foo%'";
  38. $q = $this->em->createQuery($dql);
  39. $q->setHint(Query::HINT_CUSTOM_OUTPUT_WALKER, self::TREE_WALKER_TRANSLATION);
  40. // array hydration
  41. $this->translatableListener->setTranslatableLocale('en_us');
  42. //die($q->getSQL());
  43. $result = $q->getArrayResult();
  44. $this->assertEquals(1, count($result));
  45. $this->assertEquals('Food', $result[0]['title']);
  46. }
  47. protected function getUsedEntityFixtures()
  48. {
  49. return array(
  50. self::ARTICLE,
  51. self::TRANSLATION,
  52. );
  53. }
  54. private function populate()
  55. {
  56. $repo = $this->em->getRepository(self::ARTICLE);
  57. $food = new Article;
  58. $food->setTitle('Food');
  59. $food->setTitleTest('about food');
  60. $citron = new Article;
  61. $citron->setTitle('Citron');
  62. $citron->setTitleTest('something citron');
  63. $this->em->persist($food);
  64. $this->em->persist($citron);
  65. $this->em->flush();
  66. $this->translatableListener->setTranslatableLocale('lt_lt');
  67. $food->setTitle('Maistas');
  68. $food->setTitleTest('apie maista');
  69. $citron->setTitle('Citrina');
  70. $citron->setTitleTest('kazkas citrina');
  71. $this->em->persist($food);
  72. $this->em->persist($citron);
  73. $this->em->flush();
  74. $this->em->clear();
  75. }
  76. }