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
/*
* 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 DbTest extends PredisTestCase
{
private $testClass;
protected function setUp(): void
{
parent::setUp();
$this->testClass = new class extends RedisCommand {
use DB;
public static $dbArgumentPositionOffset = 0;
public function getId()
{
return 'test';
}
};
}
/**
* @dataProvider argumentsProvider
* @param int $offset
* @param array $arguments
* @param array $expectedResponse
* @return void
*/
public function testReturnsCorrectArguments(int $offset, array $arguments, array $expectedResponse): void
{
$this->testClass::$dbArgumentPositionOffset = $offset;
$this->testClass->setArguments($arguments);
$this->assertSame($expectedResponse, $this->testClass->getArguments());
}
/**
* @return void
*/
public function testThrowsErrorOnUnexpectedValueGiven(): void
{
$this->testClass::$dbArgumentPositionOffset = 0;
$this->expectException(UnexpectedValueException::class);
$this->expectExceptionMessage('DB argument should be a valid numeric value');
$this->testClass->setArguments(['wrong']);
}
public static function argumentsProvider(): array
{
return [
'with positive integer db argument' => [
0,
[1],
['DB', 1],
],
'with wrong offset' => [
1,
[1],
[1],
],
'with negative integer db argument' => [
1,
['argument1', -1],
['argument1'],
],
];
}
}
|