PageRenderTime 40ms CodeModel.GetById 14ms RepoModel.GetById 0ms app.codeStats 0ms

/tests/Zend/Validate/AbstractTest.php

https://github.com/tanduy/zf
PHP | 316 lines | 224 code | 37 blank | 55 comment | 4 complexity | ece9cd5176956bb36e3c442f08a1a569 MD5 | raw file
  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-2010 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. if (!defined('PHPUnit_MAIN_METHOD')) {
  23. define('PHPUnit_MAIN_METHOD', 'Zend_Validate_AbstractTest::main');
  24. }
  25. /** Test helper */
  26. require_once dirname(__FILE__) . '/../../TestHelper.php';
  27. /** Zend_Validate_Abstract */
  28. require_once 'Zend/Validate/Abstract.php';
  29. /** Zend_Translate */
  30. require_once 'Zend/Translate.php';
  31. /** Zend_Registry */
  32. require_once 'Zend/Registry.php';
  33. /**
  34. * @category Zend
  35. * @package Zend_Validate
  36. * @subpackage UnitTests
  37. * @copyright Copyright (c) 2005-2010 Zend Technologies USA Inc. (http://www.zend.com)
  38. * @license http://framework.zend.com/license/new-bsd New BSD License
  39. * @group Zend_Validate
  40. */
  41. class Zend_Validate_AbstractTest extends PHPUnit_Framework_TestCase
  42. {
  43. /**
  44. * Runs this test suite
  45. *
  46. * @return void
  47. */
  48. public static function main()
  49. {
  50. $suite = new PHPUnit_Framework_TestSuite('Zend_Validate_AbstractTest');
  51. $result = PHPUnit_TextUI_TestRunner::run($suite);
  52. }
  53. public function clearRegistry()
  54. {
  55. if (Zend_Registry::isRegistered('Zend_Translate')) {
  56. $registry = Zend_Registry::getInstance();
  57. unset($registry['Zend_Translate']);
  58. }
  59. }
  60. /**
  61. * Creates a new validation object for each test method
  62. *
  63. * @return void
  64. */
  65. public function setUp()
  66. {
  67. $this->clearRegistry();
  68. Zend_Validate_Abstract::setDefaultTranslator(null);
  69. $this->validator = new Zend_Validate_AbstractTest_Concrete();
  70. }
  71. public function tearDown()
  72. {
  73. $this->clearRegistry();
  74. Zend_Validate_Abstract::setDefaultTranslator(null);
  75. Zend_Validate_Abstract::setMessageLength(-1);
  76. }
  77. public function testTranslatorNullByDefault()
  78. {
  79. $this->assertNull($this->validator->getTranslator());
  80. }
  81. public function testCanSetTranslator()
  82. {
  83. $this->testTranslatorNullByDefault();
  84. set_error_handler(array($this, 'errorHandlerIgnore'));
  85. $translator = new Zend_Translate('array', array(), 'en');
  86. restore_error_handler();
  87. $this->validator->setTranslator($translator);
  88. $this->assertSame($translator->getAdapter(), $this->validator->getTranslator());
  89. }
  90. public function testCanSetTranslatorToNull()
  91. {
  92. $this->testCanSetTranslator();
  93. set_error_handler(array($this, 'errorHandlerIgnore'));
  94. $this->validator->setTranslator(null);
  95. restore_error_handler();
  96. $this->assertNull($this->validator->getTranslator());
  97. }
  98. public function testGlobalDefaultTranslatorNullByDefault()
  99. {
  100. $this->assertNull(Zend_Validate_Abstract::getDefaultTranslator());
  101. }
  102. public function testCanSetGlobalDefaultTranslator()
  103. {
  104. $this->testGlobalDefaultTranslatorNullByDefault();
  105. set_error_handler(array($this, 'errorHandlerIgnore'));
  106. $translator = new Zend_Translate('array', array(), 'en');
  107. restore_error_handler();
  108. Zend_Validate_Abstract::setDefaultTranslator($translator);
  109. $this->assertSame($translator->getAdapter(), Zend_Validate_Abstract::getDefaultTranslator());
  110. }
  111. public function testGlobalDefaultTranslatorUsedWhenNoLocalTranslatorSet()
  112. {
  113. $this->testCanSetGlobalDefaultTranslator();
  114. $this->assertSame(Zend_Validate_Abstract::getDefaultTranslator(), $this->validator->getTranslator());
  115. }
  116. public function testGlobalTranslatorFromRegistryUsedWhenNoLocalTranslatorSet()
  117. {
  118. set_error_handler(array($this, 'errorHandlerIgnore'));
  119. $translate = new Zend_Translate('array', array());
  120. restore_error_handler();
  121. Zend_Registry::set('Zend_Translate', $translate);
  122. $this->assertSame($translate->getAdapter(), $this->validator->getTranslator());
  123. }
  124. public function testLocalTranslatorPreferredOverGlobalTranslator()
  125. {
  126. $this->testCanSetGlobalDefaultTranslator();
  127. set_error_handler(array($this, 'errorHandlerIgnore'));
  128. $translator = new Zend_Translate('array', array(), 'en');
  129. restore_error_handler();
  130. $this->validator->setTranslator($translator);
  131. $this->assertNotSame(Zend_Validate_Abstract::getDefaultTranslator(), $this->validator->getTranslator());
  132. }
  133. public function testErrorMessagesAreTranslatedWhenTranslatorPresent()
  134. {
  135. $translator = new Zend_Translate(
  136. 'array',
  137. array('fooMessage' => 'This is the translated message for %value%'),
  138. 'en'
  139. );
  140. $this->validator->setTranslator($translator);
  141. $this->assertFalse($this->validator->isValid('bar'));
  142. $messages = $this->validator->getMessages();
  143. $this->assertTrue(array_key_exists('fooMessage', $messages));
  144. $this->assertContains('bar', $messages['fooMessage']);
  145. $this->assertContains('This is the translated message for ', $messages['fooMessage']);
  146. }
  147. public function testCanTranslateMessagesInsteadOfKeys()
  148. {
  149. $translator = new Zend_Translate(
  150. 'array',
  151. array('%value% was passed' => 'This is the translated message for %value%'),
  152. 'en'
  153. );
  154. $this->validator->setTranslator($translator);
  155. $this->assertFalse($this->validator->isValid('bar'));
  156. $messages = $this->validator->getMessages();
  157. $this->assertTrue(array_key_exists('fooMessage', $messages));
  158. $this->assertContains('bar', $messages['fooMessage']);
  159. $this->assertContains('This is the translated message for ', $messages['fooMessage']);
  160. }
  161. public function testObscureValueFlagFalseByDefault()
  162. {
  163. $this->assertFalse($this->validator->getObscureValue());
  164. }
  165. public function testCanSetObscureValueFlag()
  166. {
  167. $this->testObscureValueFlagFalseByDefault();
  168. $this->validator->setObscureValue(true);
  169. $this->assertTrue($this->validator->getObscureValue());
  170. $this->validator->setObscureValue(false);
  171. $this->assertFalse($this->validator->getObscureValue());
  172. }
  173. public function testValueIsObfuscatedWheObscureValueFlagIsTrue()
  174. {
  175. $this->validator->setObscureValue(true);
  176. $this->assertFalse($this->validator->isValid('foobar'));
  177. $messages = $this->validator->getMessages();
  178. $this->assertTrue(isset($messages['fooMessage']));
  179. $message = $messages['fooMessage'];
  180. $this->assertNotContains('foobar', $message);
  181. $this->assertContains('******', $message);
  182. }
  183. /**
  184. * @see ZF-4463
  185. */
  186. public function testDoesNotFailOnObjectInput()
  187. {
  188. $this->assertFalse($this->validator->isValid(new stdClass()));
  189. $messages = $this->validator->getMessages();
  190. $this->assertTrue(array_key_exists('fooMessage', $messages));
  191. }
  192. public function testTranslatorEnabledPerDefault()
  193. {
  194. set_error_handler(array($this, 'errorHandlerIgnore'));
  195. $translator = new Zend_Translate('array', array(), 'en');
  196. restore_error_handler();
  197. $this->validator->setTranslator($translator);
  198. $this->assertFalse($this->validator->translatorIsDisabled());
  199. }
  200. public function testCanDisableTranslator()
  201. {
  202. set_error_handler(array($this, 'errorHandlerIgnore'));
  203. $translator = new Zend_Translate(
  204. 'array',
  205. array('fooMessage' => 'This is the translated message for %value%'),
  206. 'en'
  207. );
  208. restore_error_handler();
  209. $this->validator->setTranslator($translator);
  210. $this->assertFalse($this->validator->isValid('bar'));
  211. $messages = $this->validator->getMessages();
  212. $this->assertTrue(array_key_exists('fooMessage', $messages));
  213. $this->assertContains('bar', $messages['fooMessage']);
  214. $this->assertContains('This is the translated message for ', $messages['fooMessage']);
  215. $this->validator->setDisableTranslator(true);
  216. $this->assertTrue($this->validator->translatorIsDisabled());
  217. $this->assertFalse($this->validator->isValid('bar'));
  218. $messages = $this->validator->getMessages();
  219. $this->assertTrue(array_key_exists('fooMessage', $messages));
  220. $this->assertContains('bar', $messages['fooMessage']);
  221. $this->assertContains('bar was passed', $messages['fooMessage']);
  222. }
  223. public function testGetMessageTemplates()
  224. {
  225. $messages = $this->validator->getMessageTemplates();
  226. $this->assertEquals(
  227. array('fooMessage' => '%value% was passed'), $messages);
  228. $this->assertEquals(
  229. array(
  230. Zend_Validate_AbstractTest_Concrete::FOO_MESSAGE => '%value% was passed'), $messages);
  231. }
  232. public function testMaximumErrorMessageLength()
  233. {
  234. require_once 'Zend/Validate.php';
  235. $this->assertEquals(-1, Zend_Validate::getMessageLength());
  236. Zend_Validate_Abstract::setMessageLength(10);
  237. $this->assertEquals(10, Zend_Validate::getMessageLength());
  238. $translator = new Zend_Translate(
  239. 'array',
  240. array('fooMessage' => 'This is the translated message for %value%'),
  241. 'en'
  242. );
  243. $this->validator->setTranslator($translator);
  244. $this->assertFalse($this->validator->isValid('bar'));
  245. $messages = $this->validator->getMessages();
  246. $this->assertTrue(array_key_exists('fooMessage', $messages));
  247. $this->assertEquals('This is...', $messages['fooMessage']);
  248. }
  249. /**
  250. * Ignores a raised PHP error when in effect, but throws a flag to indicate an error occurred
  251. *
  252. * @param integer $errno
  253. * @param string $errstr
  254. * @param string $errfile
  255. * @param integer $errline
  256. * @param array $errcontext
  257. * @return void
  258. */
  259. public function errorHandlerIgnore($errno, $errstr, $errfile, $errline, array $errcontext)
  260. {
  261. $this->_errorOccurred = true;
  262. }
  263. }
  264. class Zend_Validate_AbstractTest_Concrete extends Zend_Validate_Abstract
  265. {
  266. const FOO_MESSAGE = 'fooMessage';
  267. protected $_messageTemplates = array(
  268. 'fooMessage' => '%value% was passed',
  269. );
  270. public function isValid($value)
  271. {
  272. $this->_setValue($value);
  273. $this->_error(self::FOO_MESSAGE);
  274. return false;
  275. }
  276. }
  277. if (PHPUnit_MAIN_METHOD == 'Zend_Validate_AbstractTest::main') {
  278. Zend_Validate_AbstractTest::main();
  279. }