Merge "Added release notes for 'ContentHandler::runLegacyHooks' removal"
[mediawiki.git] / tests / phpunit / includes / media / BitmapScalingTest.php
blob92a927f8ec3782163eb1be3add478376e2657aa3
1 <?php
3 /**
4 * @group Media
5 */
6 class BitmapScalingTest extends MediaWikiTestCase {
8 protected function setUp() {
9 parent::setUp();
11 $this->setMwGlobals( [
12 'wgMaxImageArea' => 1.25e7, // 3500x3500
13 'wgCustomConvertCommand' => 'dummy', // Set so that we don't get client side rendering
14 ] );
17 /**
18 * @dataProvider provideNormaliseParams
19 * @covers BitmapHandler::normaliseParams
21 public function testNormaliseParams( $fileDimensions, $expectedParams, $params, $msg ) {
22 $file = new FakeDimensionFile( $fileDimensions );
23 $handler = new BitmapHandler;
24 $valid = $handler->normaliseParams( $file, $params );
25 $this->assertTrue( $valid );
26 $this->assertEquals( $expectedParams, $params, $msg );
29 public static function provideNormaliseParams() {
30 return [
31 /* Regular resize operations */
33 [ 1024, 768 ],
35 'width' => 512, 'height' => 384,
36 'physicalWidth' => 512, 'physicalHeight' => 384,
37 'page' => 1, 'interlace' => false,
39 [ 'width' => 512 ],
40 'Resizing with width set',
43 [ 1024, 768 ],
45 'width' => 512, 'height' => 384,
46 'physicalWidth' => 512, 'physicalHeight' => 384,
47 'page' => 1, 'interlace' => false,
49 [ 'width' => 512, 'height' => 768 ],
50 'Resizing with height set too high',
53 [ 1024, 768 ],
55 'width' => 512, 'height' => 384,
56 'physicalWidth' => 512, 'physicalHeight' => 384,
57 'page' => 1, 'interlace' => false,
59 [ 'width' => 1024, 'height' => 384 ],
60 'Resizing with height set',
63 /* Very tall images */
65 [ 1000, 100 ],
67 'width' => 5, 'height' => 1,
68 'physicalWidth' => 5, 'physicalHeight' => 1,
69 'page' => 1, 'interlace' => false,
71 [ 'width' => 5 ],
72 'Very wide image',
76 [ 100, 1000 ],
78 'width' => 1, 'height' => 10,
79 'physicalWidth' => 1, 'physicalHeight' => 10,
80 'page' => 1, 'interlace' => false,
82 [ 'width' => 1 ],
83 'Very high image',
86 [ 100, 1000 ],
88 'width' => 1, 'height' => 5,
89 'physicalWidth' => 1, 'physicalHeight' => 10,
90 'page' => 1, 'interlace' => false,
92 [ 'width' => 10, 'height' => 5 ],
93 'Very high image with height set',
95 /* Max image area */
97 [ 4000, 4000 ],
99 'width' => 5000, 'height' => 5000,
100 'physicalWidth' => 4000, 'physicalHeight' => 4000,
101 'page' => 1, 'interlace' => false,
103 [ 'width' => 5000 ],
104 'Bigger than max image size but doesn\'t need scaling',
106 /* Max interlace image area */
108 [ 4000, 4000 ],
110 'width' => 5000, 'height' => 5000,
111 'physicalWidth' => 4000, 'physicalHeight' => 4000,
112 'page' => 1, 'interlace' => false,
114 [ 'width' => 5000, 'interlace' => true ],
115 'Interlace bigger than max interlace area',
121 * @covers BitmapHandler::doTransform
123 public function testTooBigImage() {
124 $file = new FakeDimensionFile( [ 4000, 4000 ] );
125 $handler = new BitmapHandler;
126 $params = [ 'width' => '3700' ]; // Still bigger than max size.
127 $this->assertEquals( 'TransformTooBigImageAreaError',
128 get_class( $handler->doTransform( $file, 'dummy path', '', $params ) ) );
132 * @covers BitmapHandler::doTransform
134 public function testTooBigMustRenderImage() {
135 $file = new FakeDimensionFile( [ 4000, 4000 ] );
136 $file->mustRender = true;
137 $handler = new BitmapHandler;
138 $params = [ 'width' => '5000' ]; // Still bigger than max size.
139 $this->assertEquals( 'TransformTooBigImageAreaError',
140 get_class( $handler->doTransform( $file, 'dummy path', '', $params ) ) );
144 * @covers BitmapHandler::getImageArea
146 public function testImageArea() {
147 $file = new FakeDimensionFile( [ 7, 9 ] );
148 $handler = new BitmapHandler;
149 $this->assertEquals( 63, $handler->getImageArea( $file ) );