1
0
mirror of https://github.com/php/php-src.git synced 2026-04-23 16:08:35 +02:00
Files
archived-php-src/ext/standard/tests/math/base_convert_variation1.phpt
T
Nikita Popov b10416a652 Deprecate passing null to non-nullable arg of internal function
This deprecates passing null to non-nullable scale arguments of
internal functions, with the eventual goal of making the behavior
consistent with userland functions, where null is never accepted
for non-nullable arguments.

This change is expected to cause quite a lot of fallout. In most
cases, calling code should be adjusted to avoid passing null. In
some cases, PHP should be adjusted to make some function arguments
nullable. I have already fixed a number of functions before landing
this, but feel free to file a bug if you encounter a function that
doesn't accept null, but probably should. (The rule of thumb for
this to be applicable is that the function must have special behavior
for 0 or "", which is distinct from the natural behavior of the
parameter.)

RFC: https://wiki.php.net/rfc/deprecate_null_to_scalar_internal_arg

Closes GH-6475.
2021-02-11 21:46:13 +01:00

147 lines
2.9 KiB
PHP

--TEST--
Test base_convert() function : usage variations - different data types as $number argument
--FILE--
<?php
echo "*** Testing base_convert() : usage variations ***\n";
// heredoc string
$heredoc = <<<EOT
abc
xyz
EOT;
// get a resource variable
$fp = fopen(__FILE__, "r");
$inputs = array(
// int data
/*1*/ 0,
1,
12,
-12,
2147483647,
// float data
/*6*/ 10.5,
-10.5,
1.234567e2,
1.234567E-2,
.5,
// boolean data
/*13*/ true,
false,
TRUE,
FALSE,
// empty data
/*17*/ "",
'',
array(),
// string data
/*20*/ "abcxyz",
'abcxyz',
$heredoc,
// resource variable
/*25*/ $fp
);
// loop through each element of $inputs to check the behaviour of base_convert()
$iterator = 1;
foreach($inputs as $input) {
echo "\n-- Iteration $iterator --\n";
try {
var_dump(base_convert($input, 10, 8));
} catch (TypeError $exception) {
echo $exception->getMessage() . "\n";
}
$iterator++;
}
fclose($fp);
?>
--EXPECTF--
*** Testing base_convert() : usage variations ***
-- Iteration 1 --
string(1) "0"
-- Iteration 2 --
string(1) "1"
-- Iteration 3 --
string(2) "14"
-- Iteration 4 --
Deprecated: Invalid characters passed for attempted conversion, these have been ignored in %s on line %d
string(2) "14"
-- Iteration 5 --
string(11) "17777777777"
-- Iteration 6 --
Deprecated: Invalid characters passed for attempted conversion, these have been ignored in %s on line %d
string(3) "151"
-- Iteration 7 --
Deprecated: Invalid characters passed for attempted conversion, these have been ignored in %s on line %d
string(3) "151"
-- Iteration 8 --
Deprecated: Invalid characters passed for attempted conversion, these have been ignored in %s on line %d
string(7) "4553207"
-- Iteration 9 --
Deprecated: Invalid characters passed for attempted conversion, these have been ignored in %s on line %d
string(7) "4553207"
-- Iteration 10 --
Deprecated: Invalid characters passed for attempted conversion, these have been ignored in %s on line %d
string(1) "5"
-- Iteration 11 --
string(1) "1"
-- Iteration 12 --
string(1) "0"
-- Iteration 13 --
string(1) "1"
-- Iteration 14 --
string(1) "0"
-- Iteration 15 --
string(1) "0"
-- Iteration 16 --
string(1) "0"
-- Iteration 17 --
base_convert(): Argument #1 ($num) must be of type string, array given
-- Iteration 18 --
Deprecated: Invalid characters passed for attempted conversion, these have been ignored in %s on line %d
string(1) "0"
-- Iteration 19 --
Deprecated: Invalid characters passed for attempted conversion, these have been ignored in %s on line %d
string(1) "0"
-- Iteration 20 --
Deprecated: Invalid characters passed for attempted conversion, these have been ignored in %s on line %d
string(1) "0"
-- Iteration 21 --
base_convert(): Argument #1 ($num) must be of type string, resource given