Eu sei apenas de uma maneira como obter teclas numéricas de string: convertendo objeto em matriz
$object = new stdClass();
$object->{'100'} = 0;
$object->strKey1 = 0;
$object->strKey2 = 0;
$array1 = (array) $object;
var_dump($array1);
//array(3) {
// '100' => -- string
// int(0)
// 'strKey1' =>
// int(0)
// 'strKey2' =>
// int(0)
//}
Então, $ Array1 não é igual a este $ Array2
$array2 = array('100' => 0, 'strKey1' => 0, 'strKey2' => 0,);
var_dump($array2);
//array(3) {
// [100] => -- integer
// int(0)
// 'strKey1' =>
// int(0)
// 'strKey2' =>
// int(0)
//}
var_dump($array1 == $array2);
//bool(false)
Não é um bug: https://bugs.php.net/bug.php?id=61655
Além disso, a Phpunit tem suas próprias regras de comparação.
$this->assertEquals($array1, $array1); // Fail
$this->assertEquals($array1, $array1); // Pass
https://github.com/sebastianbergmann/phpunit/blob/3.7/phpunit/framework/comparator/array.php
Breve descrição da comparação de phpunit:
$expected = $array1;
$actual = $array1;
$remaining = $actual;
$equal = TRUE;
foreach ($expected as $key => $value){
unset($remaining[$key]);} // string numeric keys would not be unsetted.
if ($remaining)
$equal = FALSE;
var_dump($equal);
//bool(false)
Então ... você está fazendo certo. Para obter uma matriz "normal", você precisa recriar a matriz. Você pode usar foreach. Mas o Shoer Way está usando funções de serialização.
$this->assertEquals(unserialize(serialize($array1)), unserialize(serialize($array1)));
//Pass
Mas não parece muito melhor. :^)
Também você poderia usar assertSame
.