|
@@ -39,6 +39,25 @@ class ScriptedCommandTest extends StandardTestCase
|
|
|
$this->assertSame(array_merge(array(self::LUA_SCRIPT, 2), $arguments), $command->getArguments());
|
|
|
}
|
|
|
|
|
|
+ /**
|
|
|
+ * @group disconnected
|
|
|
+ */
|
|
|
+ public function testGetArgumentsWithNegativeKeysCount()
|
|
|
+ {
|
|
|
+ $arguments = array('key1', 'key2', 'value1', 'value2');
|
|
|
+
|
|
|
+ $command = $this->getMock('Predis\Commands\ScriptedCommand', array('getScript', 'getKeysCount'));
|
|
|
+ $command->expects($this->once())
|
|
|
+ ->method('getScript')
|
|
|
+ ->will($this->returnValue(self::LUA_SCRIPT));
|
|
|
+ $command->expects($this->once())
|
|
|
+ ->method('getKeysCount')
|
|
|
+ ->will($this->returnValue(-2));
|
|
|
+ $command->setArguments($arguments);
|
|
|
+
|
|
|
+ $this->assertSame(array_merge(array(self::LUA_SCRIPT, 2), $arguments), $command->getArguments());
|
|
|
+ }
|
|
|
+
|
|
|
/**
|
|
|
* @group disconnected
|
|
|
*/
|
|
@@ -58,6 +77,25 @@ class ScriptedCommandTest extends StandardTestCase
|
|
|
$this->assertSame(array('key1', 'key2'), $command->getKeys());
|
|
|
}
|
|
|
|
|
|
+ /**
|
|
|
+ * @group disconnected
|
|
|
+ */
|
|
|
+ public function testGetKeysWithNegativeKeysCount()
|
|
|
+ {
|
|
|
+ $arguments = array('key1', 'key2', 'value1', 'value2');
|
|
|
+
|
|
|
+ $command = $this->getMock('Predis\Commands\ScriptedCommand', array('getScript', 'getKeysCount'));
|
|
|
+ $command->expects($this->once())
|
|
|
+ ->method('getScript')
|
|
|
+ ->will($this->returnValue(self::LUA_SCRIPT));
|
|
|
+ $command->expects($this->exactly(2))
|
|
|
+ ->method('getKeysCount')
|
|
|
+ ->will($this->returnValue(-2));
|
|
|
+ $command->setArguments($arguments);
|
|
|
+
|
|
|
+ $this->assertSame(array('key1', 'key2'), $command->getKeys());
|
|
|
+ }
|
|
|
+
|
|
|
/**
|
|
|
* @group disconnected
|
|
|
*/
|
|
@@ -80,6 +118,28 @@ class ScriptedCommandTest extends StandardTestCase
|
|
|
$this->assertSame($expected, $command->getKeys());
|
|
|
}
|
|
|
|
|
|
+ /**
|
|
|
+ * @group disconnected
|
|
|
+ */
|
|
|
+ public function testPrefixKeysWithNegativeKeysCount()
|
|
|
+ {
|
|
|
+ $arguments = array('foo', 'hoge', 'bar', 'piyo');
|
|
|
+ $expected = array('prefix:foo', 'prefix:hoge');
|
|
|
+
|
|
|
+ $command = $this->getMock('Predis\Commands\ScriptedCommand', array('getScript', 'getKeysCount'));
|
|
|
+ $command->expects($this->once())
|
|
|
+ ->method('getScript')
|
|
|
+ ->will($this->returnValue(self::LUA_SCRIPT));
|
|
|
+ $command->expects($this->exactly(2))
|
|
|
+ ->method('getKeysCount')
|
|
|
+ ->will($this->returnValue(-2));
|
|
|
+ $command->setArguments($arguments);
|
|
|
+
|
|
|
+ $command->prefixKeys('prefix:');
|
|
|
+
|
|
|
+ $this->assertSame($expected, $command->getKeys());
|
|
|
+ }
|
|
|
+
|
|
|
/**
|
|
|
* @group disconnected
|
|
|
*/
|