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
|
<?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 JSONMGET_Test extends PredisCommandTestCase
{
/**
* {@inheritDoc}
*/
protected function getExpectedCommand(): string
{
return JSONMGET::class;
}
/**
* {@inheritDoc}
*/
protected function getExpectedId(): string
{
return 'JSONMGET';
}
/**
* @group disconnected
*/
public function testFilterArguments(): void
{
$arguments = [['key1', 'key2', 'key3'], 'path'];
$expected = ['key1', 'key2', 'key3', 'path'];
$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 $firstJson
* @param array $secondJson
* @param array $keys
* @param string $path
* @param array $expectedResponse
* @return void
* @requiresRedisJsonVersion >= 1.0.0
*/
public function testMGetReturnsMultipleKeysArguments(
array $firstJson,
array $secondJson,
array $keys,
string $path,
array $expectedResponse
): void {
$redis = $this->getClient();
$redis->jsonset(...$firstJson);
$redis->jsonset(...$secondJson);
$this->assertSame($expectedResponse, $redis->jsonmget($keys, $path));
}
public function jsonProvider(): array
{
return [
'with both existing paths' => [
['key1', '$', '{"key1":"value1","key2":"value2"}'],
['key2', '$', '{"key1":"value3","key2":"value2"}'],
['key1', 'key2'],
'$.key1',
['["value1"]', '["value3"]'],
],
'with non-existing path' => [
['key1', '$', '{"key1":"value1","key2":"value2"}'],
['key2', '$', '{"key1":"value3","key3":"value3"}'],
['key1', 'key2'],
'$.key3',
['[]', '["value3"]'],
],
'with nested paths - different keys' => [
['key1', '$', '{"key1":"value1","key2":{"key3":"value3"}}'],
['key2', '$', '{"key1":"value3","key2":{"key3":"value4"}}'],
['key1', 'key2'],
'$..key3',
['["value3"]', '["value4"]'],
],
'with nested paths - similar keys' => [
['key1', '$', '{"key1":"value1","key2":{"key1":"value3"}}'],
['key2', '$', '{"key1":"value3","key2":{"key1":"value4"}}'],
['key1', 'key2'],
'$..key1',
['["value1","value3"]', '["value3","value4"]'],
],
];
}
}
|