| <?php |
| /** |
| * ezcImageConversionHandlerGdTest |
| * |
| * Licensed to the Apache Software Foundation (ASF) under one |
| * or more contributor license agreements. See the NOTICE file |
| * distributed with this work for additional information |
| * regarding copyright ownership. The ASF licenses this file |
| * to you under the Apache License, Version 2.0 (the |
| * "License"); you may not use this file except in compliance |
| * with the License. You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, |
| * software distributed under the License is distributed on an |
| * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY |
| * KIND, either express or implied. See the License for the |
| * specific language governing permissions and limitations |
| * under the License. |
| * |
| * @package ImageConversion |
| * @version //autogentag// |
| * @copyright Copyright (C) 2005-2010 eZ Systems AS. All rights reserved. |
| * @license http://www.apache.org/licenses/LICENSE-2.0 Apache License, Version 2.0 |
| */ |
| |
| /** |
| * Require base class for handler tests. |
| */ |
| require_once "handler_test.php"; |
| |
| /** |
| * Test suite for ImageHandlerGd class. |
| * This test class contains all tests that are specific to the GD handler. |
| * |
| * @package ImageConversion |
| * @version //autogentag// |
| */ |
| class ezcImageConversionHandlerGdTest extends ezcImageConversionHandlerTest |
| { |
| public static function suite() |
| { |
| return new PHPUnit_Framework_TestSuite( "ezcImageConversionHandlerGdTest" ); |
| } |
| |
| protected function setUp() |
| { |
| try |
| { |
| $dummy = new ezcImageGdHandler( ezcImageGdBaseHandler::defaultSettings() ); |
| } |
| catch ( Exception $e ) |
| { |
| $this->markTestSkipped( $e->getMessage() ); |
| } |
| $this->handlerClass = "ezcImageGdHandler"; |
| parent::setUp(); |
| } |
| |
| public function testLoadSuccess() |
| { |
| $filePath = $this->testFiles["jpeg"]; |
| |
| $ref = $this->handler->load( $filePath ); |
| |
| $refProp = $this->getReferences(); |
| $imageRef = current( $refProp ); |
| |
| $this->assertEquals( |
| $imageRef["file"], |
| $filePath, |
| "Image reference not registered correctly." |
| ); |
| |
| $this->assertEquals( |
| $imageRef["mime"], |
| "image/jpeg", |
| "Image reference not registered correctly." |
| ); |
| } |
| |
| public function testLoadFailureFilenotexists() |
| { |
| $filePath = $this->testFiles["nonexistent"]; |
| |
| try |
| { |
| $ref = $this->handler->load( $filePath ); |
| } |
| catch ( ezcBaseFileNotFoundException $e ) |
| { |
| return; |
| } |
| $this->fail( "Required exception not thrown on not existing file." ); |
| } |
| |
| public function testLoadFailureUnknownmimetype() |
| { |
| $filePath = $this->testFiles["text"]; |
| |
| try |
| { |
| $ref = $this->handler->load( $filePath ); |
| } |
| catch ( ezcImageMimeTypeUnsupportedException $e ) |
| { |
| return; |
| } |
| $this->fail( "Required exception not thrown on not existing file." ); |
| } |
| |
| public function testLoadFailureUnknownMimeTypeParam() |
| { |
| $filePath = $this->testFiles['png']; |
| |
| try |
| { |
| $ref = $this->handler->load( $filePath, 'text/plain' ); |
| } |
| catch ( ezcImageMimeTypeUnsupportedException $e ) |
| { |
| return; |
| } |
| $this->fail( "Required exception not thrown on not existing file." ); |
| } |
| |
| public function testLoadCorruptJpegFailure() |
| { |
| $origPath = $this->testFiles['corrupt_jpeg']; |
| |
| try |
| { |
| $ref = $this->handler->load( $origPath ); |
| $this->fail( 'Exception not thrown on loading corrupt JPEG.' ); |
| } |
| catch ( ezcImageFileNotProcessableException $e ) {} |
| } |
| |
| public function testLoadCorruptJpegSuccess() |
| { |
| $origPath = $this->testFiles['corrupt_jpeg']; |
| $tmpPath = $this->getTempPath(); |
| |
| copy( $origPath, $tmpPath ); |
| |
| ini_set( "gd.jpeg_ignore_warning", true ); |
| |
| $ref = $this->handler->load( $tmpPath ); |
| |
| unlink( $tmpPath ); |
| |
| $this->handler->save( $ref ); |
| |
| ini_set( "gd.jpeg_ignore_warning", false ); |
| |
| $ref = $this->handler->load( $tmpPath ); |
| } |
| |
| public function testSaveOldfileNoconvert() |
| { |
| $srcPath = $this->testFiles["jpeg"]; |
| $dstPath = $this->getTempPath(); |
| |
| copy( $srcPath, $dstPath ); |
| |
| $copytime = filemtime( $dstPath ); |
| |
| $handler = new ezcImageGdHandler( ezcImageGdHandler::defaultSettings() ); |
| $ref = $handler->load( $dstPath ); |
| |
| unlink( $dstPath ); |
| |
| $handler->save( $ref ); |
| |
| $this->assertTrue( |
| file_exists( $dstPath ), |
| "File not correctly saved to old destination." |
| ); |
| } |
| |
| public function testSaveNewfileNoconvert() |
| { |
| $srcPath = $this->testFiles["jpeg"]; |
| $dstPath = $this->getTempPath(); |
| |
| $handler = new ezcImageGdHandler( ezcImageGdHandler::defaultSettings() ); |
| $ref = $handler->load( $srcPath ); |
| $handler->save( $ref, $dstPath ); |
| |
| $this->assertTrue( |
| file_exists( $dstPath ), |
| "File not correctly saved to new destination." |
| ); |
| } |
| |
| public function testSaveNewfileConvert() |
| { |
| $srcPath = $this->testFiles["jpeg"]; |
| $dstPath = $this->getTempPath(); |
| |
| $handler = new ezcImageGdHandler( ezcImageGdHandler::defaultSettings() ); |
| $ref = $handler->load( $srcPath ); |
| $handler->save( $ref, $dstPath, "image/png" ); |
| |
| $analyzer = new ezcImageAnalyzer( $dstPath ); |
| |
| $this->assertEquals( |
| "image/png", |
| $analyzer->mime, |
| "File not correctly saved to new destination." |
| ); |
| } |
| |
| public function testSaveNewfileQualityLow() |
| { |
| $srcPath = $this->testFiles["png"]; |
| $dstPath = $this->getTempPath(); |
| |
| $handler = new ezcImageGdHandler( ezcImageGdHandler::defaultSettings() ); |
| $ref = $handler->load( $srcPath ); |
| |
| $opts = new ezcImageSaveOptions(); |
| $opts->quality = 0; |
| |
| $handler->save( $ref, $dstPath, "image/jpeg", $opts ); |
| |
| $this->assertTrue( |
| filesize( $dstPath ) < 2000, |
| "File saved with too high quality." |
| ); |
| } |
| |
| public function testSaveNewfileQualityHigh() |
| { |
| $srcPath = $this->testFiles["png"]; |
| $dstPath = $this->getTempPath(); |
| |
| $handler = new ezcImageGdHandler( ezcImageGdHandler::defaultSettings() ); |
| $ref = $handler->load( $srcPath ); |
| |
| $opts = new ezcImageSaveOptions(); |
| $opts->quality = 100; |
| |
| $handler->save( $ref, $dstPath, "image/jpeg", $opts ); |
| |
| $this->assertTrue( |
| filesize( $dstPath ) > 30000, |
| "File saved with too low quality." |
| ); |
| } |
| |
| public function testSaveNewfileCompressionLow() |
| { |
| $srcPath = $this->testFiles["png"]; |
| $dstPath = $this->getTempPath(); |
| |
| $handler = new ezcImageGdHandler( ezcImageGdHandler::defaultSettings() ); |
| $ref = $handler->load( $srcPath ); |
| |
| $opts = new ezcImageSaveOptions(); |
| $opts->compression = 0; |
| |
| $handler->save( $ref, $dstPath, "image/png", $opts ); |
| |
| $this->assertTrue( |
| filesize( $dstPath ) > 100000, |
| "File saved with too high compression." |
| ); |
| } |
| |
| public function testSaveNewfileCompressionHigh() |
| { |
| $srcPath = $this->testFiles["png"]; |
| $dstPath = $this->getTempPath(); |
| |
| $handler = new ezcImageGdHandler( ezcImageGdHandler::defaultSettings() ); |
| $ref = $handler->load( $srcPath ); |
| |
| $opts = new ezcImageSaveOptions(); |
| $opts->compression = 9; |
| |
| $handler->save( $ref, $dstPath, "image/png", $opts ); |
| |
| $this->assertTrue( |
| filesize( $dstPath ) < 40000, |
| "File saved with too low compression." |
| ); |
| } |
| |
| public function testSaveFailureUnknownMimeType() |
| { |
| $srcPath = $this->testFiles['jpeg']; |
| $dstPath = $this->getTempPath(); |
| |
| $handler = new ezcImageGdHandler( ezcImageGdHandler::defaultSettings() ); |
| $ref = $handler->load( $srcPath ); |
| try |
| { |
| $handler->save( $ref, $dstPath, 'text/plain' ); |
| $this->fail( 'Exception not thrown on save with invalid MIME type.' ); |
| } |
| catch ( ezcImageMimeTypeUnsupportedException $e ) |
| {} |
| |
| $handler->close( $ref ); |
| } |
| |
| public function testConvertSuccess() |
| { |
| $filePath = $this->testFiles["jpeg"]; |
| |
| $ref = $this->handler->load( $filePath ); |
| $this->handler->convert( $ref, "image/png" ); |
| |
| $refProp = $this->getReferences(); |
| $imageRef = current( $refProp ); |
| |
| $this->assertTrue( |
| $imageRef["mime"] === "image/png", |
| "MIME type conversion not registered correctly." |
| ); |
| } |
| |
| public function testConvertFailure() |
| { |
| $filePath = $this->testFiles["jpeg"]; |
| |
| $ref = $this->handler->load( $filePath ); |
| |
| try |
| { |
| $this->handler->convert( $ref, "application/ezc" ); |
| } |
| catch ( ezcImageMimeTypeUnsupportedException $e ) |
| { |
| return; |
| } |
| $this->fail( "Exception for unknown conversion not thrown." ); |
| } |
| |
| public function testApplyFilterSingle() |
| { |
| $srcPath = $this->testFiles["jpeg"]; |
| $dstPath = $this->getTempPath(); |
| |
| $ref = $this->handler->load( $srcPath ); |
| $this->handler->applyFilter( $ref, new ezcImageFilter( "scale", array( "width" => 200, "height" => 200, "direction" => ezcImageGeometryFilters::SCALE_BOTH ) ) ); |
| $this->handler->save( $ref, $dstPath ); |
| $this->assertImageSimilar( |
| $this->getReferencePath(), |
| $dstPath, |
| "Applying single filter through handler failed.", |
| // ezcImageConversionTestCase::DEFAULT_SIMILARITY_GAP |
| 60 |
| ); |
| } |
| |
| public function testApplyFilterMultiple() |
| { |
| $srcPath = $this->testFiles["jpeg"]; |
| $dstPath = $this->getTempPath(); |
| |
| $ref = $this->handler->load( $srcPath ); |
| $this->handler->applyFilter( $ref, new ezcImageFilter( "scale", array( "width" => 200, "height" => 200, "direction" => ezcImageGeometryFilters::SCALE_BOTH ) ) ); |
| $this->handler->applyFilter( $ref, new ezcImageFilter( "crop", array( "x" => 50, "width" => 100, "y" => 50, "height" => 100 ) ) ); |
| $this->handler->applyFilter( $ref, new ezcImageFilter( "colorspace", array( "space" => ezcImageColorspaceFilters::COLORSPACE_SEPIA ) ) ); |
| $this->handler->save( $ref, $dstPath ); |
| |
| $this->assertImageSimilar( |
| $this->getReferencePath(), |
| $dstPath, |
| "Applying multiple filter through handler failed.", |
| // ezcImageConversionTestCase::DEFAULT_SIMILARITY_GAP |
| 80 |
| ); |
| } |
| |
| public function testApplyFilterFailureNonExistent() |
| { |
| $srcPath = $this->testFiles["jpeg"]; |
| $dstPath = $this->getTempPath(); |
| |
| $ref = $this->handler->load( $srcPath ); |
| |
| try |
| { |
| $this->handler->applyFilter( |
| $ref, |
| new ezcImageFilter( |
| "non-existent", |
| array( "width" => 200, "height" => 200, "direction" => ezcImageGeometryFilters::SCALE_BOTH ) |
| ) |
| ); |
| $this->fail( 'Exception not throwen on apply of non-existent filter.' ); |
| } |
| catch ( ezcImageFilterNotAvailableException $e ) |
| {} |
| } |
| |
| public function testConvertTransparentNonTransparent() |
| { |
| |
| $srcPath = $this->testFiles["png_transparent"]; |
| $dstPath = $this->getTempPath(); |
| |
| $ref = $this->handler->load( $srcPath ); |
| |
| $options = new ezcImageSaveOptions(); |
| $options->transparencyReplacementColor = array( 255, 0, 0 ); |
| |
| $this->handler->save( $ref, $dstPath, 'image/jpeg', $options ); |
| |
| $this->handler->close( $ref ); |
| $this->assertImageSimilar( |
| $this->getReferencePath(), |
| $dstPath, |
| "Converting transparent background failed.", |
| 500 |
| ); |
| } |
| } |
| ?> |