markTestSkipped( "This test needs the exif extension." ); } $filePath = __DIR__ . '/../../data/media'; $this->backend = new FSFileBackend( array( 'name' => 'localtesting', 'wikiId' => wfWikiId(), 'containerPaths' => array( 'data' => $filePath ) ) ); $this->repo = new FSRepo( array( 'name' => 'temp', 'url' => 'http://localhost/thumbtest', 'backend' => $this->backend ) ); $this->setMwGlobals( 'wgShowEXIF', true ); } /** * @covers File::formatMetadata */ public function testInvalidDate() { $file = $this->dataFile( 'broken_exif_date.jpg', 'image/jpeg' ); // Throws an error if bug hit $meta = $file->formatMetadata(); $this->assertNotEquals( false, $meta, 'Valid metadata extracted' ); // Find date exif entry $this->assertArrayHasKey( 'visible', $meta ); $dateIndex = null; foreach ( $meta['visible'] as $i => $data ) { if ( $data['id'] == 'exif-datetimeoriginal' ) { $dateIndex = $i; } } $this->assertNotNull( $dateIndex, 'Date entry exists in metadata' ); $this->assertEquals( '0000:01:00 00:02:27', $meta['visible'][$dateIndex]['value'], 'File with invalid date metadata (bug 29471)' ); } /** * @param $filename String * @param $expected Integer Total image area * @dataProvider provideFlattenArray * @covers FormatMetadata::flattenArray */ public function testFlattenArray( $vals, $type, $noHtml, $ctx, $expected ) { $actual = FormatMetadata::flattenArray( $vals, $type, $noHtml, $ctx ); $this->assertEquals( $expected, $actual ); } public static function provideFlattenArray() { return array( array( array( 1, 2, 3 ), 'ul', false, false, "", ), array( array( 1, 2, 3 ), 'ol', false, false, "
  1. 1
  2. \n
  3. 2
  4. \n
  5. 3
", ), array( array( 1, 2, 3 ), 'ul', true, false, "\n*1\n*2\n*3", ), array( array( 1, 2, 3 ), 'ol', true, false, "\n#1\n#2\n#3", ), // TODO: more test cases ); } private function dataFile( $name, $type ) { return new UnregisteredLocalFile( false, $this->repo, "mwstore://localtesting/data/$name", $type ); } }