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
|
<?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\Json;
use Predis\Command\Command as RedisCommand;
use PredisTestCase;
use UnexpectedValueException;
class NewlineTest extends PredisTestCase
{
private $testClass;
protected function setUp(): void
{
$this->testClass = new class extends RedisCommand {
use Newline;
public static $newlineArgumentPositionOffset = 0;
public function getId()
{
return 'test';
}
};
}
/**
* @dataProvider argumentsProvider
* @param int $offset
* @param array $actualArguments
* @param array $expectedResponse
* @return void
*/
public function testReturnsCorrectArguments(
int $offset,
array $actualArguments,
array $expectedResponse
): void {
$this->testClass::$newlineArgumentPositionOffset = $offset;
$this->testClass->setArguments($actualArguments);
$this->assertSame($expectedResponse, $this->testClass->getArguments());
}
/**
* @return void
*/
public function testThrowsExceptionOnUnexpectedValueGiven(): void
{
$this->expectException(UnexpectedValueException::class);
$this->expectExceptionMessage('Newline argument value should be a string');
$this->testClass->setArguments([1]);
}
public static function argumentsProvider(): array
{
return [
'with wrong offset' => [
2,
['argument1'],
['argument1'],
],
'with default value' => [
0,
[''],
[false],
],
'with correct argument' => [
0,
['\n'],
['NEWLINE', '\n'],
],
];
}
}
|