php-src/ext/standard/tests/array/array_diff_assoc_variation3.phpt
Peter Kokot d679f02295 Sync leading and final newlines in *.phpt sections
This patch adds missing newlines, trims multiple redundant final
newlines into a single one, and trims redundant leading newlines in all
*.phpt sections.

According to POSIX, a line is a sequence of zero or more non-' <newline>'
characters plus a terminating '<newline>' character. [1] Files should
normally have at least one final newline character.

C89 [2] and later standards [3] mention a final newline:
"A source file that is not empty shall end in a new-line character,
which shall not be immediately preceded by a backslash character."

Although it is not mandatory for all files to have a final newline
fixed, a more consistent and homogeneous approach brings less of commit
differences issues and a better development experience in certain text
editors and IDEs.

[1] http://pubs.opengroup.org/onlinepubs/9699919799/basedefs/V1_chap03.html#tag_03_206
[2] https://port70.net/~nsz/c/c89/c89-draft.html#2.1.1.2
[3] https://port70.net/~nsz/c/c99/n1256.html#5.1.1.2
2018-10-15 04:33:09 +02:00

205 lines
2.9 KiB
PHP

--TEST--
Test array_diff_assoc() function : variation - array containing different data types
--FILE--
<?php
/* Prototype : array array_diff_assoc(array $arr1, array $arr2 [, array ...])
* Description: Returns the entries of arr1 that have values which are not present
* in any of the others arguments but do additional checks whether the keys are equal
* Source code: ext/standard/array.c
*/
/*
* Test how array_diff_assoc() compares indexed arrays containing different data types
*/
echo "\n*** Testing array_diff_assoc() : usage variations ***\n";
$array = array(1, 2, 3);
//get an unset variable
$unset_var = 10;
unset ($unset_var);
// get a class
class classA
{
public function __toString() {
return "Class A object";
}
}
// heredoc string
$heredoc = <<<EOT
hello world
EOT;
//array of different data types to be passed to $arr1 argument
$inputs = array(
// int data
/*1*/
'int' => array(
0,
1,
12345,
-2345),
// float data
/*2*/
'float' => array(
10.5,
-10.5,
12.3456789000e10,
12.3456789000E-10,
.5),
// null data
/*3*/
'null' => array(
NULL,
null),
// boolean data
/*4*/
'bool' => array(
true,
false,
TRUE,
FALSE),
// empty data
/*5*/
'empty' => array(
"",
''),
// string data
/*6*/
'string' => array(
"string",
'string',
$heredoc),
// binary data
/*7*/
'binary' => array(
b"binary",
(binary)"binary"),
// object data
/*8*/
'object' => array(
new classA()),
// undefined data
/*9*/
'undefined' => array(
@$undefined_var),
// unset data
/*10*/
'unset' => array(
@$unset_var),
);
// loop through each element of $inputs to check the behavior of array_diff_assoc
$iterator = 1;
foreach($inputs as $key => $input) {
echo "\n-- Iteration $iterator --\n";
var_dump( array_diff_assoc($input, $array));
$iterator++;
};
echo "Done";
?>
--EXPECTF--
*** Testing array_diff_assoc() : usage variations ***
-- Iteration 1 --
array(4) {
[0]=>
int(0)
[1]=>
int(1)
[2]=>
int(12345)
[3]=>
int(-2345)
}
-- Iteration 2 --
array(5) {
[0]=>
float(10.5)
[1]=>
float(-10.5)
[2]=>
float(123456789000)
[3]=>
float(1.23456789E-9)
[4]=>
float(0.5)
}
-- Iteration 3 --
array(2) {
[0]=>
NULL
[1]=>
NULL
}
-- Iteration 4 --
array(3) {
[1]=>
bool(false)
[2]=>
bool(true)
[3]=>
bool(false)
}
-- Iteration 5 --
array(2) {
[0]=>
string(0) ""
[1]=>
string(0) ""
}
-- Iteration 6 --
array(3) {
[0]=>
string(6) "string"
[1]=>
string(6) "string"
[2]=>
string(11) "hello world"
}
-- Iteration 7 --
array(2) {
[0]=>
string(6) "binary"
[1]=>
string(6) "binary"
}
-- Iteration 8 --
array(1) {
[0]=>
object(classA)#%d (0) {
}
}
-- Iteration 9 --
array(1) {
[0]=>
NULL
}
-- Iteration 10 --
array(1) {
[0]=>
NULL
}
Done