Test case: class changes propagate to translations when published

This commit is contained in:
Jeremy Thomerson 2013-08-18 01:46:46 +00:00
parent fe6696a8f3
commit 7534807137

View File

@ -15,7 +15,7 @@ class TranslatableTest extends FunctionalTest {
); );
protected $requiredExtensions = array( protected $requiredExtensions = array(
'SiteTree' => array('Translatable'), 'SiteTree' => array('Translatable', 'Versioned', 'EveryoneCanPublish'),
'SiteConfig' => array('Translatable'), 'SiteConfig' => array('Translatable'),
'TranslatableTest_DataObject' => array('Translatable'), 'TranslatableTest_DataObject' => array('Translatable'),
'TranslatableTest_OneByLocaleDataObject' => array('Translatable'), 'TranslatableTest_OneByLocaleDataObject' => array('Translatable'),
@ -71,7 +71,7 @@ class TranslatableTest extends FunctionalTest {
Translatable::enable_locale_filter(); Translatable::enable_locale_filter();
$found = Translatable::get_one_by_locale('TranslatableTest_OneByLocaleDataObject', $obj->Locale); $found = Translatable::get_one_by_locale('TranslatableTest_OneByLocaleDataObject', $obj->Locale);
$this->assertNotNull($found, 'should have found one for ' . $obj->Locale); $this->assertNotNull($found, 'should have found one for ' . $obj->Locale);
$this->assertEquals($obj->ID, $found->ID); $this->assertEquals($obj->ID, $found->ID);
$translated = $obj->createTranslation('de_DE'); $translated = $obj->createTranslation('de_DE');
@ -226,6 +226,12 @@ class TranslatableTest extends FunctionalTest {
); );
} }
function assertClass($class, $node) {
$this->assertNotNull($node);
$this->assertEquals($class, $node->ClassName);
$this->assertEquals($class, get_class($node));
}
function testChangingClassOfDefaultLocaleTranslationChangesOthers() { function testChangingClassOfDefaultLocaleTranslationChangesOthers() {
// see https://github.com/silverstripe/silverstripe-translatable/issues/97 // see https://github.com/silverstripe/silverstripe-translatable/issues/97
// create an English SiteTree // create an English SiteTree
@ -247,12 +253,9 @@ class TranslatableTest extends FunctionalTest {
$esPg = DataObject::get_by_id('Page', $esST->ID, $cache = false); $esPg = DataObject::get_by_id('Page', $esST->ID, $cache = false);
// make sure they are all the right class // make sure they are all the right class
$this->assertEquals('Page', $enPg->ClassName); $this->assertClass('Page', $enPg);
$this->assertEquals('Page', get_class($enPg)); $this->assertClass('Page', $frPg);
$this->assertEquals('Page', $frPg->ClassName); $this->assertClass('Page', $esPg);
$this->assertEquals('Page', get_class($frPg));
$this->assertEquals('Page', $esPg->ClassName);
$this->assertEquals('Page', get_class($esPg));
// test that we get the right translations back from each instance // test that we get the right translations back from each instance
$this->assertArrayEqualsAfterSort( $this->assertArrayEqualsAfterSort(
@ -268,6 +271,36 @@ class TranslatableTest extends FunctionalTest {
$esPg->getTranslations()->column('Locale') $esPg->getTranslations()->column('Locale')
); );
} }
function testChangingClassOfDefaultLocaleTranslationChangesOthersWhenPublished() {
// create an English SiteTree
$enST = new SiteTree();
$enST->Locale = 'en_US';
$enST->write();
$enST->doPublish();
// create and publish French and Spanish translations
$frST = $enST->createTranslation('fr_FR');
$this->assertTrue($frST->doPublish(), 'should have been able to publish French translation');
$esST = $enST->createTranslation('es_ES');
$this->assertTrue($esST->doPublish(), 'should have been able to publish Spanish translation');
// change the class name of the default locale's translation (as CMS admin would)
// and publish the change - we should see both versions of English change class
$enST->setClassName('Page');
$enST->doPublish();
$this->assertClass('Page', Versioned::get_one_by_stage('SiteTree', 'Stage', '"ID" = ' . $enST->ID));
$this->assertClass('Page', Versioned::get_one_by_stage('SiteTree', 'Live', '"ID" = ' . $enST->ID));
// and all of the draft versions of translations:
$this->assertClass('Page', Versioned::get_one_by_stage('SiteTree', 'Stage', '"ID" = ' . $frST->ID));
$this->assertClass('Page', Versioned::get_one_by_stage('SiteTree', 'Stage', '"ID" = ' . $esST->ID));
// and all of the live versions of translations as well:
$this->assertClass('Page', Versioned::get_one_by_stage('SiteTree', 'Live', '"ID" = ' . $frST->ID));
$this->assertClass('Page', Versioned::get_one_by_stage('SiteTree', 'Live', '"ID" = ' . $esST->ID));
}
function testTranslationGroupsWhenTranslationIsSubclass() { function testTranslationGroupsWhenTranslationIsSubclass() {
// create an English SiteTree // create an English SiteTree
@ -303,16 +336,13 @@ class TranslatableTest extends FunctionalTest {
$esPg = DataObject::get_by_id('Page', $esST->ID, $cache = false); $esPg = DataObject::get_by_id('Page', $esST->ID, $cache = false);
// make sure we successfully changed the class // make sure we successfully changed the class
$this->assertEquals('Page', $esPg->ClassName); $this->assertClass('Page', $esPg);
$this->assertEquals('Page', get_class($esPg));
// and make sure that the class of the others did not change // and make sure that the class of the others did not change
$frST = DataObject::get_by_id('SiteTree', $frST->ID, $cache = false); $frST = DataObject::get_by_id('SiteTree', $frST->ID, $cache = false);
$this->assertEquals('SiteTree', $frST->ClassName); $this->assertClass('SiteTree', $frST);
$this->assertEquals('SiteTree', get_class($frST));
$enST = DataObject::get_by_id('SiteTree', $enST->ID, $cache = false); $enST = DataObject::get_by_id('SiteTree', $enST->ID, $cache = false);
$this->assertEquals('SiteTree', $enST->ClassName); $this->assertClass('SiteTree', $enST);
$this->assertEquals('SiteTree', get_class($enST));
// now that we know our edge case is successfully configured, we need to // now that we know our edge case is successfully configured, we need to
// make sure that we get the right translations back from everything // make sure that we get the right translations back from everything
@ -1213,4 +1243,12 @@ class TranslatableTest_Page extends Page implements TestOnly {
} }
} }
class EveryoneCanPublish extends DataExtension {
function canPublish($member = null) {
return true;
}
}
TranslatableTest_DataObject::add_extension('TranslatableTest_Extension'); TranslatableTest_DataObject::add_extension('TranslatableTest_Extension');