From adc268778aab47e1465fd7ebf90ecfdd9ca6080c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Martin=20Auswo=CC=88ger?= Date: Tue, 13 Aug 2019 19:24:27 +0200 Subject: [PATCH] Fix getMaxFilesize() returning zero --- File/UploadedFile.php | 2 +- Tests/File/UploadedFileTest.php | 14 ++++++++++++++ 2 files changed, 15 insertions(+), 1 deletion(-) diff --git a/File/UploadedFile.php b/File/UploadedFile.php index 093aaf832..86153ed49 100644 --- a/File/UploadedFile.php +++ b/File/UploadedFile.php @@ -217,7 +217,7 @@ public static function getMaxFilesize() $sizePostMax = self::parseFilesize(ini_get('post_max_size')); $sizeUploadMax = self::parseFilesize(ini_get('upload_max_filesize')); - return min([$sizePostMax, $sizeUploadMax]); + return min($sizePostMax ?: PHP_INT_MAX, $sizeUploadMax ?: PHP_INT_MAX); } /** diff --git a/Tests/File/UploadedFileTest.php b/Tests/File/UploadedFileTest.php index 629211052..4186c72a6 100644 --- a/Tests/File/UploadedFileTest.php +++ b/Tests/File/UploadedFileTest.php @@ -281,4 +281,18 @@ public function testIsInvalidIfNotHttpUpload() $this->assertFalse($file->isValid()); } + + public function testGetMaxFilesize() + { + $size = UploadedFile::getMaxFilesize(); + + $this->assertIsInt($size); + $this->assertGreaterThan(0, $size); + + if (0 === (int) ini_get('post_max_size') && 0 === (int) ini_get('upload_max_filesize')) { + $this->assertSame(PHP_INT_MAX, $size); + } else { + $this->assertLessThan(PHP_INT_MAX, $size); + } + } }