Skip to content

Commit

Permalink
feat: add detected mime type to exception
Browse files Browse the repository at this point in the history
The mimetype may not match the file extension.
Helps the user to find out why a provided image is not accepted.

Signed-off-by: Daniel Kesselberg <mail@danielkesselberg.de>
  • Loading branch information
kesselb committed Jun 19, 2023
1 parent 7250b98 commit 93ea4b8
Show file tree
Hide file tree
Showing 2 changed files with 27 additions and 1 deletion.
2 changes: 1 addition & 1 deletion apps/theming/lib/ImageManager.php
Expand Up @@ -240,7 +240,7 @@ public function updateImage(string $key, string $tmpFile): string {
$supportedFormats = $this->getSupportedUploadImageFormats($key);
$detectedMimeType = mime_content_type($tmpFile);
if (!in_array($detectedMimeType, $supportedFormats, true)) {
throw new \Exception('Unsupported image type');
throw new \Exception('Unsupported image type: ' . $detectedMimeType);
}

if ($key === 'background' && $this->shouldOptimizeBackgroundImage($detectedMimeType, filesize($tmpFile))) {
Expand Down
26 changes: 26 additions & 0 deletions apps/theming/tests/ImageManagerTest.php
Expand Up @@ -390,4 +390,30 @@ public function testUpdateImage($key, $tmpFile, $folderExists, $shouldConvert) {

$this->imageManager->updateImage($key, $tmpFile);
}

public function testUnsupportedImageType(): void {
$this->expectException(\Exception::class);
$this->expectExceptionMessage('Unsupported image type: text/plain');

$file = $this->createMock(ISimpleFile::class);
$folder = $this->createMock(ISimpleFolder::class);
$oldFile = $this->createMock(ISimpleFile::class);

$folder->expects($this->any())
->method('getFile')
->willReturn($oldFile);

$this->rootFolder
->expects($this->any())
->method('getFolder')
->with('images')
->willReturn($folder);

$folder->expects($this->once())
->method('newFile')
->with('favicon')
->willReturn($file);

$this->imageManager->updateImage('favicon', __DIR__ . '/../../../tests/data/lorem.txt');
}
}

0 comments on commit 93ea4b8

Please sign in to comment.