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 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125
|
<?php
/*
* This file is part of the Predis package.
*
* (c) 2009-2020 Daniele Alessandri
* (c) 2021-2025 Till Krüss
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace Predis\Command\Traits;
use Predis\Command\Command as RedisCommand;
use PredisTestCase;
use UnexpectedValueException;
class KeysTest extends PredisTestCase
{
private $testClass;
protected function setUp(): void
{
parent::setUp();
$this->testClass = new class extends RedisCommand {
use Keys;
public static $keysArgumentPositionOffset = 0;
public function getId()
{
return 'test';
}
};
}
/**
* @dataProvider argumentsProvider
* @param int $offset
* @param bool $withNumkeys
* @param array $actualArguments
* @param array $expectedArguments
* @return void
*/
public function testReturnsCorrectArguments(
int $offset,
bool $withNumkeys,
array $actualArguments,
array $expectedArguments
): void {
$this->testClass::$keysArgumentPositionOffset = $offset;
$this->testClass->setArguments($actualArguments, $withNumkeys);
$this->assertSame($expectedArguments, $this->testClass->getArguments());
}
/**
* @dataProvider unexpectedValuesProvider
* @param int $offset
* @param array $actualArguments
* @return void
*/
public function testThrowsExceptionOnUnexpectedValueGiven(int $offset, array $actualArguments): void
{
$this->testClass::$keysArgumentPositionOffset = $offset;
$this->expectException(UnexpectedValueException::class);
$this->expectExceptionMessage('Wrong keys argument type or position offset');
$this->testClass->setArguments($actualArguments);
}
public static function argumentsProvider(): array
{
return [
'keys argument first and there is arguments after' => [
0,
true,
[['key1', 'key2'], 'second argument', 'third argument'],
[2, 'key1', 'key2', 'second argument', 'third argument'],
],
'keys argument last and there is arguments before' => [
2,
true,
['first argument', 'second argument', ['key1', 'key2']],
['first argument', 'second argument', 2, 'key1', 'key2'],
],
'keys argument not the first and not the last' => [
1,
true,
['first argument', ['key1', 'key2'], 'third argument'],
['first argument', 2, 'key1', 'key2', 'third argument'],
],
'keys argument the only argument' => [
0,
true,
[['key1', 'key2']],
[2, 'key1', 'key2'],
],
'without numkeys modifier' => [
0,
false,
[['key1', 'key2']],
['key1', 'key2'],
],
];
}
public static function unexpectedValuesProvider(): array
{
return [
'keys argument not an array' => [
0,
['key1'],
],
'keys argument position offset higher then arguments quantity' => [
2,
[['key1', 'key2']],
],
];
}
}
|