mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 14:05:37 +02:00
Merge pull request #4578 from jonom/image-properties-3
FIX Resampled images inherit source properties
This commit is contained in:
commit
46ebdd5a8d
@ -691,11 +691,7 @@ class Image extends File implements Flushable {
|
|||||||
call_user_func_array(array($this, "generateFormattedImage"), $args);
|
call_user_func_array(array($this, "generateFormattedImage"), $args);
|
||||||
}
|
}
|
||||||
|
|
||||||
$cached = new Image_Cached($cacheFile);
|
$cached = new Image_Cached($cacheFile, false, $this);
|
||||||
// Pass through the title so the templates can use it
|
|
||||||
$cached->Title = $this->Title;
|
|
||||||
// Pass through the parent, to store cached images in correct folder.
|
|
||||||
$cached->ParentID = $this->ParentID;
|
|
||||||
return $cached;
|
return $cached;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1037,8 +1033,9 @@ class Image_Cached extends Image {
|
|||||||
* @param boolean $isSingleton This this to true if this is a singleton() object, a stub for calling methods.
|
* @param boolean $isSingleton This this to true if this is a singleton() object, a stub for calling methods.
|
||||||
* Singletons don't have their defaults set.
|
* Singletons don't have their defaults set.
|
||||||
*/
|
*/
|
||||||
public function __construct($filename = null, $isSingleton = false) {
|
public function __construct($filename = null, $isSingleton = false, Image $sourceImage = null) {
|
||||||
parent::__construct(array(), $isSingleton);
|
parent::__construct(array(), $isSingleton);
|
||||||
|
if ($sourceImage) $this->update($sourceImage->toMap());
|
||||||
$this->ID = -1;
|
$this->ID = -1;
|
||||||
$this->Filename = $filename;
|
$this->Filename = $filename;
|
||||||
}
|
}
|
||||||
|
@ -340,6 +340,19 @@ class ImageTest extends SapphireTest {
|
|||||||
$this->assertTrue(file_exists($p), 'Resized image exists after regeneration call');
|
$this->assertTrue(file_exists($p), 'Resized image exists after regeneration call');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test that propertes from the source Image are inherited by resampled images
|
||||||
|
*/
|
||||||
|
public function testPropertyInheritance() {
|
||||||
|
$testString = 'This is a test';
|
||||||
|
$origImage = $this->objFromFixture('Image', 'imageWithTitle');
|
||||||
|
$origImage->TestProperty = $testString;
|
||||||
|
$resampled = $origImage->ScaleWidth(10);
|
||||||
|
$this->assertEquals($resampled->TestProperty, $testString);
|
||||||
|
$resampled2 = $resampled->ScaleWidth(5);
|
||||||
|
$this->assertEquals($resampled2->TestProperty, $testString);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Tests that cached images are regenerated properly after a cached file is renamed with new arguments
|
* Tests that cached images are regenerated properly after a cached file is renamed with new arguments
|
||||||
* ToDo: This doesn't seem like something that is worth testing - what is the point of this?
|
* ToDo: This doesn't seem like something that is worth testing - what is the point of this?
|
||||||
|
Loading…
Reference in New Issue
Block a user