HashScanTest.php 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138
  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\Command;
  11. use PHPUnit_Framework_TestCase as StandardTestCase;
  12. /**
  13. * @group commands
  14. * @group realm-hash
  15. */
  16. class HashScanTest extends CommandTestCase
  17. {
  18. /**
  19. * {@inheritdoc}
  20. */
  21. protected function getExpectedCommand()
  22. {
  23. return 'Predis\Command\HashScan';
  24. }
  25. /**
  26. * {@inheritdoc}
  27. */
  28. protected function getExpectedId()
  29. {
  30. return 'HSCAN';
  31. }
  32. /**
  33. * @group disconnected
  34. */
  35. public function testFilterArguments()
  36. {
  37. $arguments = array('key', 0, 'MATCH', 'field:*', 'COUNT', 10);
  38. $expected = array('key', 0, 'MATCH', 'field:*', 'COUNT', 10);
  39. $command = $this->getCommand();
  40. $command->setArguments($arguments);
  41. $this->assertSame($expected, $command->getArguments());
  42. }
  43. /**
  44. * @group disconnected
  45. */
  46. public function testFilterArgumentsBasicUsage()
  47. {
  48. $arguments = array('key', 0);
  49. $expected = array('key', 0);
  50. $command = $this->getCommand();
  51. $command->setArguments($arguments);
  52. $this->assertSame($expected, $command->getArguments());
  53. }
  54. /**
  55. * @group disconnected
  56. */
  57. public function testFilterArgumentsWithOptionsArray()
  58. {
  59. $arguments = array('key', 0, array('match' => 'field:*', 'count' => 10));
  60. $expected = array('key', 0, 'MATCH', 'field:*', 'COUNT', 10);
  61. $command = $this->getCommand();
  62. $command->setArguments($arguments);
  63. $this->assertSame($expected, $command->getArguments());
  64. }
  65. /**
  66. * @group disconnected
  67. */
  68. public function testParseResponse()
  69. {
  70. $raw = array('3', array('field:1', '1', 'field:2', '2', 'field:3', '3'));
  71. $expected = array(3, array('field:1' => '1', 'field:2' => '2', 'field:3' => '3'));
  72. $command = $this->getCommand();
  73. $this->assertSame($expected, $command->parseResponse($raw));
  74. }
  75. /**
  76. * @group connected
  77. */
  78. public function testScanWithoutMatch()
  79. {
  80. $expectedFields = array('field:one', 'field:two', 'field:three', 'field:four');
  81. $expectedValues = array('one', 'two', 'three', 'four');
  82. $redis = $this->getClient();
  83. $redis->hmset('key', array_combine($expectedFields, $expectedValues));
  84. $response = $redis->hscan('key', 0);
  85. $this->assertSame(0, $response[0]);
  86. $this->assertSame($expectedFields, array_keys($response[1]));
  87. $this->assertSame($expectedValues, array_values($response[1]));
  88. }
  89. /**
  90. * @group connected
  91. */
  92. public function testScanWithMatchingMembers()
  93. {
  94. $redis = $this->getClient();
  95. $redis->hmset('key', array('field:one' => 'one', 'field:two' => 'two', 'field:three' => 'three', 'field:four' => 'four'));
  96. $response = $redis->hscan('key', 0, 'MATCH', 'field:t*');
  97. $this->assertSame(array('field:two', 'field:three'), array_keys($response[1]));
  98. $this->assertSame(array('two', 'three'), array_values($response[1]));
  99. }
  100. /**
  101. * @group connected
  102. */
  103. public function testScanWithNoMatchingMembers()
  104. {
  105. $redis = $this->getClient();
  106. $redis->hmset('key', array('field:one' => 'one', 'field:two' => 'two', 'field:three' => 'three', 'field:four' => 'four'));
  107. $response = $redis->hscan('key', 0, 'MATCH', 'nofield:*');
  108. $this->assertSame(0, $response[0]);
  109. $this->assertEmpty($response[1]);
  110. }
  111. }