Merge pull request #3302 from JayDevlin/3250-deleteFormattedImages-test

FIX Image: deleteFormattedImages() regex
This commit is contained in:
Sean Harvey 2014-08-20 09:13:36 +12:00
commit 552b54201a
2 changed files with 63 additions and 1 deletions

View File

@ -582,7 +582,7 @@ class Image extends File {
} }
// All generate functions may appear any number of times in the image cache name. // All generate functions may appear any number of times in the image cache name.
$generateFuncs = implode('|', $generateFuncs); $generateFuncs = implode('|', $generateFuncs);
$pattern = "/^(({$generateFuncs})\d+\-)+" . preg_quote($this->Name) . "$/i"; $pattern = "/^(({$generateFuncs}).*\-)+" . preg_quote($this->Name) . "$/i";
foreach($cachedFiles as $cfile) { foreach($cachedFiles as $cfile) {
if(preg_match($pattern, $cfile)) { if(preg_match($pattern, $cfile)) {

View File

@ -268,4 +268,66 @@ class ImageTest extends SapphireTest {
$secondImagePath = $secondImage->getRelativePath(); $secondImagePath = $secondImage->getRelativePath();
$this->assertEquals($secondImagePath, $secondImage->Filename); $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;
}
} }