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 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88
|
<?php
declare(strict_types=1);
namespace PhpMyAdmin\Tests\Config\Settings;
use PhpMyAdmin\Config\Settings\SqlQueryBox;
use PHPUnit\Framework\TestCase;
use function array_keys;
use function array_merge;
/**
* @covers \PhpMyAdmin\Config\Settings\SqlQueryBox
*/
class SqlQueryBoxTest extends TestCase
{
/** @var array<string, bool> */
private $defaultValues = ['Edit' => true, 'Explain' => true, 'ShowAsPHP' => true, 'Refresh' => true];
/**
* @param mixed[][] $values
* @psalm-param (array{0: string, 1: mixed, 2: mixed})[] $values
*
* @dataProvider providerForTestConstructor
*/
public function testConstructor(array $values): void
{
$actualValues = [];
$expectedValues = [];
/** @psalm-suppress MixedAssignment */
foreach ($values as $value) {
$actualValues[$value[0]] = $value[1];
$expectedValues[$value[0]] = $value[2];
}
$expected = array_merge($this->defaultValues, $expectedValues);
$settings = new SqlQueryBox($actualValues);
foreach (array_keys($expectedValues) as $key) {
$this->assertSame($expected[$key], $settings->$key);
}
}
/**
* [setting key, actual value, expected value]
*
* @return mixed[][][][]
* @psalm-return (array{0: string, 1: mixed, 2: mixed})[][][]
*/
public function providerForTestConstructor(): array
{
return [
'null values' => [
[
['Edit', null, true],
['Explain', null, true],
['ShowAsPHP', null, true],
['Refresh', null, true],
],
],
'valid values' => [
[
['Edit', true, true],
['Explain', true, true],
['ShowAsPHP', true, true],
['Refresh', true, true],
],
],
'valid values 2' => [
[
['Edit', false, false],
['Explain', false, false],
['ShowAsPHP', false, false],
['Refresh', false, false],
],
],
'valid values with type coercion' => [
[
['Edit', 0, false],
['Explain', 0, false],
['ShowAsPHP', 0, false],
['Refresh', 0, false],
],
],
];
}
}
|