php-src/ext/standard/tests/array/bug68553.phpt
Nikita Popov 091d53c131 Use standard key behavior in array_column()
array_column() reimplements array key handling in a way that does
not match standard array key behavior in PHP. Avoid this by making
use of the standard API.

Of course, there is a minor backwards compatibilty break here,
e.g. people could be relying on objects getting cast to string
instead of throwing.

Closes GH-5487.
2020-05-11 14:16:24 +02:00

82 lines
1.3 KiB
PHP

--TEST--
Bug #68553 (array_column: null values in $index_key become incrementing keys in result)
--FILE--
<?php
$i = 100;
/* increase the resource id to make test stable */
while ($i--) {
$fd = fopen(__FILE__, "r");
fclose($fd);
}
$a = [
['a' => 10],
['a' => 20],
['a' => true],
['a' => false],
['a' => fopen(__FILE__, "r")],
['a' => -5],
['a' => 7.38],
['a' => null, "test"],
['a' => null],
];
var_dump(array_column($a, null, 'a'));
try {
var_dump(array_column([['a' => new stdClass]], null, 'a'));
} catch (Error $e) {
echo $e->getMessage(), "\n";
}
try {
var_dump(array_column([['a' => []]], null, 'a'));
} catch (Error $e) {
echo $e->getMessage(), "\n";
}
?>
--EXPECTF--
Warning: Resource ID#%d used as offset, casting to integer (%d) in %s on line %d
array(8) {
[10]=>
array(1) {
["a"]=>
int(10)
}
[20]=>
array(1) {
["a"]=>
int(20)
}
[1]=>
array(1) {
["a"]=>
bool(true)
}
[0]=>
array(1) {
["a"]=>
bool(false)
}
[%d]=>
array(1) {
["a"]=>
resource(%d) of type (stream)
}
[-5]=>
array(1) {
["a"]=>
int(-5)
}
[7]=>
array(1) {
["a"]=>
float(7.38)
}
[""]=>
array(1) {
["a"]=>
NULL
}
}
Illegal offset type
Illegal offset type