StringGetMultipleTest.php 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127
  1. <?php
  2. /*
  3. * This file is part of the Predis package.
  4. *
  5. * (c) Daniele Alessandri <suppakilla@gmail.com>
  6. *
  7. * For the full copyright and license information, please view the LICENSE
  8. * file that was distributed with this source code.
  9. */
  10. namespace Predis\Commands;
  11. use \PHPUnit_Framework_TestCase as StandardTestCase;
  12. /**
  13. * @group commands
  14. * @group realm-string
  15. */
  16. class StringGetMultipleTest extends CommandTestCase
  17. {
  18. /**
  19. * {@inheritdoc}
  20. */
  21. protected function getExpectedCommand()
  22. {
  23. return 'Predis\Commands\StringGetMultiple';
  24. }
  25. /**
  26. * {@inheritdoc}
  27. */
  28. protected function getExpectedId()
  29. {
  30. return 'MGET';
  31. }
  32. /**
  33. * @group disconnected
  34. */
  35. public function testFilterArguments()
  36. {
  37. $arguments = array('key1', 'key2', 'key3');
  38. $expected = array('key1', 'key2', 'key3');
  39. $command = $this->getCommand();
  40. $command->setArguments($arguments);
  41. $this->assertSame($expected, $command->getArguments());
  42. }
  43. /**
  44. * @group disconnected
  45. */
  46. public function testFilterArgumentsAsSingleArray()
  47. {
  48. $arguments = array(array('key1', 'key2', 'key3'));
  49. $expected = array('key1', 'key2', 'key3');
  50. $command = $this->getCommand();
  51. $command->setArguments($arguments);
  52. $this->assertSame($expected, $command->getArguments());
  53. }
  54. /**
  55. * @group disconnected
  56. */
  57. public function testParseResponse()
  58. {
  59. $raw = array('value1', 'value2', 'value3');
  60. $expected = array('value1', 'value2', 'value3');
  61. $command = $this->getCommand();
  62. $this->assertSame($expected, $command->parseResponse($raw));
  63. }
  64. /**
  65. * @group disconnected
  66. */
  67. public function testPrefixKeys()
  68. {
  69. $arguments = array('key1', 'key2', 'key3');
  70. $expected = array('prefix:key1', 'prefix:key2', 'prefix:key3');
  71. $command = $this->getCommandWithArgumentsArray($arguments);
  72. $command->prefixKeys('prefix:');
  73. $this->assertSame($expected, $command->getArguments());
  74. }
  75. /**
  76. * @group connected
  77. */
  78. public function testReturnsArrayOfValues()
  79. {
  80. $redis = $this->getClient();
  81. $redis->set('foo', 'bar');
  82. $redis->set('hoge', 'piyo');
  83. $this->assertSame(array('bar', 'piyo'), $redis->mget('foo', 'hoge'));
  84. }
  85. /**
  86. * @group connected
  87. */
  88. public function testReturnsArrayWithNullValuesOnNonExistingKeys()
  89. {
  90. $redis = $this->getClient();
  91. $this->assertSame(array(null, null), $redis->mget('foo', 'hoge'));
  92. }
  93. /**
  94. * @group connected
  95. */
  96. public function testDoesNotThrowExceptionOnWrongType()
  97. {
  98. $redis = $this->getClient();
  99. $redis->lpush('metavars', 'foo');
  100. $this->assertSame(array(null), $redis->mget('metavars'));
  101. }
  102. }