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 126 127 128 129 130
|
<?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;
class CLUSTER_Test extends PredisCommandTestCase
{
/**
* {@inheritDoc}
*/
protected function getExpectedCommand(): string
{
return CLUSTER::class;
}
/**
* {@inheritDoc}
*/
protected function getExpectedId(): string
{
return 'CLUSTER';
}
/**
* @group disconnected
*/
public function testFilterArgumentsOfAddSlotsRange(): void
{
$arguments = ['ADDSLOTSRANGE', 1, 1000];
$expected = ['ADDSLOTSRANGE', 1, 1000];
$command = $this->getCommand();
$command->setArguments($arguments);
$this->assertSame($expected, $command->getArguments());
}
/**
* @group disconnected
*/
public function testFilterArgumentsOfDelSlotsRange(): void
{
$arguments = ['DELSLOTSRANGE', 1, 1000];
$expected = ['DELSLOTSRANGE', 1, 1000];
$command = $this->getCommand();
$command->setArguments($arguments);
$this->assertSame($expected, $command->getArguments());
}
/**
* @group disconnected
*/
public function testFilterArgumentsOfLinks(): void
{
$arguments = ['LINKS'];
$expected = ['LINKS'];
$command = $this->getCommand();
$command->setArguments($arguments);
$this->assertSame($expected, $command->getArguments());
}
/**
* @group disconnected
*/
public function testFilterArgumentsOfShards(): void
{
$arguments = ['SHARDS'];
$expected = ['SHARDS'];
$command = $this->getCommand();
$command->setArguments($arguments);
$this->assertSame($expected, $command->getArguments());
}
/**
* @group connected
* @group cluster
* @return void
* @requiresRedisVersion >= 7.0.0
*/
public function testAddSlotsRangeToGivenNode(): void
{
$redis = $this->getClient();
// Sometimes the cluster can be in a state where slots are
// missing on some shards (e.g. they are being rebalanced)
$shards = $redis->cluster->shards();
$slots = $shards[0][1] ?? $shards[0]['slots'];
if (empty($slots)) {
$slots = $shards[1][1] ?? $shards[1]['slots'];
}
if (empty($slots)) {
$slots = $shards[2][1] ?? $shards[2]['slots'];
}
[$startSlot, $endSlot] = $slots;
$this->assertEquals('OK', $redis->cluster->delSlotsRange($startSlot, $endSlot));
$this->assertEquals('OK', $redis->cluster->addSlotsRange($startSlot, $endSlot));
}
/**
* @group connected
* @group cluster
* @return void
* @requiresRedisVersion >= 7.0.0
*/
public function testLinksReturnsClusterPeerLinks(): void
{
$redis = $this->getClient();
$this->assertNotEmpty($redis->cluster->links());
}
}
|