PredisShared.php 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213
  1. <?php
  2. require_once '../lib/Predis.php';
  3. if (I_AM_AWARE_OF_THE_DESTRUCTIVE_POWER_OF_THIS_TEST_SUITE !== true) {
  4. exit('Please set the I_AM_AWARE_OF_THE_DESTRUCTIVE_POWER_OF_THIS_TEST_SUITE constant to TRUE if you want to proceed.');
  5. }
  6. if (!function_exists('array_union')) {
  7. function array_union(Array $a, Array $b) {
  8. return array_merge($a, array_diff($b, $a));
  9. }
  10. }
  11. class RC {
  12. const SERVER_HOST = '127.0.0.1';
  13. const SERVER_PORT = 6379;
  14. const DEFAULT_DATABASE = 15;
  15. const WIPE_OUT = 1;
  16. const EXCEPTION_WRONG_TYPE = 'Operation against a key holding the wrong kind of value';
  17. const EXCEPTION_NO_SUCH_KEY = 'no such key';
  18. const EXCEPTION_OUT_OF_RANGE = 'index out of range';
  19. const EXCEPTION_INVALID_DB_IDX = 'invalid DB index';
  20. const EXCEPTION_VALUE_NOT_INT = 'value is not an integer';
  21. const EXCEPTION_EXEC_NO_MULTI = 'EXEC without MULTI';
  22. const EXCEPTION_SETEX_TTL = 'invalid expire time in SETEX';
  23. const EXCEPTION_HASH_VALNOTINT = 'hash value is not an integer';
  24. private static $_connection;
  25. public static function getConnectionArguments() {
  26. return array('host' => RC::SERVER_HOST, 'port' => RC::SERVER_PORT);
  27. }
  28. public static function getConnectionParameters() {
  29. return new Predis\ConnectionParameters(array('host' => RC::SERVER_HOST, 'port' => RC::SERVER_PORT));
  30. }
  31. private static function createConnection() {
  32. $serverProfile = Predis\RedisServerProfile::get('dev');
  33. $connection = new Predis\Client(RC::getConnectionArguments(), $serverProfile);
  34. $connection->connect();
  35. $connection->select(RC::DEFAULT_DATABASE);
  36. return $connection;
  37. }
  38. public static function getConnection($new = false) {
  39. if ($new == true) {
  40. return self::createConnection();
  41. }
  42. if (self::$_connection === null || !self::$_connection->isConnected()) {
  43. self::$_connection = self::createConnection();
  44. }
  45. return self::$_connection;
  46. }
  47. public static function resetConnection() {
  48. if (self::$_connection !== null && self::$_connection->isConnected()) {
  49. self::$_connection->disconnect();
  50. self::$_connection = self::createConnection();
  51. }
  52. }
  53. public static function helperForBlockingPops($op) {
  54. // TODO: I admit that this helper is kinda lame and it does not run
  55. // in a separate process to properly test BLPOP/BRPOP
  56. $redisUri = sprintf('redis://%s:%d/?database=%d', RC::SERVER_HOST, RC::SERVER_PORT, RC::DEFAULT_DATABASE);
  57. $handle = popen('php', 'w');
  58. fwrite($handle, "<?php
  59. require '../lib/Predis.php';
  60. \$redis = Predis\Client::create('$redisUri');
  61. \$redis->rpush('{$op}1', 'a');
  62. \$redis->rpush('{$op}2', 'b');
  63. \$redis->rpush('{$op}3', 'c');
  64. \$redis->rpush('{$op}1', 'd');
  65. ?>");
  66. pclose($handle);
  67. }
  68. public static function getArrayOfNumbers() {
  69. return array(0, 1, 2, 3, 4, 5, 6, 7, 8, 9);
  70. }
  71. public static function getKeyValueArray() {
  72. return array(
  73. 'foo' => 'bar',
  74. 'hoge' => 'piyo',
  75. 'foofoo' => 'barbar',
  76. );
  77. }
  78. public static function getNamespacedKeyValueArray() {
  79. return array(
  80. 'metavar:foo' => 'bar',
  81. 'metavar:hoge' => 'piyo',
  82. 'metavar:foofoo' => 'barbar',
  83. );
  84. }
  85. public static function getZSetArray() {
  86. return array(
  87. 'a' => -10, 'b' => 0, 'c' => 10, 'd' => 20, 'e' => 20, 'f' => 30
  88. );
  89. }
  90. public static function sameValuesInArrays($arrayA, $arrayB) {
  91. if (count($arrayA) != count($arrayB)) {
  92. return false;
  93. }
  94. return count(array_diff($arrayA, $arrayB)) == 0;
  95. }
  96. public static function testForServerException($testcaseInstance, $expectedMessage, $wrapFunction) {
  97. $thrownException = null;
  98. try {
  99. $wrapFunction($testcaseInstance);
  100. }
  101. catch (Predis\ServerException $exception) {
  102. $thrownException = $exception;
  103. }
  104. $testcaseInstance->assertType('Predis\ServerException', $thrownException);
  105. if (isset($expectedMessage)) {
  106. $testcaseInstance->assertEquals($expectedMessage, $thrownException->getMessage());
  107. }
  108. }
  109. public static function testForClientException($testcaseInstance, $expectedMessage, $wrapFunction) {
  110. $thrownException = null;
  111. try {
  112. $wrapFunction($testcaseInstance);
  113. }
  114. catch (Predis\ClientException $exception) {
  115. $thrownException = $exception;
  116. }
  117. $testcaseInstance->assertType('Predis\ClientException', $thrownException);
  118. if (isset($expectedMessage)) {
  119. $testcaseInstance->assertEquals($expectedMessage, $thrownException->getMessage());
  120. }
  121. }
  122. public static function testForCommunicationException($testcaseInstance, $expectedMessage, $wrapFunction) {
  123. $thrownException = null;
  124. try {
  125. $wrapFunction($testcaseInstance);
  126. }
  127. catch (Predis\CommunicationException $exception) {
  128. $thrownException = $exception;
  129. }
  130. $testcaseInstance->assertType('Predis\CommunicationException', $thrownException);
  131. if (isset($expectedMessage)) {
  132. $testcaseInstance->assertEquals($expectedMessage, $thrownException->getMessage());
  133. }
  134. }
  135. public static function testForAbortedMultiExecException($testcaseInstance, $wrapFunction) {
  136. $thrownException = null;
  137. try {
  138. $wrapFunction($testcaseInstance);
  139. }
  140. catch (Predis\AbortedMultiExec $exception) {
  141. $thrownException = $exception;
  142. }
  143. $testcaseInstance->assertType('Predis\AbortedMultiExec', $thrownException);
  144. }
  145. public static function pushTailAndReturn(Predis\Client $client, $keyName, Array $values, $wipeOut = 0) {
  146. if ($wipeOut == true) {
  147. $client->del($keyName);
  148. }
  149. foreach ($values as $value) {
  150. $client->rpush($keyName, $value);
  151. }
  152. return $values;
  153. }
  154. public static function setAddAndReturn(Predis\Client $client, $keyName, Array $values, $wipeOut = 0) {
  155. if ($wipeOut == true) {
  156. $client->del($keyName);
  157. }
  158. foreach ($values as $value) {
  159. $client->sadd($keyName, $value);
  160. }
  161. return $values;
  162. }
  163. public static function zsetAddAndReturn(Predis\Client $client, $keyName, Array $values, $wipeOut = 0) {
  164. // $values: array(SCORE => VALUE, ...);
  165. if ($wipeOut == true) {
  166. $client->del($keyName);
  167. }
  168. foreach ($values as $value => $score) {
  169. $client->zadd($keyName, $score, $value);
  170. }
  171. return $values;
  172. }
  173. public static function getConnectionParametersArgumentsArray() {
  174. return array(
  175. 'host' => '10.0.0.1', 'port' => 6380, 'connection_timeout' => 10, 'read_write_timeout' => 30,
  176. 'database' => 5, 'password' => 'dbpassword', 'alias' => 'connection_alias'
  177. );
  178. }
  179. public static function getConnectionParametersArgumentsString($arguments = null) {
  180. // TODO: must be improved
  181. $args = $arguments ?: RC::getConnectionParametersArgumentsArray();
  182. $paramsString = "redis://{$args['host']}:{$args['port']}/";
  183. $paramsString .= "?connection_timeout={$args['connection_timeout']}&read_write_timeout={$args['read_write_timeout']}";
  184. $paramsString .= "&database={$args['database']}&password={$args['password']}&alias={$args['alias']}";
  185. return $paramsString;
  186. }
  187. }
  188. ?>