ConnectionParametersTest.php 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241
  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\Connection;
  11. use \PHPUnit_Framework_TestCase as StandardTestCase;
  12. /**
  13. * @todo ConnectionParameters::define();
  14. * @todo ConnectionParameters::undefine();
  15. */
  16. class ParametersTest extends StandardTestCase
  17. {
  18. /**
  19. * @group disconnected
  20. */
  21. public function testDefaultValues()
  22. {
  23. $defaults = $this->getDefaultParametersArray();
  24. $parameters = new ConnectionParameters();
  25. $this->assertEquals($defaults['scheme'], $parameters->scheme);
  26. $this->assertEquals($defaults['host'], $parameters->host);
  27. $this->assertEquals($defaults['port'], $parameters->port);
  28. $this->assertEquals($defaults['timeout'], $parameters->timeout);
  29. }
  30. /**
  31. * @group disconnected
  32. */
  33. public function testIsSet()
  34. {
  35. $parameters = new ConnectionParameters();
  36. $this->assertTrue(isset($parameters->scheme));
  37. $this->assertFalse(isset($parameters->unknown));
  38. }
  39. /**
  40. * @group disconnected
  41. */
  42. public function testUserDefinedParameters()
  43. {
  44. $parameters = new ConnectionParameters(array('port' => 7000, 'custom' => 'foobar'));
  45. $this->assertTrue(isset($parameters->scheme));
  46. $this->assertSame('tcp', $parameters->scheme);
  47. $this->assertTrue(isset($parameters->port));
  48. $this->assertSame(7000, $parameters->port);
  49. $this->assertTrue(isset($parameters->custom));
  50. $this->assertSame('foobar', $parameters->custom);
  51. $this->assertFalse(isset($parameters->unknown));
  52. $this->assertNull($parameters->unknown);
  53. }
  54. /**
  55. * @group disconnected
  56. */
  57. public function testConstructWithUriString()
  58. {
  59. $defaults = $this->getDefaultParametersArray();
  60. $overrides = array(
  61. 'port' => 7000,
  62. 'database' => 5,
  63. 'custom' => 'foobar',
  64. );
  65. $parameters = new ConnectionParameters($this->getParametersString($overrides));
  66. $this->assertEquals($defaults['scheme'], $parameters->scheme);
  67. $this->assertEquals($defaults['host'], $parameters->host);
  68. $this->assertEquals($overrides['port'], $parameters->port);
  69. $this->assertEquals($overrides['database'], $parameters->database);
  70. $this->assertTrue(isset($parameters->custom));
  71. $this->assertEquals($overrides['custom'], $parameters->custom);
  72. $this->assertFalse(isset($parameters->unknown));
  73. $this->assertNull($parameters->unknown);
  74. }
  75. /**
  76. * @group disconnected
  77. */
  78. public function testToArray()
  79. {
  80. $additional = array('port' => 7000, 'custom' => 'foobar');
  81. $parameters = new ConnectionParameters($additional);
  82. $this->assertEquals($this->getParametersArray($additional), $parameters->toArray());
  83. }
  84. /**
  85. * @group disconnected
  86. */
  87. public function testSerialization()
  88. {
  89. $parameters = new ConnectionParameters(array('port' => 7000, 'custom' => 'foobar'));
  90. $unserialized = unserialize(serialize($parameters));
  91. $this->assertEquals($parameters->scheme, $unserialized->scheme);
  92. $this->assertEquals($parameters->port, $unserialized->port);
  93. $this->assertTrue(isset($unserialized->custom));
  94. $this->assertEquals($parameters->custom, $unserialized->custom);
  95. $this->assertFalse(isset($unserialized->unknown));
  96. $this->assertNull($unserialized->unknown);
  97. }
  98. /**
  99. * @group disconnected
  100. */
  101. public function testParsingURI()
  102. {
  103. $uri = 'tcp://10.10.10.10:6400?timeout=0.5&persistent=1';
  104. $expected = array(
  105. 'scheme' => 'tcp',
  106. 'host' => '10.10.10.10',
  107. 'port' => 6400,
  108. 'timeout' => '0.5',
  109. 'persistent' => '1',
  110. );
  111. $this->assertSame($expected, ConnectionParameters::parse($uri));
  112. }
  113. /**
  114. * @group disconnected
  115. */
  116. public function testParsingUnixDomainURI()
  117. {
  118. $uri = 'unix:///tmp/redis.sock?timeout=0.5&persistent=1';
  119. $expected = array(
  120. 'scheme' => 'unix',
  121. 'host' => 'localhost',
  122. 'path' => '/tmp/redis.sock',
  123. 'timeout' => '0.5',
  124. 'persistent' => '1',
  125. );
  126. $this->assertSame($expected, ConnectionParameters::parse($uri));
  127. }
  128. /**
  129. * @group disconnected
  130. */
  131. public function testParsingURIWithIncompletePairInQueryString()
  132. {
  133. $uri = 'tcp://10.10.10.10?persistent=1&foo=&bar';
  134. $expected = array(
  135. 'scheme' => 'tcp',
  136. 'host' => '10.10.10.10',
  137. 'persistent' => '1',
  138. 'foo' => '',
  139. );
  140. $this->assertSame($expected, ConnectionParameters::parse($uri));
  141. }
  142. /**
  143. * @group disconnected
  144. * @expectedException InvalidArgumentException
  145. * @expectedExceptionMessage Invalid parameters URI: tcp://invalid:uri
  146. */
  147. public function testParsingURIThrowOnInvalidURI()
  148. {
  149. ConnectionParameters::parse('tcp://invalid:uri');
  150. }
  151. // ******************************************************************** //
  152. // ---- HELPER METHODS ------------------------------------------------ //
  153. // ******************************************************************** //
  154. /**
  155. * Returns a named array with the default connection parameters and their values.
  156. *
  157. * @return Array Default connection parameters.
  158. */
  159. protected function getDefaultParametersArray()
  160. {
  161. return array(
  162. 'scheme' => 'tcp',
  163. 'host' => '127.0.0.1',
  164. 'port' => 6379,
  165. 'timeout' => 5.0,
  166. );
  167. }
  168. /**
  169. * Returns a named array with the default connection parameters merged with
  170. * the specified additional parameters.
  171. *
  172. * @param Array $additional Additional connection parameters.
  173. * @return Array Connection parameters.
  174. */
  175. protected function getParametersArray(Array $additional)
  176. {
  177. return array_merge($this->getDefaultParametersArray(), $additional);
  178. }
  179. /**
  180. * Returns an URI string representation of the specified connection parameters.
  181. *
  182. * @param Array $parameters Array of connection parameters.
  183. * @return String URI string.
  184. */
  185. protected function getParametersString(Array $parameters)
  186. {
  187. $defaults = $this->getDefaultParametersArray();
  188. $scheme = isset($parameters['scheme']) ? $parameters['scheme'] : $defaults['scheme'];
  189. $host = isset($parameters['host']) ? $parameters['host'] : $defaults['host'];
  190. $port = isset($parameters['port']) ? $parameters['port'] : $defaults['port'];
  191. unset($parameters['scheme'], $parameters['host'], $parameters['port']);
  192. $uriString = "$scheme://$host:$port/?";
  193. foreach ($parameters as $k => $v) {
  194. $uriString .= "$k=$v&";
  195. }
  196. return $uriString;
  197. }
  198. }