mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 14:05:37 +02:00
Merge branch '4.2' into 4
This commit is contained in:
commit
7d201309ad
@ -49,6 +49,11 @@ class ViewableData_Customised extends ViewableData
|
||||
$this->customised->$property = $this->original->$property = $value;
|
||||
}
|
||||
|
||||
public function __isset($property)
|
||||
{
|
||||
return isset($this->customised->$property) || isset($this->original->$property) || parent::__isset($property);
|
||||
}
|
||||
|
||||
public function hasMethod($method)
|
||||
{
|
||||
return $this->customised->hasMethod($method) || $this->original->hasMethod($method);
|
||||
|
55
tests/php/View/ViewableDataCustomisedTest.php
Normal file
55
tests/php/View/ViewableDataCustomisedTest.php
Normal file
@ -0,0 +1,55 @@
|
||||
<?php
|
||||
|
||||
namespace SilverStripe\View\Tests;
|
||||
|
||||
use SilverStripe\Dev\Constraint\ViewableDataContains;
|
||||
use SilverStripe\Dev\SapphireTest;
|
||||
use SilverStripe\View\ArrayData;
|
||||
use SilverStripe\View\ViewableData_Customised;
|
||||
|
||||
/**
|
||||
* Test for ViewableData_Customised.
|
||||
*/
|
||||
class ViewableDataCustomisedTest extends SapphireTest
|
||||
{
|
||||
public function testNestedViewableDataCustomisedAsCustomised()
|
||||
{
|
||||
$outerCustomised = ViewableData_Customised::create($this->makeOuterOriginal(), $this->makeInnerViewableDataCustomised());
|
||||
$this->assertThat($outerCustomised, $this->makeTestConstraint());
|
||||
}
|
||||
|
||||
public function testNestedViewableDataCustomisedAsOriginal()
|
||||
{
|
||||
$outerCustomised = ViewableData_Customised::create($this->makeInnerViewableDataCustomised(), $this->makeOuterOriginal());
|
||||
$this->assertThat($outerCustomised, $this->makeTestConstraint());
|
||||
}
|
||||
|
||||
private function makeTestConstraint()
|
||||
{
|
||||
return new ViewableDataContains([
|
||||
'outerOriginal' => 'foobar',
|
||||
'innerOriginal' => 'hello',
|
||||
'innerCustomised' => 'world',
|
||||
]);
|
||||
}
|
||||
|
||||
private function makeOuterOriginal()
|
||||
{
|
||||
return ArrayData::create([
|
||||
'outerOriginal' => 'foobar',
|
||||
]);
|
||||
}
|
||||
|
||||
private function makeInnerViewableDataCustomised()
|
||||
{
|
||||
$original = ArrayData::create([
|
||||
'innerOriginal' => 'hello',
|
||||
]);
|
||||
|
||||
$customised = ArrayData::create([
|
||||
'innerCustomised' => 'world',
|
||||
]);
|
||||
|
||||
return ViewableData_Customised::create($original, $customised);
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user