| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256 | 
							- <?php
 - 
 - namespace Gedmo\Translatable;
 - 
 - use Doctrine\Common\EventManager;
 - use Doctrine\ORM\Query;
 - use Gedmo\Translatable\TranslatableListener;
 - use Gedmo\Translatable\Query\TreeWalker\TranslationWalker;
 - use Tool\BaseTestCaseORM;
 - use Translatable\Fixture\Personal\Article;
 - use Translatable\Fixture\Personal\PersonalArticleTranslation;
 - 
 - /**
 -  * These are tests for translatable behavior
 -  *
 -  * @author Gediminas Morkevicius <gediminas.morkevicius@gmail.com>
 -  * @package Gedmo.Translatable
 -  * @link http://www.gediminasm.org
 -  * @license MIT License (http://www.opensource.org/licenses/mit-license.php)
 -  */
 - class PersonalTranslationTest extends BaseTestCaseORM
 - {
 -     const ARTICLE = 'Translatable\Fixture\Personal\Article';
 -     const TRANSLATION = 'Translatable\Fixture\Personal\PersonalArticleTranslation';
 -     const TREE_WALKER_TRANSLATION = 'Gedmo\\Translatable\\Query\\TreeWalker\\TranslationWalker';
 - 
 -     private $translatableListener;
 - 
 -     protected function setUp()
 -     {
 -         parent::setUp();
 - 
 -         $evm = new EventManager;
 -         $this->translatableListener = new TranslatableListener();
 -         $this->translatableListener->setTranslatableLocale('en');
 -         $this->translatableListener->setDefaultLocale('en');
 -         $evm->addEventSubscriber($this->translatableListener);
 - 
 -         $conn = array(
 -             'driver' => 'pdo_mysql',
 -             'host' => '127.0.0.1',
 -             'dbname' => 'test',
 -             'user' => 'root',
 -             'password' => 'nimda'
 -         );
 -         //$this->getMockCustomEntityManager($conn, $evm);
 -         $this->getMockSqliteEntityManager($evm);
 -     }
 - 
 -     /**
 -      * @test
 -      */
 -     function shouldPersistDefaultLocaleTranslationIfRequired()
 -     {
 -         $this->translatableListener->setPersistDefaultLocaleTranslation(true);
 -         $this->populate();
 -         $article = $this->em->find(self::ARTICLE, array('id' => 1));
 -         $translations = $article->getTranslations();
 -         $this->assertCount(3, $translations);
 -     }
 - 
 -     /**
 -      * @test
 -      */
 -     function shouldCreateTranslations()
 -     {
 -         $this->populate();
 -         $article = $this->em->find(self::ARTICLE, array('id' => 1));
 -         $translations = $article->getTranslations();
 -         $this->assertCount(2, $translations);
 -     }
 - 
 -     /**
 -      * @test
 -      */
 -     function shouldTranslateTheRecord()
 -     {
 -         $this->populate();
 -         $this->translatableListener->setTranslatableLocale('lt');
 - 
 -         $this->startQueryLog();
 -         $article = $this->em->find(self::ARTICLE, array('id' => 1));
 - 
 -         $sqlQueriesExecuted = $this->queryAnalyzer->getExecutedQueries();
 -         $this->assertCount(2, $sqlQueriesExecuted);
 -         $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]);
 -         $this->assertEquals('lt', $article->getTitle());
 -     }
 - 
 -     /**
 -      * @test
 -      */
 -     function shouldCascadeDeletionsByForeignKeyConstraints()
 -     {
 -         if ($this->em->getConnection()->getDatabasePlatform()->getName() == 'sqlite') {
 -             $this->markTestSkipped('Foreign key constraints does not map in sqlite.');
 -         }
 -         $this->populate();
 -         $this->em->createQuery('DELETE FROM '.self::ARTICLE.' a')->getSingleScalarResult();
 -         $trans = $this->em->getRepository(self::TRANSLATION)->findAll();
 - 
 -         $this->assertCount(0, $trans);
 -     }
 - 
 -     /**
 -      * @test
 -      */
 -     function shouldOverrideTranslationInEntityBeingTranslated()
 -     {
 -         $this->translatableListener->setDefaultLocale('de');
 -         $article = new Article;
 -         $article->setTitle('override');
 - 
 -         $enTranslation = new PersonalArticleTranslation;
 -         $enTranslation
 -             ->setField('title')
 -             ->setContent('en')
 -             ->setObject($article)
 -             ->setLocale('en')
 -         ;
 -         $this->em->persist($enTranslation);
 -         $this->em->persist($article);
 -         $this->em->flush();
 - 
 -         $trans = $this->em->createQuery('SELECT t FROM '.self::TRANSLATION.' t')->getArrayResult();
 -         $this->assertCount(1, $trans);
 -         $this->assertEquals('override', $trans[0]['content']);
 -     }
 - 
 -     /**
 -      * Covers issue #438
 -      * @test
 -      */
 -     function shouldPersistDefaultLocaleValue()
 -     {
 -         $this->translatableListener->setTranslatableLocale('de');
 -         $article = new Article;
 -         $article->setTitle('de');
 - 
 -         $deTranslation = new PersonalArticleTranslation;
 -         $deTranslation
 -             ->setField('title')
 -             ->setContent('de')
 -             ->setObject($article)
 -             ->setLocale('de')
 -         ;
 -         $this->em->persist($deTranslation);
 - 
 -         $enTranslation = new PersonalArticleTranslation;
 -         $enTranslation
 -             ->setField('title')
 -             ->setContent('en')
 -             ->setObject($article)
 -             ->setLocale('en')
 -         ;
 -         $this->em->persist($enTranslation);
 - 
 -         $this->em->persist($article);
 -         $this->em->flush();
 - 
 -         $this->translatableListener->setTranslatableLocale('en');
 -         $articles = $this->em->createQuery('SELECT t FROM '.self::ARTICLE.' t')->getArrayResult();
 -         $this->assertEquals('en', $articles[0]['title']);
 -         $trans = $this->em->createQuery('SELECT t FROM '.self::TRANSLATION.' t')->getArrayResult();
 -         $this->assertCount(2, $trans);
 -         foreach ($trans as $item){
 -             $this->assertEquals($item['locale'], $item['content']);
 -         }
 -     }
 - 
 -     /**
 -      * @test
 -      */
 -     function shouldFindFromIdentityMap()
 -     {
 -         $article = new Article;
 -         $article->setTitle('en');
 - 
 -         $ltTranslation = new PersonalArticleTranslation;
 -         $ltTranslation
 -             ->setField('title')
 -             ->setContent('lt')
 -             ->setObject($article)
 -             ->setLocale('lt')
 -         ;
 -         $this->em->persist($ltTranslation);
 -         $this->em->persist($article);
 -         $this->em->flush();
 - 
 -         $this->startQueryLog();
 -         $this->translatableListener->setTranslatableLocale('lt');
 -         $article->setTitle('change lt');
 - 
 -         $this->em->persist($article);
 -         $this->em->flush();
 -         $sqlQueriesExecuted = $this->queryAnalyzer->getExecutedQueries();
 -         $this->assertCount(3, $sqlQueriesExecuted); // one update, transaction start - commit
 -         $this->assertEquals("UPDATE article_translations SET content = 'change lt' WHERE id = 1", $sqlQueriesExecuted[1]);
 -     }
 - 
 -     /**
 -      * @test
 -      */
 -     function shouldBeAbleToUseTranslationQueryHint()
 -     {
 -         $this->populate();
 -         $dql = 'SELECT a.title FROM ' . self::ARTICLE . ' a';
 -         $query = $this
 -             ->em->createQuery($dql)
 -             ->setHint(Query::HINT_CUSTOM_OUTPUT_WALKER, self::TREE_WALKER_TRANSLATION)
 -             ->setHint(TranslatableListener::HINT_TRANSLATABLE_LOCALE, 'lt')
 -         ;
 - 
 -         $this->startQueryLog();
 -         $result = $query->getArrayResult();
 - 
 -         $this->assertCount(1, $result);
 -         $this->assertEquals('lt', $result[0]['title']);
 -         $sqlQueriesExecuted = $this->queryAnalyzer->getExecutedQueries();
 -         $this->assertCount(1, $sqlQueriesExecuted);
 -         $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]);
 -     }
 - 
 -     private function populate()
 -     {
 -         $article = new Article;
 -         $article->setTitle('en');
 - 
 -         $this->em->persist($article);
 -         $this->em->flush();
 - 
 -         $this->translatableListener->setTranslatableLocale('de');
 -         $article->setTitle('de');
 - 
 -         $ltTranslation = new PersonalArticleTranslation;
 -         $ltTranslation
 -             ->setField('title')
 -             ->setContent('lt')
 -             ->setObject($article)
 -             ->setLocale('lt')
 -         ;
 -         $this->em->persist($ltTranslation);
 -         $this->em->persist($article);
 -         $this->em->flush();
 -         $this->em->clear();
 -     }
 - 
 -     protected function getUsedEntityFixtures()
 -     {
 -         return array(
 -             self::ARTICLE,
 -             self::TRANSLATION
 -         );
 -     }
 - }
 
 
  |