aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--phpBB/includes/php/ini.php17
-rw-r--r--tests/wrapper/phpbb_php_ini_test.php31
2 files changed, 39 insertions, 9 deletions
diff --git a/phpBB/includes/php/ini.php b/phpBB/includes/php/ini.php
index de1cb5096c..bbe592a7df 100644
--- a/phpBB/includes/php/ini.php
+++ b/phpBB/includes/php/ini.php
@@ -138,7 +138,7 @@ class phpbb_php_ini
if (is_numeric($value))
{
// Already in bytes.
- return $value;
+ return $this->to_numeric($value);
}
else if (strlen($value) < 2)
{
@@ -151,7 +151,7 @@ class phpbb_php_ini
return false;
}
- $value_numeric = (int) $value;
+ $value_numeric = $this->to_numeric($value);
switch ($value[strlen($value) - 1])
{
@@ -171,4 +171,17 @@ class phpbb_php_ini
return $value_numeric;
}
+
+ /**
+ * Casts a numeric string $input to an appropriate numeric type (i.e. integer or float)
+ *
+ * @param string $input A numeric string.
+ *
+ * @return int|float Integer $input if $input fits integer,
+ * float $input otherwise.
+ */
+ protected function to_numeric($input)
+ {
+ return ($input > PHP_INT_MAX) ? (float) $input : (int) $input;
+ }
}
diff --git a/tests/wrapper/phpbb_php_ini_test.php b/tests/wrapper/phpbb_php_ini_test.php
index 5c312300d3..4d8e583eb8 100644
--- a/tests/wrapper/phpbb_php_ini_test.php
+++ b/tests/wrapper/phpbb_php_ini_test.php
@@ -49,18 +49,35 @@ class phpbb_wrapper_phpbb_php_ini_test extends phpbb_test_case
$this->assertSame(false, $this->php_ini->get_float('phpBB'));
}
- public function test_get_bytes()
+ public function test_get_bytes_invalid()
{
$this->assertSame(false, $this->php_ini->get_bytes('phpBB'));
$this->assertSame(false, $this->php_ini->get_bytes('k'));
$this->assertSame(false, $this->php_ini->get_bytes('-k'));
$this->assertSame(false, $this->php_ini->get_bytes('M'));
$this->assertSame(false, $this->php_ini->get_bytes('-M'));
- $this->assertEquals(32 * pow(2, 20), $this->php_ini->get_bytes('32m'));
- $this->assertEquals(- 32 * pow(2, 20), $this->php_ini->get_bytes('-32m'));
- $this->assertEquals(8 * pow(2, 30), $this->php_ini->get_bytes('8G'));
- $this->assertEquals(- 8 * pow(2, 30), $this->php_ini->get_bytes('-8G'));
- $this->assertEquals(1234, $this->php_ini->get_bytes('1234'));
- $this->assertEquals(-12345, $this->php_ini->get_bytes('-12345'));
+ }
+
+ /**
+ * @dataProvider get_bytes_data
+ */
+ public function test_get_bytes($expected, $value)
+ {
+ $actual = $this->php_ini->get_bytes($value);
+
+ $this->assertTrue(is_float($actual) || is_int($actual));
+ $this->assertEquals($expected, $actual);
+ }
+
+ static public function get_bytes_data()
+ {
+ return array(
+ array(32 * pow(2, 20), '32m'),
+ array(- 32 * pow(2, 20), '-32m'),
+ array(8 * pow(2, 30), '8G'),
+ array(- 8 * pow(2, 30), '-8G'),
+ array(1234, '1234'),
+ array(-12345, '-12345'),
+ );
}
}