KeyPreciseExpireTest.php 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  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-key
  15. */
  16. class KeyPreciseExpireTest extends CommandTestCase
  17. {
  18. /**
  19. * {@inheritdoc}
  20. */
  21. protected function getExpectedCommand()
  22. {
  23. return 'Predis\Commands\KeyPreciseExpire';
  24. }
  25. /**
  26. * {@inheritdoc}
  27. */
  28. protected function getExpectedId()
  29. {
  30. return 'PEXPIRE';
  31. }
  32. /**
  33. * @group disconnected
  34. */
  35. public function testFilterArguments()
  36. {
  37. $arguments = array('key', 100);
  38. $expected = array('key', 100);
  39. $command = $this->getCommand();
  40. $command->setArguments($arguments);
  41. $this->assertSame($expected, $command->getArguments());
  42. }
  43. /**
  44. * @group disconnected
  45. */
  46. public function testParseResponse()
  47. {
  48. $command = $this->getCommand();
  49. $this->assertTrue($command->parseResponse(1));
  50. $this->assertFalse($command->parseResponse(0));
  51. }
  52. /**
  53. * @group disconnected
  54. */
  55. public function testPrefixKeys()
  56. {
  57. $arguments = array('key', 'value');
  58. $expected = array('prefix:key', 'value');
  59. $command = $this->getCommandWithArgumentsArray($arguments);
  60. $command->prefixKeys('prefix:');
  61. $this->assertSame($expected, $command->getArguments());
  62. }
  63. /**
  64. * @group connected
  65. */
  66. public function testReturnsFalseOnNonExistingKeys()
  67. {
  68. $redis = $this->getClient();
  69. $this->assertFalse($redis->pexpire('foo', 20000));
  70. }
  71. /**
  72. * @group connected
  73. * @group slow
  74. */
  75. public function testCanExpireKeys()
  76. {
  77. $ttl = 1 * 1000;
  78. $redis = $this->getClient();
  79. $redis->set('foo', 'bar');
  80. $this->assertTrue($redis->pexpire('foo', $ttl));
  81. $this->sleep(1.2);
  82. $this->assertFalse($redis->exists('foo'));
  83. }
  84. /**
  85. * @group connected
  86. * @group slow
  87. */
  88. public function testConsistencyWithTTL()
  89. {
  90. $ttl = 1 * 1000;
  91. $redis = $this->getClient();
  92. $redis->set('foo', 'bar');
  93. $this->assertTrue($redis->pexpire('foo', $ttl));
  94. $this->sleep(0.5);
  95. $this->assertLessThanOrEqual($ttl, $redis->pttl('foo'));
  96. $this->assertGreaterThan($ttl - 800, $redis->pttl('foo'));
  97. }
  98. /**
  99. * @group connected
  100. */
  101. public function testDeletesKeysOnNegativeTTL()
  102. {
  103. $redis = $this->getClient();
  104. $redis->set('foo', 'bar');
  105. $this->assertTrue($redis->pexpire('foo', -10000));
  106. $this->assertFalse($redis->exists('foo'));
  107. }
  108. }