StringSetMultiplePreserveTest.php 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122
  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. /**
  12. * @group commands
  13. * @group realm-string
  14. */
  15. class StringSetMultiplePreserveTest extends PredisCommandTestCase
  16. {
  17. /**
  18. * {@inheritdoc}
  19. */
  20. protected function getExpectedCommand()
  21. {
  22. return 'Predis\Command\StringSetMultiplePreserve';
  23. }
  24. /**
  25. * {@inheritdoc}
  26. */
  27. protected function getExpectedId()
  28. {
  29. return 'MSETNX';
  30. }
  31. /**
  32. * @group disconnected
  33. */
  34. public function testFilterArguments()
  35. {
  36. $arguments = array('foo', 'bar', 'hoge', 'piyo');
  37. $expected = array('foo', 'bar', 'hoge', 'piyo');
  38. $command = $this->getCommand();
  39. $command->setArguments($arguments);
  40. $this->assertSame($expected, $command->getArguments());
  41. }
  42. /**
  43. * @group disconnected
  44. */
  45. public function testFilterArgumentsAsSingleNamedArray()
  46. {
  47. $arguments = array(array('foo' => 'bar', 'hoge' => 'piyo'));
  48. $expected = array('foo', 'bar', 'hoge', 'piyo');
  49. $command = $this->getCommand();
  50. $command->setArguments($arguments);
  51. $this->assertSame($expected, $command->getArguments());
  52. }
  53. /**
  54. * @group disconnected
  55. */
  56. public function testParseResponse()
  57. {
  58. $this->assertSame(true, $this->getCommand()->parseResponse(true));
  59. }
  60. /**
  61. * @group disconnected
  62. */
  63. public function testPrefixKeys()
  64. {
  65. $arguments = array('foo', 'bar', 'hoge', 'piyo');
  66. $expected = array('prefix:foo', 'bar', 'prefix:hoge', 'piyo');
  67. $command = $this->getCommandWithArgumentsArray($arguments);
  68. $command->prefixKeys('prefix:');
  69. $this->assertSame($expected, $command->getArguments());
  70. }
  71. /**
  72. * @group disconnected
  73. */
  74. public function testPrefixKeysIgnoredOnEmptyArguments()
  75. {
  76. $command = $this->getCommand();
  77. $command->prefixKeys('prefix:');
  78. $this->assertSame(array(), $command->getArguments());
  79. }
  80. /**
  81. * @group connected
  82. */
  83. public function testCreatesMultipleKeys()
  84. {
  85. $redis = $this->getClient();
  86. $this->assertTrue($redis->msetnx('foo', 'bar', 'hoge', 'piyo'));
  87. $this->assertSame('bar', $redis->get('foo'));
  88. $this->assertSame('piyo', $redis->get('hoge'));
  89. }
  90. /**
  91. * @group connected
  92. */
  93. public function testCreatesMultipleKeysAndPreservesExistingOnes()
  94. {
  95. $redis = $this->getClient();
  96. $redis->set('foo', 'bar');
  97. $this->assertFalse($redis->msetnx('foo', 'barbar', 'hoge', 'piyo'));
  98. $this->assertSame('bar', $redis->get('foo'));
  99. $this->assertFalse($redis->exists('hoge'));
  100. }
  101. }