IsbnTest.php 8.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271
  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. * @copyright Copyright (c) 2005-2010 Zend Technologies USA Inc. (http://www.zend.com)
  18. * @license http://framework.zend.com/license/new-bsd New BSD License
  19. * @version $Id$
  20. */
  21. /**
  22. * Test helper
  23. */
  24. require_once dirname(__FILE__) . '/../../TestHelper.php';
  25. /**
  26. * @see Zend_Validate_Isbn
  27. */
  28. require_once 'Zend/Validate/Isbn.php';
  29. /**
  30. * @category Zend
  31. * @package Zend_Validate
  32. * @subpackage UnitTests
  33. * @copyright Copyright (c) 2005-2010 Zend Technologies USA Inc. (http://www.zend.com)
  34. * @license http://framework.zend.com/license/new-bsd New BSD License
  35. */
  36. class Zend_Validate_IsbnTest extends PHPUnit_Framework_TestCase
  37. {
  38. /**
  39. * Ensures that the validator follows expected behavior
  40. *
  41. * @return void
  42. */
  43. public function testBasic()
  44. {
  45. $validator = new Zend_Validate_Isbn();
  46. // Brave New World by Aldous Huxley
  47. $this->assertTrue($validator->isValid('0060929871'));
  48. $this->assertFalse($validator->isValid('006092987X'));
  49. // Time Rations by Benjamin Friedlander
  50. $this->assertTrue($validator->isValid('188202205X'));
  51. $this->assertFalse($validator->isValid('1882022059'));
  52. // Towards The Primeval Lighting Field by Will Alexander
  53. $this->assertTrue($validator->isValid('1882022300'));
  54. $this->assertFalse($validator->isValid('1882022301'));
  55. // ISBN-13 for dummies by Zoë Wykes
  56. $this->assertTrue($validator->isValid('9780555023402'));
  57. $this->assertFalse($validator->isValid('97805550234029'));
  58. // Change Your Brain, Change Your Life Daniel G. Amen
  59. $this->assertTrue($validator->isValid('9780812929980'));
  60. $this->assertFalse($validator->isValid('9780812929981'));
  61. }
  62. /**
  63. * Ensures that setSeparator() works as expected
  64. *
  65. * @return void
  66. */
  67. public function testType()
  68. {
  69. $validator = new Zend_Validate_Isbn();
  70. try {
  71. $validator->setType(Zend_Validate_Isbn::AUTO);
  72. $this->assertTrue($validator->getType() == Zend_Validate_Isbn::AUTO);
  73. } catch (Exception $e) {
  74. $this->fail("Should accept type 'auto'");
  75. }
  76. try {
  77. $validator->setType(Zend_Validate_Isbn::ISBN10);
  78. $this->assertTrue($validator->getType() == Zend_Validate_Isbn::ISBN10);
  79. } catch (Exception $e) {
  80. $this->fail("Should accept type 'ISBN-10'");
  81. }
  82. try {
  83. $validator->setType(Zend_Validate_Isbn::ISBN13);
  84. $this->assertTrue($validator->getType() == Zend_Validate_Isbn::ISBN13);
  85. } catch (Exception $e) {
  86. $this->fail("Should accept type 'ISBN-13'");
  87. }
  88. try {
  89. $validator->setType('X');
  90. $this->fail("Should not accept type 'X'");
  91. } catch (Exception $e) {
  92. // success
  93. }
  94. }
  95. /**
  96. * Ensures that setSeparator() works as expected
  97. *
  98. * @return void
  99. */
  100. public function testSeparator()
  101. {
  102. $validator = new Zend_Validate_Isbn();
  103. try {
  104. $validator->setSeparator('-');
  105. $this->assertTrue($validator->getSeparator() == '-');
  106. } catch (Exception $e) {
  107. $this->fail("Should accept separator '-'");
  108. }
  109. try {
  110. $validator->setSeparator(' ');
  111. $this->assertTrue($validator->getSeparator() == ' ');
  112. } catch (Exception $e) {
  113. $this->fail("Should accept separator ' '");
  114. }
  115. try {
  116. $validator->setSeparator('');
  117. $this->assertTrue($validator->getSeparator() == '');
  118. } catch (Exception $e) {
  119. $this->fail("Should accept empty separator");
  120. }
  121. try {
  122. $validator->setSeparator('X');
  123. $this->fail("Should not accept separator 'X'");
  124. } catch (Exception $e) {
  125. // success
  126. }
  127. }
  128. /**
  129. * Ensures that __construct() works as expected
  130. *
  131. * @return void
  132. */
  133. public function testInitialization()
  134. {
  135. $options = array('type' => Zend_Validate_Isbn::AUTO,
  136. 'separator' => ' ');
  137. $validator = new Zend_Validate_Isbn($options);
  138. $this->assertTrue($validator->getType() == Zend_Validate_Isbn::AUTO);
  139. $this->assertTrue($validator->getSeparator() == ' ');
  140. $options = array('type' => Zend_Validate_Isbn::ISBN10,
  141. 'separator' => '-');
  142. $validator = new Zend_Validate_Isbn($options);
  143. $this->assertTrue($validator->getType() == Zend_Validate_Isbn::ISBN10);
  144. $this->assertTrue($validator->getSeparator() == '-');
  145. $options = array('type' => Zend_Validate_Isbn::ISBN13,
  146. 'separator' => '');
  147. $validator = new Zend_Validate_Isbn($options);
  148. $this->assertTrue($validator->getType() == Zend_Validate_Isbn::ISBN13);
  149. $this->assertTrue($validator->getSeparator() == '');
  150. }
  151. /**
  152. * Ensures that the validator follows expected behavior
  153. *
  154. * @return void
  155. */
  156. public function testTypeAuto()
  157. {
  158. $validator = new Zend_Validate_Isbn();
  159. $this->assertTrue($validator->isValid('0060929871'));
  160. $this->assertFalse($validator->isValid('0-06-092987-1'));
  161. $this->assertFalse($validator->isValid('0 06 092987 1'));
  162. $this->assertTrue($validator->isValid('9780555023402'));
  163. $this->assertFalse($validator->isValid('978-0-555023-40-2'));
  164. $this->assertFalse($validator->isValid('978 0 555023 40 2'));
  165. $validator->setSeparator('-');
  166. $this->assertFalse($validator->isValid('0060929871'));
  167. $this->assertTrue($validator->isValid('0-06-092987-1'));
  168. $this->assertFalse($validator->isValid('0 06 092987 1'));
  169. $this->assertFalse($validator->isValid('9780555023402'));
  170. $this->assertTrue($validator->isValid('978-0-555023-40-2'));
  171. $this->assertFalse($validator->isValid('978 0 555023 40 2'));
  172. $validator->setSeparator(' ');
  173. $this->assertFalse($validator->isValid('0060929871'));
  174. $this->assertFalse($validator->isValid('0-06-092987-1'));
  175. $this->assertTrue($validator->isValid('0 06 092987 1'));
  176. $this->assertFalse($validator->isValid('9780555023402'));
  177. $this->assertFalse($validator->isValid('978-0-555023-40-2'));
  178. $this->assertTrue($validator->isValid('978 0 555023 40 2'));
  179. }
  180. /**
  181. * Ensures that the validator follows expected behavior
  182. *
  183. * @return void
  184. */
  185. public function testType10()
  186. {
  187. $validator = new Zend_Validate_Isbn();
  188. $validator->setType(Zend_Validate_Isbn::ISBN10);
  189. $this->assertTrue($validator->isValid('0060929871'));
  190. $this->assertFalse($validator->isValid('9780555023402'));
  191. $validator->setSeparator('-');
  192. $this->assertTrue($validator->isValid('0-06-092987-1'));
  193. $this->assertFalse($validator->isValid('978-0-555023-40-2'));
  194. $validator->setSeparator(' ');
  195. $this->assertTrue($validator->isValid('0 06 092987 1'));
  196. $this->assertFalse($validator->isValid('978 0 555023 40 2'));
  197. }
  198. /**
  199. * Ensures that the validator follows expected behavior
  200. *
  201. * @return void
  202. */
  203. public function testType13()
  204. {
  205. $validator = new Zend_Validate_Isbn();
  206. $validator->setType(Zend_Validate_Isbn::ISBN13);
  207. $this->assertFalse($validator->isValid('0060929871'));
  208. $this->assertTrue($validator->isValid('9780555023402'));
  209. $validator->setSeparator('-');
  210. $this->assertFalse($validator->isValid('0-06-092987-1'));
  211. $this->assertTrue($validator->isValid('978-0-555023-40-2'));
  212. $validator->setSeparator(' ');
  213. $this->assertFalse($validator->isValid('0 06 092987 1'));
  214. $this->assertTrue($validator->isValid('978 0 555023 40 2'));
  215. }
  216. /**
  217. * @group ZF-9605
  218. */
  219. public function testInvalidTypeGiven()
  220. {
  221. $validator = new Zend_Validate_Isbn();
  222. $validator->setType(Zend_Validate_Isbn::ISBN13);
  223. $this->assertFalse($validator->isValid((float) 1.2345));
  224. $this->assertFalse($validator->isValid((object) 'Test'));
  225. }
  226. }