2007-09-04 20:41:23 +00:00
< ? php
/*
* $Id $
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* " AS IS " AND ANY EXPRESS OR IMPLIED WARRANTIES , INCLUDING , BUT NOT
* LIMITED TO , THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
* A PARTICULAR PURPOSE ARE DISCLAIMED . IN NO EVENT SHALL THE COPYRIGHT
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT , INDIRECT , INCIDENTAL ,
* SPECIAL , EXEMPLARY , OR CONSEQUENTIAL DAMAGES ( INCLUDING , BUT NOT
* LIMITED TO , PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES ; LOSS OF USE ,
* DATA , OR PROFITS ; OR BUSINESS INTERRUPTION ) HOWEVER CAUSED AND ON ANY
* THEORY OF LIABILITY , WHETHER IN CONTRACT , STRICT LIABILITY , OR TORT
* ( INCLUDING NEGLIGENCE OR OTHERWISE ) ARISING IN ANY WAY OUT OF THE USE
* OF THIS SOFTWARE , EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE .
*
* This software consists of voluntary contributions made by many individuals
* and is licensed under the LGPL . For more information , see
* < http :// www . phpdoctrine . com >.
*/
/**
* Doctrine_I18n_TestCase
*
* @ package Doctrine
* @ author Konsta Vesterinen < kvesteri @ cc . hut . fi >
* @ license http :// www . opensource . org / licenses / lgpl - license . php LGPL
* @ category Object Relational Mapping
* @ link www . phpdoctrine . com
* @ since 1.0
* @ version $Revision $
*/
class Doctrine_I18n_TestCase extends Doctrine_UnitTestCase
{
public function prepareData ()
{ }
public function prepareTables ()
2007-09-12 21:52:34 +00:00
{
$this -> tables = array ();
2007-09-04 20:41:23 +00:00
parent :: prepareTables ();
}
2007-09-12 21:52:34 +00:00
public function testTranslationTableGetsExported ()
{
$this -> conn -> setAttribute ( Doctrine :: ATTR_EXPORT , Doctrine :: EXPORT_ALL );
$this -> assertTrue ( Doctrine :: EXPORT_ALL & Doctrine :: EXPORT_TABLES );
$this -> assertTrue ( Doctrine :: EXPORT_ALL & Doctrine :: EXPORT_CONSTRAINTS );
$this -> assertTrue ( Doctrine :: EXPORT_ALL & Doctrine :: EXPORT_PLUGINS );
$sql = $this -> conn -> export -> exportClassesSql ( array ( 'I18nTest' ));
foreach ( $sql as $query ) {
$this -> conn -> exec ( $query );
}
}
2007-10-05 21:14:46 +00:00
public function testTranslatedColumnsAreRemovedFromMainComponent ()
{
$i = new I18nTest ();
$columns = $i -> getTable () -> getColumns ();
$this -> assertFalse ( isset ( $columns [ 'title' ]));
$this -> assertFalse ( isset ( $columns [ 'name' ]));
}
2007-09-12 21:52:34 +00:00
public function testTranslationTableIsInitializedProperly ()
{
$i = new I18nTest ();
2007-10-05 21:18:40 +00:00
$i -> id = 1 ;
2007-09-12 21:52:34 +00:00
2007-10-05 21:14:46 +00:00
$i -> Translation [ 'EN' ] -> name = 'some name' ;
$i -> Translation [ 'EN' ] -> title = 'some title' ;
2007-09-12 21:52:34 +00:00
$this -> assertEqual ( $i -> Translation -> getTable () -> getComponentName (), 'I18nTestTranslation' );
$i -> Translation [ 'FI' ] -> name = 'joku nimi' ;
$i -> Translation [ 'FI' ] -> title = 'joku otsikko' ;
$i -> Translation [ 'FI' ] -> lang = 'FI' ;
$i -> save ();
$this -> conn -> clear ();
$t = Doctrine_Query :: create () -> from ( 'I18nTestTranslation' ) -> fetchOne ();
2007-10-05 21:14:46 +00:00
$this -> assertEqual ( $t -> name , 'some name' );
$this -> assertEqual ( $t -> title , 'some title' );
$this -> assertEqual ( $t -> lang , 'EN' );
2007-09-12 21:52:34 +00:00
}
public function testDataFetching ()
{
2007-10-05 21:14:46 +00:00
$i = Doctrine_Query :: create () -> from ( 'I18nTest i' ) -> innerJoin ( 'i.Translation t INDEXBY t.lang' ) -> orderby ( 't.lang' ) -> fetchOne ( array (), Doctrine :: HYDRATE_ARRAY );
2007-10-05 21:18:40 +00:00
2007-10-05 21:14:46 +00:00
$this -> assertEqual ( $i [ 'Translation' ][ 'EN' ][ 'name' ], 'some name' );
$this -> assertEqual ( $i [ 'Translation' ][ 'EN' ][ 'title' ], 'some title' );
$this -> assertEqual ( $i [ 'Translation' ][ 'EN' ][ 'lang' ], 'EN' );
2007-09-12 21:52:34 +00:00
$this -> assertEqual ( $i [ 'Translation' ][ 'FI' ][ 'name' ], 'joku nimi' );
$this -> assertEqual ( $i [ 'Translation' ][ 'FI' ][ 'title' ], 'joku otsikko' );
$this -> assertEqual ( $i [ 'Translation' ][ 'FI' ][ 'lang' ], 'FI' );
}
2007-10-05 21:14:46 +00:00
public function testIndexByLangIsAttachedToNewlyCreatedCollections ()
{
$coll = new Doctrine_Collection ( 'I18nTestTranslation' );
$coll [ 'EN' ][ 'name' ] = 'some name' ;
$this -> assertEqual ( $coll [ 'EN' ] -> lang , 'EN' );
}
public function testIndexByLangIsAttachedToFetchedCollections ()
{
$coll = Doctrine_Query :: create () -> from ( 'I18nTestTranslation' ) -> execute ();
$this -> assertTrue ( $coll [ 'FI' ] -> exists ());
}
2007-09-04 20:41:23 +00:00
}