InflectorTest.php 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435
  1. <?php
  2. /**
  3. * InflectorTest
  4. *
  5. * InflectorTest is used to test cases on the Inflector class
  6. *
  7. * PHP 5
  8. *
  9. * CakePHP(tm) : Rapid Development Framework (http://cakephp.org)
  10. * Copyright 2005-2011, Cake Software Foundation, Inc. (http://cakefoundation.org)
  11. *
  12. * Licensed under The Open Group Test Suite License
  13. * Redistributions of files must retain the above copyright notice.
  14. *
  15. * @copyright Copyright 2005-2011, Cake Software Foundation, Inc. (http://cakefoundation.org)
  16. * @link http://book.cakephp.org/view/1196/Testing
  17. * @package Cake.Test.Case.Utility
  18. * @package Cake.Test.Case.Utility
  19. * @since CakePHP(tm) v 1.2.0.4206
  20. * @license Open Group Test Suite License (http://www.opensource.org/licenses/opengroup.php)
  21. */
  22. /**
  23. * Included libraries.
  24. *
  25. */
  26. App::uses('Inflector', 'Utility');
  27. /**
  28. * Short description for class.
  29. *
  30. * @package cake.tests
  31. * @package Cake.Test.Case.Utility
  32. */
  33. class InflectorTest extends CakeTestCase {
  34. /**
  35. * teardown
  36. *
  37. * @return void
  38. */
  39. public function tearDown() {
  40. parent::tearDown();
  41. Inflector::reset();
  42. }
  43. /**
  44. * testInflectingSingulars method
  45. *
  46. * @return void
  47. */
  48. public function testInflectingSingulars() {
  49. $this->assertEqual(Inflector::singularize('categorias'), 'categoria');
  50. $this->assertEqual(Inflector::singularize('menus'), 'menu');
  51. $this->assertEqual(Inflector::singularize('news'), 'news');
  52. $this->assertEqual(Inflector::singularize('food_menus'), 'food_menu');
  53. $this->assertEqual(Inflector::singularize('Menus'), 'Menu');
  54. $this->assertEqual(Inflector::singularize('FoodMenus'), 'FoodMenu');
  55. $this->assertEqual(Inflector::singularize('houses'), 'house');
  56. $this->assertEqual(Inflector::singularize('powerhouses'), 'powerhouse');
  57. $this->assertEqual(Inflector::singularize('quizzes'), 'quiz');
  58. $this->assertEqual(Inflector::singularize('Buses'), 'Bus');
  59. $this->assertEqual(Inflector::singularize('buses'), 'bus');
  60. $this->assertEqual(Inflector::singularize('matrix_rows'), 'matrix_row');
  61. $this->assertEqual(Inflector::singularize('matrices'), 'matrix');
  62. $this->assertEqual(Inflector::singularize('vertices'), 'vertex');
  63. $this->assertEqual(Inflector::singularize('indices'), 'index');
  64. $this->assertEqual(Inflector::singularize('Aliases'), 'Alias');
  65. $this->assertEqual(Inflector::singularize('Alias'), 'Alias');
  66. $this->assertEqual(Inflector::singularize('Media'), 'Media');
  67. $this->assertEqual(Inflector::singularize('alumni'), 'alumnus');
  68. $this->assertEqual(Inflector::singularize('bacilli'), 'bacillus');
  69. $this->assertEqual(Inflector::singularize('cacti'), 'cactus');
  70. $this->assertEqual(Inflector::singularize('foci'), 'focus');
  71. $this->assertEqual(Inflector::singularize('fungi'), 'fungus');
  72. $this->assertEqual(Inflector::singularize('nuclei'), 'nucleus');
  73. $this->assertEqual(Inflector::singularize('octopuses'), 'octopus');
  74. $this->assertEqual(Inflector::singularize('radii'), 'radius');
  75. $this->assertEqual(Inflector::singularize('stimuli'), 'stimulus');
  76. $this->assertEqual(Inflector::singularize('syllabi'), 'syllabus');
  77. $this->assertEqual(Inflector::singularize('termini'), 'terminus');
  78. $this->assertEqual(Inflector::singularize('viri'), 'virus');
  79. $this->assertEqual(Inflector::singularize('people'), 'person');
  80. $this->assertEqual(Inflector::singularize('gloves'), 'glove');
  81. $this->assertEqual(Inflector::singularize('doves'), 'dove');
  82. $this->assertEqual(Inflector::singularize('lives'), 'life');
  83. $this->assertEqual(Inflector::singularize('knives'), 'knife');
  84. $this->assertEqual(Inflector::singularize('wolves'), 'wolf');
  85. $this->assertEqual(Inflector::singularize('slaves'), 'slave');
  86. $this->assertEqual(Inflector::singularize('shelves'), 'shelf');
  87. $this->assertEqual(Inflector::singularize('taxis'), 'taxi');
  88. $this->assertEqual(Inflector::singularize('taxes'), 'tax');
  89. $this->assertEqual(Inflector::singularize('Taxes'), 'Tax');
  90. $this->assertEqual(Inflector::singularize('AwesomeTaxes'), 'AwesomeTax');
  91. $this->assertEqual(Inflector::singularize('faxes'), 'fax');
  92. $this->assertEqual(Inflector::singularize('waxes'), 'wax');
  93. $this->assertEqual(Inflector::singularize('niches'), 'niche');
  94. $this->assertEqual(Inflector::singularize('waves'), 'wave');
  95. $this->assertEqual(Inflector::singularize('bureaus'), 'bureau');
  96. $this->assertEqual(Inflector::singularize('genetic_analyses'), 'genetic_analysis');
  97. $this->assertEqual(Inflector::singularize('doctor_diagnoses'), 'doctor_diagnosis');
  98. $this->assertEqual(Inflector::singularize('parantheses'), 'paranthesis');
  99. $this->assertEqual(Inflector::singularize('Causes'), 'Cause');
  100. $this->assertEqual(Inflector::singularize('colossuses'), 'colossus');
  101. $this->assertEqual(Inflector::singularize('diagnoses'), 'diagnosis');
  102. $this->assertEqual(Inflector::singularize('bases'), 'basis');
  103. $this->assertEqual(Inflector::singularize('analyses'), 'analysis');
  104. $this->assertEqual(Inflector::singularize('curves'), 'curve');
  105. $this->assertEqual(Inflector::singularize('cafes'), 'cafe');
  106. $this->assertEqual(Inflector::singularize('roofs'), 'roof');
  107. $this->assertEqual(Inflector::singularize(''), '');
  108. }
  109. /**
  110. * testInflectingPlurals method
  111. *
  112. * @return void
  113. */
  114. public function testInflectingPlurals() {
  115. $this->assertEqual(Inflector::pluralize('categoria'), 'categorias');
  116. $this->assertEqual(Inflector::pluralize('house'), 'houses');
  117. $this->assertEqual(Inflector::pluralize('powerhouse'), 'powerhouses');
  118. $this->assertEqual(Inflector::pluralize('Bus'), 'Buses');
  119. $this->assertEqual(Inflector::pluralize('bus'), 'buses');
  120. $this->assertEqual(Inflector::pluralize('menu'), 'menus');
  121. $this->assertEqual(Inflector::pluralize('news'), 'news');
  122. $this->assertEqual(Inflector::pluralize('food_menu'), 'food_menus');
  123. $this->assertEqual(Inflector::pluralize('Menu'), 'Menus');
  124. $this->assertEqual(Inflector::pluralize('FoodMenu'), 'FoodMenus');
  125. $this->assertEqual(Inflector::pluralize('quiz'), 'quizzes');
  126. $this->assertEqual(Inflector::pluralize('matrix_row'), 'matrix_rows');
  127. $this->assertEqual(Inflector::pluralize('matrix'), 'matrices');
  128. $this->assertEqual(Inflector::pluralize('vertex'), 'vertices');
  129. $this->assertEqual(Inflector::pluralize('index'), 'indices');
  130. $this->assertEqual(Inflector::pluralize('Alias'), 'Aliases');
  131. $this->assertEqual(Inflector::pluralize('Aliases'), 'Aliases');
  132. $this->assertEqual(Inflector::pluralize('Media'), 'Media');
  133. $this->assertEqual(Inflector::pluralize('alumnus'), 'alumni');
  134. $this->assertEqual(Inflector::pluralize('bacillus'), 'bacilli');
  135. $this->assertEqual(Inflector::pluralize('cactus'), 'cacti');
  136. $this->assertEqual(Inflector::pluralize('focus'), 'foci');
  137. $this->assertEqual(Inflector::pluralize('fungus'), 'fungi');
  138. $this->assertEqual(Inflector::pluralize('nucleus'), 'nuclei');
  139. $this->assertEqual(Inflector::pluralize('octopus'), 'octopuses');
  140. $this->assertEqual(Inflector::pluralize('radius'), 'radii');
  141. $this->assertEqual(Inflector::pluralize('stimulus'), 'stimuli');
  142. $this->assertEqual(Inflector::pluralize('syllabus'), 'syllabi');
  143. $this->assertEqual(Inflector::pluralize('terminus'), 'termini');
  144. $this->assertEqual(Inflector::pluralize('virus'), 'viri');
  145. $this->assertEqual(Inflector::pluralize('person'), 'people');
  146. $this->assertEqual(Inflector::pluralize('people'), 'people');
  147. $this->assertEqual(Inflector::pluralize('glove'), 'gloves');
  148. $this->assertEqual(Inflector::pluralize('crisis'), 'crises');
  149. $this->assertEqual(Inflector::pluralize('tax'), 'taxes');
  150. $this->assertEqual(Inflector::pluralize('wave'), 'waves');
  151. $this->assertEqual(Inflector::pluralize('bureau'), 'bureaus');
  152. $this->assertEqual(Inflector::pluralize('cafe'), 'cafes');
  153. $this->assertEqual(Inflector::pluralize('roof'), 'roofs');
  154. $this->assertEqual(Inflector::pluralize(''), '');
  155. }
  156. /**
  157. * testInflectorSlug method
  158. *
  159. * @return void
  160. */
  161. public function testInflectorSlug() {
  162. $result = Inflector::slug('Foo Bar: Not just for breakfast any-more');
  163. $expected = 'Foo_Bar_Not_just_for_breakfast_any_more';
  164. $this->assertEqual($expected, $result);
  165. $result = Inflector::slug('this/is/a/path');
  166. $expected = 'this_is_a_path';
  167. $this->assertEqual($expected, $result);
  168. $result = Inflector::slug('Foo Bar: Not just for breakfast any-more', "-");
  169. $expected = 'Foo-Bar-Not-just-for-breakfast-any-more';
  170. $this->assertEqual($expected, $result);
  171. $result = Inflector::slug('Foo Bar: Not just for breakfast any-more', "+");
  172. $expected = 'Foo+Bar+Not+just+for+breakfast+any+more';
  173. $this->assertEqual($expected, $result);
  174. $result = Inflector::slug('Äpfel Über Öl grün ärgert groß öko', '-');
  175. $expected = 'Aepfel-Ueber-Oel-gruen-aergert-gross-oeko';
  176. $this->assertEqual($expected, $result);
  177. $result = Inflector::slug('The truth - and- more- news', '-');
  178. $expected = 'The-truth-and-more-news';
  179. $this->assertEqual($expected, $result);
  180. $result = Inflector::slug('The truth: and more news', '-');
  181. $expected = 'The-truth-and-more-news';
  182. $this->assertEqual($expected, $result);
  183. $result = Inflector::slug('La langue française est un attribut de souveraineté en France', '-');
  184. $expected = 'La-langue-francaise-est-un-attribut-de-souverainete-en-France';
  185. $this->assertEqual($expected, $result);
  186. $result = Inflector::slug('!@$#exciting stuff! - what !@-# was that?', '-');
  187. $expected = 'exciting-stuff-what-was-that';
  188. $this->assertEqual($expected, $result);
  189. $result = Inflector::slug('20% of profits went to me!', '-');
  190. $expected = '20-of-profits-went-to-me';
  191. $this->assertEqual($expected, $result);
  192. $result = Inflector::slug('#this melts your face1#2#3', '-');
  193. $expected = 'this-melts-your-face1-2-3';
  194. $this->assertEqual($expected, $result);
  195. $result = Inflector::slug('controller/action/りんご/1');
  196. $expected = 'controller_action_りんご_1';
  197. $this->assertEqual($expected, $result);
  198. $result = Inflector::slug('の話が出たので大丈夫かなあと');
  199. $expected = 'の話が出たので大丈夫かなあと';
  200. $this->assertEqual($expected, $result);
  201. $result = Inflector::slug('posts/view/한국어/page:1/sort:asc');
  202. $expected = 'posts_view_한국어_page_1_sort_asc';
  203. $this->assertEqual($expected, $result);
  204. }
  205. /**
  206. * testInflectorSlugWithMap method
  207. *
  208. * @return void
  209. */
  210. public function testInflectorSlugWithMap() {
  211. Inflector::rules('transliteration', array('/r/' => '1'));
  212. $result = Inflector::slug('replace every r');
  213. $expected = '1eplace_eve1y_1';
  214. $this->assertEqual($expected, $result);
  215. $result = Inflector::slug('replace every r', '_');
  216. $expected = '1eplace_eve1y_1';
  217. $this->assertEqual($expected, $result);
  218. }
  219. /**
  220. * testInflectorSlugWithMapOverridingDefault method
  221. *
  222. * @return void
  223. */
  224. public function testInflectorSlugWithMapOverridingDefault() {
  225. Inflector::rules('transliteration', array('/å/' => 'aa', '/ø/' => 'oe'));
  226. $result = Inflector::slug('Testing æ ø å', '-');
  227. $expected = 'Testing-ae-oe-aa';
  228. $this->assertEqual($expected, $result);
  229. }
  230. /**
  231. * testInflectorUnderscore method
  232. *
  233. * @return void
  234. */
  235. public function testInflectorUnderscore() {
  236. $this->assertIdentical(Inflector::underscore('TestThing'), 'test_thing');
  237. $this->assertIdentical(Inflector::underscore('testThing'), 'test_thing');
  238. $this->assertIdentical(Inflector::underscore('TestThingExtra'), 'test_thing_extra');
  239. $this->assertIdentical(Inflector::underscore('testThingExtra'), 'test_thing_extra');
  240. // Identical checks test the cache code path.
  241. $this->assertIdentical(Inflector::underscore('TestThing'), 'test_thing');
  242. $this->assertIdentical(Inflector::underscore('testThing'), 'test_thing');
  243. $this->assertIdentical(Inflector::underscore('TestThingExtra'), 'test_thing_extra');
  244. $this->assertIdentical(Inflector::underscore('testThingExtra'), 'test_thing_extra');
  245. // Test stupid values
  246. $this->assertIdentical(Inflector::underscore(''), '');
  247. $this->assertIdentical(Inflector::underscore(0), '0');
  248. $this->assertIdentical(Inflector::underscore(false), '');
  249. }
  250. /**
  251. * testVariableNaming method
  252. *
  253. * @return void
  254. */
  255. public function testVariableNaming() {
  256. $this->assertEqual(Inflector::variable('test_field'), 'testField');
  257. $this->assertEqual(Inflector::variable('test_fieLd'), 'testFieLd');
  258. $this->assertEqual(Inflector::variable('test field'), 'testField');
  259. $this->assertEqual(Inflector::variable('Test_field'), 'testField');
  260. }
  261. /**
  262. * testClassNaming method
  263. *
  264. * @return void
  265. */
  266. public function testClassNaming() {
  267. $this->assertEqual(Inflector::classify('artists_genres'), 'ArtistsGenre');
  268. $this->assertEqual(Inflector::classify('file_systems'), 'FileSystem');
  269. $this->assertEqual(Inflector::classify('news'), 'News');
  270. $this->assertEqual(Inflector::classify('bureaus'), 'Bureau');
  271. }
  272. /**
  273. * testTableNaming method
  274. *
  275. * @return void
  276. */
  277. public function testTableNaming() {
  278. $this->assertEqual(Inflector::tableize('ArtistsGenre'), 'artists_genres');
  279. $this->assertEqual(Inflector::tableize('FileSystem'), 'file_systems');
  280. $this->assertEqual(Inflector::tableize('News'), 'news');
  281. $this->assertEqual(Inflector::tableize('Bureau'), 'bureaus');
  282. }
  283. /**
  284. * testHumanization method
  285. *
  286. * @return void
  287. */
  288. public function testHumanization() {
  289. $this->assertEqual(Inflector::humanize('posts'), 'Posts');
  290. $this->assertEqual(Inflector::humanize('posts_tags'), 'Posts Tags');
  291. $this->assertEqual(Inflector::humanize('file_systems'), 'File Systems');
  292. }
  293. /**
  294. * testCustomPluralRule method
  295. *
  296. * @return void
  297. */
  298. public function testCustomPluralRule() {
  299. Inflector::rules('plural', array('/^(custom)$/i' => '\1izables'));
  300. $this->assertEqual(Inflector::pluralize('custom'), 'customizables');
  301. Inflector::rules('plural', array('uninflected' => array('uninflectable')));
  302. $this->assertEqual(Inflector::pluralize('uninflectable'), 'uninflectable');
  303. Inflector::rules('plural', array(
  304. 'rules' => array('/^(alert)$/i' => '\1ables'),
  305. 'uninflected' => array('noflect', 'abtuse'),
  306. 'irregular' => array('amaze' => 'amazable', 'phone' => 'phonezes')
  307. ));
  308. $this->assertEqual(Inflector::pluralize('noflect'), 'noflect');
  309. $this->assertEqual(Inflector::pluralize('abtuse'), 'abtuse');
  310. $this->assertEqual(Inflector::pluralize('alert'), 'alertables');
  311. $this->assertEqual(Inflector::pluralize('amaze'), 'amazable');
  312. $this->assertEqual(Inflector::pluralize('phone'), 'phonezes');
  313. }
  314. /**
  315. * testCustomSingularRule method
  316. *
  317. * @return void
  318. */
  319. public function testCustomSingularRule() {
  320. Inflector::rules('singular', array('/(eple)r$/i' => '\1', '/(jente)r$/i' => '\1'));
  321. $this->assertEqual(Inflector::singularize('epler'), 'eple');
  322. $this->assertEqual(Inflector::singularize('jenter'), 'jente');
  323. Inflector::rules('singular', array(
  324. 'rules' => array('/^(bil)er$/i' => '\1', '/^(inflec|contribu)tors$/i' => '\1ta'),
  325. 'uninflected' => array('singulars'),
  326. 'irregular' => array('spins' => 'spinor')
  327. ));
  328. $this->assertEqual(Inflector::singularize('inflectors'), 'inflecta');
  329. $this->assertEqual(Inflector::singularize('contributors'), 'contributa');
  330. $this->assertEqual(Inflector::singularize('spins'), 'spinor');
  331. $this->assertEqual(Inflector::singularize('singulars'), 'singulars');
  332. }
  333. /**
  334. * testCustomTransliterationRule method
  335. *
  336. * @return void
  337. */
  338. public function testCustomTransliterationRule() {
  339. $this->assertEqual(Inflector::slug('Testing æ ø å'), 'Testing_ae_o_a');
  340. Inflector::rules('transliteration', array('/å/' => 'aa', '/ø/' => 'oe'));
  341. $this->assertEqual(Inflector::slug('Testing æ ø å'), 'Testing_ae_oe_aa');
  342. Inflector::rules('transliteration', array('/ä|æ/' => 'ae', '/å/' => 'aa'), true);
  343. $this->assertEqual(Inflector::slug('Testing æ ø å'), 'Testing_ae_ø_aa');
  344. }
  345. /**
  346. * test that setting new rules clears the inflector caches.
  347. *
  348. * @return void
  349. */
  350. public function testRulesClearsCaches() {
  351. $this->assertEqual(Inflector::singularize('Bananas'), 'Banana');
  352. $this->assertEqual(Inflector::tableize('Banana'), 'bananas');
  353. $this->assertEqual(Inflector::pluralize('Banana'), 'Bananas');
  354. Inflector::rules('singular', array(
  355. 'rules' => array('/(.*)nas$/i' => '\1zzz')
  356. ));
  357. $this->assertEquals('Banazzz', Inflector::singularize('Bananas'), 'Was inflected with old rules.');
  358. Inflector::rules('plural', array(
  359. 'rules' => array('/(.*)na$/i' => '\1zzz')
  360. ));
  361. $this->assertEqual('Banazzz', Inflector::pluralize('Banana'), 'Was inflected with old rules.');
  362. }
  363. /**
  364. * Test resetting inflection rules.
  365. *
  366. * @return void
  367. */
  368. public function testCustomRuleWithReset() {
  369. $uninflected = array('atlas', 'lapis', 'onibus', 'pires', 'virus', '.*x');
  370. $pluralIrregular = array('as' => 'ases');
  371. Inflector::rules('singular', array(
  372. 'rules' => array('/^(.*)(a|e|o|u)is$/i' => '\1\2l'),
  373. 'uninflected' => $uninflected,
  374. ), true);
  375. Inflector::rules('plural', array(
  376. 'rules' => array(
  377. '/^(.*)(a|e|o|u)l$/i' => '\1\2is',
  378. ),
  379. 'uninflected' => $uninflected,
  380. 'irregular' => $pluralIrregular
  381. ), true);
  382. $this->assertEqual(Inflector::pluralize('Alcool'), 'Alcoois');
  383. $this->assertEqual(Inflector::pluralize('Atlas'), 'Atlas');
  384. $this->assertEqual(Inflector::singularize('Alcoois'), 'Alcool');
  385. $this->assertEqual(Inflector::singularize('Atlas'), 'Atlas');
  386. }
  387. }