2
0

AbstractTest.php 11 KB

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