1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71
|
--TEST--
Decimal::toFloat
--SKIPIF--
<?php
if (!extension_loaded("decimal")) echo "skip";
?>
--FILE--
<?php
use Decimal\Decimal;
/**
* Shortcut to construct a new decimal.
*/
function decimal(...$args) { return new Decimal(...$args); }
$tests = [
["0", 0.0],
["-0.1", -0.1],
[ "0.1", 0.1],
["-2.4", -2.4],
["-2.5", -2.5],
["-2.6", -2.6],
[ "2.4", 2.4],
[ "2.5", 2.5],
[ "2.6", 2.6],
[ "1E-50", 1E-50],
["-1E-50", -1E-50],
["-1E-1000", 0.0], // Warning
/* [ "NAN", NAN], Can"t test NAN because it does not equal itself */
[ "INF", INF],
["-INF", -INF],
];
foreach ($tests as $test) {
$number = $test[0];
$expect = $test[1];
try {
$result = decimal($number)->toFloat();
} catch (Throwable $e) {
printf("%s: %s\n", get_class($e), $e->getMessage());
continue;
}
if ($result !== $expect) {
print_r(compact("number", "result", "expect"));
}
}
/* Test that toint does not modify the original */
$number = decimal("2.5");
$result = $number->toFloat();
if ((string) $number !== "2.5") {
var_dump("Mutated!", compact("number"));
}
/* Test NAN */
var_dump(decimal("NAN")->toFloat());
?>
--EXPECT--
UnderflowException: Floating point underflow
float(NAN)
|