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
|
<?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\Redis\Json;
use Predis\Command\Redis\PredisCommandTestCase;
/**
* @group commands
* @group realm-stack
*/
class JSONARRLEN_Test extends PredisCommandTestCase
{
/**
* {@inheritDoc}
*/
protected function getExpectedCommand(): string
{
return JSONARRLEN::class;
}
/**
* {@inheritDoc}
*/
protected function getExpectedId(): string
{
return 'JSONARRLEN';
}
/**
* @group disconnected
*/
public function testFilterArguments(): void
{
$arguments = ['key', '$..'];
$expected = ['key', '$..'];
$command = $this->getCommand();
$command->setArguments($arguments);
$this->assertSame($expected, $command->getArguments());
}
/**
* @group disconnected
*/
public function testParseResponse(): void
{
$this->assertSame(1, $this->getCommand()->parseResponse(1));
}
/**
* @group connected
* @group relay-resp3
* @dataProvider jsonProvider
* @param array $jsonArguments
* @param string $key
* @param string $path
* @param array $expectedLength
* @return void
* @requiresRedisJsonVersion >= 1.0.0
*/
public function testReturnsCorrectJsonArrayLength(
array $jsonArguments,
string $key,
string $path,
array $expectedLength
): void {
$redis = $this->getClient();
$redis->jsonset(...$jsonArguments);
$this->assertSame($expectedLength, $redis->jsonarrlen($key, $path));
}
public function jsonProvider(): array
{
return [
'on root level' => [
['key', '$', '{"key1":"value1","key2":["value1","value2"]}'],
'key',
'$.key2',
[2],
],
'on nested level' => [
['key', '$', '{"key1":{"key2":["value1","value2"]}}'],
'key',
'$..key2',
[2],
],
'with same keys on both levels' => [
['key', '$', '{"key1":{"key2":["value1","value2"]},"key2":["value1","value2","value3"]}'],
'key',
'$..key2',
[3, 2],
],
'with non-array path' => [
['key', '$', '{"key1":"value1","key2":"value2"}'],
'key',
'$.key2',
[null],
],
];
}
}
|