Merged FileBackend branch. Manually avoiding merging the many prop-only changes SVN...
[lhc/web/wiklou.git] / tests / phpunit / includes / media / GIFTest.php
index 42c25ca..3665835 100644 (file)
@@ -2,12 +2,22 @@
 class GIFHandlerTest extends MediaWikiTestCase {
 
        public function setUp() {
-               $this->filePath = dirname( __FILE__ ) . '/../../data/media/';
+               $this->filePath = dirname( __FILE__ ) .  '/../../data/media';
+               $this->backend = new FSFileBackend( array(
+                       'name'           => 'localtesting',
+                       'lockManager'    => 'nullLockManager',
+                       'containerPaths' => array( 'data' => $this->filePath )
+               ) );
+               $this->repo = new FSRepo( array(
+                       'name'    => 'temp',
+                       'url'     => 'http://localhost/thumbtest',
+                       'backend' => $this->backend
+               ) );
                $this->handler = new GIFHandler();
        }
 
        public function testInvalidFile() {
-               $res = $this->handler->getMetadata( null, $this->filePath . 'README' );
+               $res = $this->handler->getMetadata( null, $this->filePath . '/README' );
                $this->assertEquals( GIFHandler::BROKEN_FILE, $res );
        }
        /**
@@ -16,8 +26,7 @@ class GIFHandlerTest extends MediaWikiTestCase {
         * @dataProvider dataIsAnimated
         */
        public function testIsAnimanted( $filename, $expected ) {
-               $file = UnregisteredLocalFile::newFromPath( $this->filePath . $filename,
-                       'image/gif' );
+               $file = $this->dataFile( $filename, 'image/gif' );
                $actual = $this->handler->isAnimatedImage( $file );
                $this->assertEquals( $expected, $actual );
        }
@@ -34,8 +43,7 @@ class GIFHandlerTest extends MediaWikiTestCase {
         * @dataProvider dataGetImageArea
         */
        public function testGetImageArea( $filename, $expected ) {
-               $file = UnregisteredLocalFile::newFromPath( $this->filePath . $filename,
-                       'image/gif' );
+               $file = $this->dataFile( $filename, 'image/gif' );
                $actual = $this->handler->getImageArea( $file, $file->getWidth(), $file->getHeight() );
                $this->assertEquals( $expected, $actual );
        }
@@ -71,15 +79,20 @@ class GIFHandlerTest extends MediaWikiTestCase {
         * @dataProvider dataGetMetadata
         */
        public function testGetMetadata( $filename, $expected ) {
-               $file = UnregisteredLocalFile::newFromPath( $this->filePath . $filename,
-                       'image/gif' );
-               $actual = $this->handler->getMetadata( $file, $this->filePath . $filename );
+               $file = $this->dataFile( $filename, 'image/gif' );
+               $actual = $this->handler->getMetadata( $file, "$this->filePath/$filename" );
                $this->assertEquals( unserialize( $expected ), unserialize( $actual ) );
        }
+
        public function dataGetMetadata() {
                return array(
                        array( 'nonanimated.gif', 'a:4:{s:10:"frameCount";i:1;s:6:"looped";b:0;s:8:"duration";d:0.1000000000000000055511151231257827021181583404541015625;s:8:"metadata";a:2:{s:14:"GIFFileComment";a:1:{i:0;s:35:"GIF test file ⁕ Created with GIMP";}s:15:"_MW_GIF_VERSION";i:1;}}' ),
                        array( 'animated-xmp.gif', 'a:4:{s:10:"frameCount";i:4;s:6:"looped";b:1;s:8:"duration";d:2.399999999999999911182158029987476766109466552734375;s:8:"metadata";a:5:{s:6:"Artist";s:7:"Bawolff";s:16:"ImageDescription";a:2:{s:9:"x-default";s:18:"A file to test GIF";s:5:"_type";s:4:"lang";}s:15:"SublocationDest";s:13:"The interwebs";s:14:"GIFFileComment";a:1:{i:0;s:16:"GIƒ·test·file";}s:15:"_MW_GIF_VERSION";i:1;}}' ),
                );
        }
+
+       private function dataFile( $name, $type ) {
+               return new UnregisteredLocalFile( false, $this->repo,
+                       "mwstore://localtesting/data/$name", $type );
+       }
 }