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
|
<?php
/*
* This file is part of the Predis package.
*
* (c) Daniele Alessandri <suppakilla@gmail.com>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace Predis\Command;
/**
* In order to support the output of SLOWLOG, the backend connection must be
* able to parse nested multibulk responses deeper than 2 levels.
*
* @group commands
* @group realm-server
*/
class ServerSlowlogTest extends PredisCommandTestCase
{
/**
* {@inheritdoc}
*/
protected function getExpectedCommand()
{
return 'Predis\Command\ServerSlowlog';
}
/**
* {@inheritdoc}
*/
protected function getExpectedId()
{
return 'SLOWLOG';
}
/**
* @group disconnected
*/
public function testFilterArguments()
{
$arguments = array('GET', '2');
$expected = array('GET', '2');
$command = $this->getCommand();
$command->setArguments($arguments);
$this->assertSame($expected, $command->getArguments());
}
/**
* @group disconnected
*/
public function testParseResponse()
{
$raw = array(array(0, 1323163469, 12451, array('SORT', 'list:unordered')));
$expected = array(
array(
'id' => 0,
'timestamp' => 1323163469,
'duration' => 12451,
'command' => array('SORT', 'list:unordered'),
),
);
$command = $this->getCommand();
$this->assertSame($expected, $command->parseResponse($raw));
}
/**
* @group connected
*/
public function testReturnsAnArrayOfLoggedCommands()
{
$redis = $this->getClient();
$config = $redis->config('get', 'slowlog-log-slower-than');
$threshold = array_pop($config);
$redis->config('set', 'slowlog-log-slower-than', 0);
$redis->set('foo', 'bar');
$this->assertIsArray($slowlog = $redis->slowlog('GET'));
$this->assertGreaterThan(0, count($slowlog));
$this->assertIsArray($slowlog[0]);
$this->assertGreaterThan(0, $slowlog[0]['id']);
$this->assertGreaterThan(0, $slowlog[0]['timestamp']);
$this->assertGreaterThan(0, $slowlog[0]['duration']);
$this->assertIsArray($slowlog[0]['command']);
$redis->config('set', 'slowlog-log-slower-than', $threshold);
}
/**
* @group connected
*/
public function testCanResetTheLog()
{
$redis = $this->getClient();
$this->assertEquals('OK', $redis->slowlog('RESET'));
}
/**
* @group connected
*/
public function testThrowsExceptionOnInvalidSubcommand()
{
$this->expectException('\Predis\Response\ServerException');
$redis = $this->getClient();
$redis->slowlog('INVALID');
}
}
|