HostnameTest.php 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383
  1. <?php
  2. /**
  3. * Zend Framework
  4. *
  5. * LICENSE
  6. *
  7. * This source file is subject to the new BSD license that is bundled
  8. * with this package in the file LICENSE.txt.
  9. * It is also available through the world-wide-web at this URL:
  10. * http://framework.zend.com/license/new-bsd
  11. * If you did not receive a copy of the license and are unable to
  12. * obtain it through the world-wide-web, please send an email
  13. * to license@zend.com so we can send you a copy immediately.
  14. *
  15. * @category Zend
  16. * @package Zend_Validate
  17. * @subpackage UnitTests
  18. * @copyright Copyright (c) 2005-2009 Zend Technologies USA Inc. (http://www.zend.com)
  19. * @license http://framework.zend.com/license/new-bsd New BSD License
  20. * @version $Id$
  21. */
  22. /**
  23. * Test helper
  24. */
  25. require_once dirname(__FILE__) . '/../../TestHelper.php';
  26. /**
  27. * @see Zend_Validate_Hostname
  28. */
  29. require_once 'Zend/Validate/Hostname.php';
  30. /**
  31. * @category Zend
  32. * @package Zend_Validate
  33. * @subpackage UnitTests
  34. * @copyright Copyright (c) 2005-2009 Zend Technologies USA Inc. (http://www.zend.com)
  35. * @license http://framework.zend.com/license/new-bsd New BSD License
  36. */
  37. class Zend_Validate_HostnameTest extends PHPUnit_Framework_TestCase
  38. {
  39. /**
  40. * Default instance created for all test methods
  41. *
  42. * @var Zend_Validate_Hostname
  43. */
  44. protected $_validator;
  45. /**
  46. * Creates a new Zend_Validate_Hostname object for each test method
  47. *
  48. * @return void
  49. */
  50. public function setUp()
  51. {
  52. $this->_origEncoding = iconv_get_encoding('internal_encoding');
  53. $this->_validator = new Zend_Validate_Hostname();
  54. }
  55. /**
  56. * Reset iconv
  57. */
  58. public function tearDown()
  59. {
  60. iconv_set_encoding('internal_encoding', $this->_origEncoding);
  61. }
  62. /**
  63. * Ensures that the validator follows expected behavior
  64. *
  65. * @return void
  66. */
  67. public function testBasic()
  68. {
  69. $valuesExpected = array(
  70. array(Zend_Validate_Hostname::ALLOW_IP, true, array('1.2.3.4', '10.0.0.1', '255.255.255.255')),
  71. array(Zend_Validate_Hostname::ALLOW_IP, false, array('1.2.3.4.5', '0.0.0.256')),
  72. array(Zend_Validate_Hostname::ALLOW_DNS, true, array('example.com', 'example.museum', 'd.hatena.ne.jp')),
  73. array(Zend_Validate_Hostname::ALLOW_DNS, false, array('localhost', 'localhost.localdomain', '1.2.3.4', 'domain.invalid')),
  74. array(Zend_Validate_Hostname::ALLOW_LOCAL, true, array('localhost', 'localhost.localdomain', 'example.com')),
  75. array(Zend_Validate_Hostname::ALLOW_ALL, true, array('localhost', 'example.com', '1.2.3.4')),
  76. array(Zend_Validate_Hostname::ALLOW_LOCAL, false, array('local host', 'example,com', 'exam_ple.com'))
  77. );
  78. foreach ($valuesExpected as $element) {
  79. $validator = new Zend_Validate_Hostname($element[0]);
  80. foreach ($element[2] as $input) {
  81. $this->assertEquals($element[1], $validator->isValid($input), implode("\n", $validator->getMessages()) . $input);
  82. }
  83. }
  84. }
  85. public function testCombination()
  86. {
  87. $valuesExpected = array(
  88. array(Zend_Validate_Hostname::ALLOW_DNS | Zend_Validate_Hostname::ALLOW_LOCAL, true, array('domain.com', 'localhost', 'local.localhost')),
  89. array(Zend_Validate_Hostname::ALLOW_DNS | Zend_Validate_Hostname::ALLOW_LOCAL, false, array('1.2.3.4', '255.255.255.255')),
  90. array(Zend_Validate_Hostname::ALLOW_DNS | Zend_Validate_Hostname::ALLOW_IP, true, array('1.2.3.4', '255.255.255.255')),
  91. array(Zend_Validate_Hostname::ALLOW_DNS | Zend_Validate_Hostname::ALLOW_IP, false, array('localhost', 'local.localhost'))
  92. );
  93. foreach ($valuesExpected as $element) {
  94. $validator = new Zend_Validate_Hostname($element[0]);
  95. foreach ($element[2] as $input) {
  96. $this->assertEquals($element[1], $validator->isValid($input), implode("\n", $validator->getMessages()) . $input);
  97. }
  98. }
  99. }
  100. /**
  101. * Ensure the dash character tests work as expected
  102. *
  103. */
  104. public function testDashes()
  105. {
  106. $valuesExpected = array(
  107. array(Zend_Validate_Hostname::ALLOW_DNS, true, array('domain.com', 'doma-in.com')),
  108. array(Zend_Validate_Hostname::ALLOW_DNS, false, array('-domain.com', 'domain-.com', 'do--main.com'))
  109. );
  110. foreach ($valuesExpected as $element) {
  111. $validator = new Zend_Validate_Hostname($element[0]);
  112. foreach ($element[2] as $input) {
  113. $this->assertEquals($element[1], $validator->isValid($input), implode("\n", $validator->getMessages()) . $input);
  114. }
  115. }
  116. }
  117. /**
  118. * Ensures that getMessages() returns expected default value
  119. *
  120. * @return void
  121. */
  122. public function testGetMessages()
  123. {
  124. $this->assertEquals(array(), $this->_validator->getMessages());
  125. }
  126. /**
  127. * Ensure the IDN check works as expected
  128. *
  129. */
  130. public function testIDN()
  131. {
  132. $validator = new Zend_Validate_Hostname();
  133. // Check IDN matching
  134. $valuesExpected = array(
  135. array(true, array('bürger.de', 'hãllo.de', 'hållo.se')),
  136. array(true, array('bÜrger.de', 'hÃllo.de', 'hÅllo.se')),
  137. array(false, array('hãllo.se', 'bürger.lt', 'hãllo.uk'))
  138. );
  139. foreach ($valuesExpected as $element) {
  140. foreach ($element[1] as $input) {
  141. $this->assertEquals($element[0], $validator->isValid($input), implode("\n", $validator->getMessages()) . $input);
  142. }
  143. }
  144. // Check no IDN matching
  145. $validator->setValidateIdn(false);
  146. $valuesExpected = array(
  147. array(false, array('bürger.de', 'hãllo.de', 'hållo.se'))
  148. );
  149. foreach ($valuesExpected as $element) {
  150. foreach ($element[1] as $input) {
  151. $this->assertEquals($element[0], $validator->isValid($input), implode("\n", $validator->getMessages()) . $input);
  152. }
  153. }
  154. // Check setting no IDN matching via constructor
  155. unset($validator);
  156. $validator = new Zend_Validate_Hostname(Zend_Validate_Hostname::ALLOW_DNS, false);
  157. $valuesExpected = array(
  158. array(false, array('bürger.de', 'hãllo.de', 'hållo.se'))
  159. );
  160. foreach ($valuesExpected as $element) {
  161. foreach ($element[1] as $input) {
  162. $this->assertEquals($element[0], $validator->isValid($input), implode("\n", $validator->getMessages()) . $input);
  163. }
  164. }
  165. }
  166. /**
  167. * Ensure the IDN check works on ressource files as expected
  168. *
  169. */
  170. public function testRessourceIDN()
  171. {
  172. $validator = new Zend_Validate_Hostname();
  173. // Check IDN matching
  174. $valuesExpected = array(
  175. array(true, array('bürger.com', 'hãllo.com', 'hållo.com')),
  176. array(true, array('bÜrger.com', 'hÃllo.com', 'hÅllo.com')),
  177. array(false, array('hãllo.lt', 'bürger.lt', 'hãllo.lt'))
  178. );
  179. foreach ($valuesExpected as $element) {
  180. foreach ($element[1] as $input) {
  181. $this->assertEquals($element[0], $validator->isValid($input), implode("\n", $validator->getMessages()) . $input);
  182. }
  183. }
  184. // Check no IDN matching
  185. $validator->setValidateIdn(false);
  186. $valuesExpected = array(
  187. array(false, array('bürger.com', 'hãllo.com', 'hållo.com'))
  188. );
  189. foreach ($valuesExpected as $element) {
  190. foreach ($element[1] as $input) {
  191. $this->assertEquals($element[0], $validator->isValid($input), implode("\n", $validator->getMessages()) . $input);
  192. }
  193. }
  194. // Check setting no IDN matching via constructor
  195. unset($validator);
  196. $validator = new Zend_Validate_Hostname(Zend_Validate_Hostname::ALLOW_DNS, false);
  197. $valuesExpected = array(
  198. array(false, array('bürger.com', 'hãllo.com', 'hållo.com'))
  199. );
  200. foreach ($valuesExpected as $element) {
  201. foreach ($element[1] as $input) {
  202. $this->assertEquals($element[0], $validator->isValid($input), implode("\n", $validator->getMessages()) . $input);
  203. }
  204. }
  205. }
  206. /**
  207. * Ensure the TLD check works as expected
  208. *
  209. */
  210. public function testTLD()
  211. {
  212. $validator = new Zend_Validate_Hostname();
  213. // Check TLD matching
  214. $valuesExpected = array(
  215. array(true, array('domain.co.uk', 'domain.uk.com', 'domain.tl', 'domain.zw')),
  216. array(false, array('domain.xx', 'domain.zz', 'domain.madeup'))
  217. );
  218. foreach ($valuesExpected as $element) {
  219. foreach ($element[1] as $input) {
  220. $this->assertEquals($element[0], $validator->isValid($input), implode("\n", $validator->getMessages()) . $input);
  221. }
  222. }
  223. // Check no TLD matching
  224. $validator->setValidateTld(false);
  225. $valuesExpected = array(
  226. array(true, array('domain.xx', 'domain.zz', 'domain.madeup'))
  227. );
  228. foreach ($valuesExpected as $element) {
  229. foreach ($element[1] as $input) {
  230. $this->assertEquals($element[0], $validator->isValid($input), implode("\n", $validator->getMessages()) . $input);
  231. }
  232. }
  233. // Check setting no TLD matching via constructor
  234. unset($validator);
  235. $validator = new Zend_Validate_Hostname(Zend_Validate_Hostname::ALLOW_DNS, true, false);
  236. $valuesExpected = array(
  237. array(true, array('domain.xx', 'domain.zz', 'domain.madeup'))
  238. );
  239. foreach ($valuesExpected as $element) {
  240. foreach ($element[1] as $input) {
  241. $this->assertEquals($element[0], $validator->isValid($input), implode("\n", $validator->getMessages()) . $input);
  242. }
  243. }
  244. }
  245. /**
  246. * Ensures that getAllow() returns expected default value
  247. *
  248. * @return void
  249. */
  250. public function testGetAllow()
  251. {
  252. $this->assertEquals(Zend_Validate_Hostname::ALLOW_DNS, $this->_validator->getAllow());
  253. }
  254. /**
  255. * Test changed with ZF-6676, as IP check is only involved when IP patterns match
  256. *
  257. * @see ZF-2861
  258. * @see ZF-6676
  259. */
  260. public function testValidatorMessagesShouldBeTranslated()
  261. {
  262. require_once 'Zend/Translate.php';
  263. $translations = array(
  264. 'hostnameInvalidLocalName' => 'this is the IP error message',
  265. );
  266. $translator = new Zend_Translate('array', $translations);
  267. $this->_validator->setTranslator($translator);
  268. $this->_validator->isValid('0.239,512.777');
  269. $messages = $this->_validator->getMessages();
  270. $found = false;
  271. foreach ($messages as $code => $message) {
  272. if (array_key_exists($code, $translations)) {
  273. $found = true;
  274. break;
  275. }
  276. }
  277. $this->assertTrue($found);
  278. $this->assertEquals($translations[$code], $message);
  279. }
  280. /**
  281. * @see ZF-6033
  282. */
  283. public function testNumberNames()
  284. {
  285. $validator = new Zend_Validate_Hostname();
  286. // Check TLD matching
  287. $valuesExpected = array(
  288. array(true, array('www.danger1.com', 'danger.com', 'www.danger.com')),
  289. array(false, array('www.danger1com', 'dangercom', 'www.dangercom'))
  290. );
  291. foreach ($valuesExpected as $element) {
  292. foreach ($element[1] as $input) {
  293. $this->assertEquals($element[0], $validator->isValid($input), implode("\n", $validator->getMessages()) . $input);
  294. }
  295. }
  296. }
  297. /**
  298. * @see ZF-6133
  299. */
  300. public function testPunycodeDecoding()
  301. {
  302. $validator = new Zend_Validate_Hostname();
  303. // Check TLD matching
  304. $valuesExpected = array(
  305. array(true, array('xn--brger-kva.com')),
  306. array(false, array('xn--brger-x45d2va.com', 'xn--bürger.com', 'xn--'))
  307. );
  308. foreach ($valuesExpected as $element) {
  309. foreach ($element[1] as $input) {
  310. $this->assertEquals($element[0], $validator->isValid($input), implode("\n", $validator->getMessages()) . $input);
  311. }
  312. }
  313. }
  314. /**
  315. * @ZF-4352
  316. */
  317. public function testNonStringValidation()
  318. {
  319. $this->assertFalse($this->_validator->isValid(array(1 => 1)));
  320. }
  321. /**
  322. * @ZF-7323
  323. */
  324. public function testLatinSpecialChars()
  325. {
  326. $this->assertFalse($this->_validator->isValid('place@yah&oo.com'));
  327. $this->assertFalse($this->_validator->isValid('place@y*ahoo.com'));
  328. $this->assertFalse($this->_validator->isValid('ya#hoo'));
  329. }
  330. /**
  331. * @see ZF-7277
  332. */
  333. public function testDifferentIconvEncoding()
  334. {
  335. iconv_set_encoding('internal_encoding', 'ISO8859-1');
  336. $validator = new Zend_Validate_Hostname();
  337. $valuesExpected = array(
  338. array(true, array('bürger.com', 'hãllo.com', 'hållo.com')),
  339. array(true, array('bÜrger.com', 'hÃllo.com', 'hÅllo.com')),
  340. array(false, array('hãllo.lt', 'bürger.lt', 'hãllo.lt'))
  341. );
  342. foreach ($valuesExpected as $element) {
  343. foreach ($element[1] as $input) {
  344. $this->assertEquals($element[0], $validator->isValid($input), implode("\n", $validator->getMessages()) . $input);
  345. }
  346. }
  347. }
  348. }