mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 12:05:37 +00:00
Merge pull request #3302 from JayDevlin/3250-deleteFormattedImages-test
FIX Image: deleteFormattedImages() regex
This commit is contained in:
commit
552b54201a
@ -582,7 +582,7 @@ class Image extends File {
|
||||
}
|
||||
// All generate functions may appear any number of times in the image cache name.
|
||||
$generateFuncs = implode('|', $generateFuncs);
|
||||
$pattern = "/^(({$generateFuncs})\d+\-)+" . preg_quote($this->Name) . "$/i";
|
||||
$pattern = "/^(({$generateFuncs}).*\-)+" . preg_quote($this->Name) . "$/i";
|
||||
|
||||
foreach($cachedFiles as $cfile) {
|
||||
if(preg_match($pattern, $cfile)) {
|
||||
|
@ -268,4 +268,66 @@ class ImageTest extends SapphireTest {
|
||||
$secondImagePath = $secondImage->getRelativePath();
|
||||
$this->assertEquals($secondImagePath, $secondImage->Filename);
|
||||
}
|
||||
|
||||
/**
|
||||
* Test all generate methods
|
||||
*/
|
||||
public function testGenerateMethods() {
|
||||
$image = $this->objFromFixture('Image', 'imageWithoutTitle');
|
||||
$generateMethods = $this->getGenerateMethods();
|
||||
|
||||
// test each generate method
|
||||
foreach ($generateMethods as $method) {
|
||||
$generatedImage = $image->$method(333, 333, 'FFFFFF');
|
||||
$this->assertFileExists(
|
||||
$generatedImage->getFullPath(),
|
||||
'Formatted ' . $method . ' image exists'
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Test deleteFormattedImages() against all generate methods
|
||||
*/
|
||||
public function testDeleteFormattedImages() {
|
||||
$image = $this->objFromFixture('Image', 'imageWithoutTitle');
|
||||
$generateMethods = $this->getGenerateMethods();
|
||||
|
||||
// get paths for each generate method
|
||||
$paths = array();
|
||||
foreach ($generateMethods as $method) {
|
||||
$generatedImage = $image->$method(333, 333, 'FFFFFF');
|
||||
$paths[$method] = $generatedImage->getFullPath();
|
||||
}
|
||||
|
||||
// delete formatted images
|
||||
$image->deleteFormattedImages();
|
||||
|
||||
// test that all formatted images are deleted
|
||||
foreach ($paths as $method => $path) {
|
||||
$this->assertFalse(
|
||||
file_exists($path),
|
||||
'Formatted ' . $method . ' image does not exist'
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @param bool $custom include methods added dynamically at runtime
|
||||
* @return array
|
||||
*/
|
||||
protected function getGenerateMethods($custom = true) {
|
||||
$generateMethods = array();
|
||||
$methodNames = Image::create()->allMethodNames($custom);
|
||||
|
||||
foreach ($methodNames as $methodName) {
|
||||
if (substr($methodName, 0, 8) == 'generate' && $methodName != 'generateformattedimage') {
|
||||
$format = substr($methodName, 8);
|
||||
$generateMethods[] = $format;
|
||||
}
|
||||
}
|
||||
|
||||
return $generateMethods;
|
||||
}
|
||||
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user