Update v1.0.6
This commit is contained in:
		| @@ -1,309 +0,0 @@ | ||||
| <?php | ||||
|  | ||||
| namespace Doctrine\Tests\Common\Inflector; | ||||
|  | ||||
| use Doctrine\Tests\DoctrineTestCase; | ||||
| use Doctrine\Common\Inflector\Inflector; | ||||
|  | ||||
| class InflectorTest extends DoctrineTestCase | ||||
| { | ||||
|     /** | ||||
|      * Singular & Plural test data. Returns an array of sample words. | ||||
|      * | ||||
|      * @return array | ||||
|      */  | ||||
|     public function dataSampleWords()  | ||||
|     { | ||||
|         Inflector::reset(); | ||||
|          | ||||
|         // In the format array('singular', 'plural') | ||||
|         return array( | ||||
|             array('', ''), | ||||
|             array('Alias', 'Aliases'), | ||||
|             array('alumnus', 'alumni'), | ||||
|             array('analysis', 'analyses'), | ||||
|             array('aquarium', 'aquaria'), | ||||
|             array('arch', 'arches'), | ||||
|             array('atlas', 'atlases'), | ||||
|             array('axe', 'axes'), | ||||
|             array('baby', 'babies'), | ||||
|             array('bacillus', 'bacilli'), | ||||
|             array('bacterium', 'bacteria'), | ||||
|             array('bureau', 'bureaus'), | ||||
|             array('bus', 'buses'), | ||||
|             array('Bus', 'Buses'), | ||||
|             array('cactus', 'cacti'), | ||||
|             array('cafe', 'cafes'), | ||||
|             array('calf', 'calves'), | ||||
|             array('categoria', 'categorias'), | ||||
|             array('chateau', 'chateaux'), | ||||
|             array('cherry', 'cherries'), | ||||
|             array('child', 'children'), | ||||
|             array('church', 'churches'), | ||||
|             array('circus', 'circuses'), | ||||
|             array('city', 'cities'), | ||||
|             array('cod', 'cod'), | ||||
|             array('cookie', 'cookies'), | ||||
|             array('copy', 'copies'), | ||||
|             array('crisis', 'crises'), | ||||
|             array('criterion', 'criteria'), | ||||
|             array('curriculum', 'curricula'), | ||||
|             array('curve', 'curves'), | ||||
|             array('deer', 'deer'), | ||||
|             array('demo', 'demos'), | ||||
|             array('dictionary', 'dictionaries'), | ||||
|             array('domino', 'dominoes'), | ||||
|             array('dwarf', 'dwarves'), | ||||
|             array('echo', 'echoes'), | ||||
|             array('elf', 'elves'), | ||||
|             array('emphasis', 'emphases'), | ||||
|             array('family', 'families'), | ||||
|             array('fax', 'faxes'), | ||||
|             array('fish', 'fish'), | ||||
|             array('flush', 'flushes'), | ||||
|             array('fly', 'flies'), | ||||
|             array('focus', 'foci'), | ||||
|             array('foe', 'foes'), | ||||
|             array('food_menu', 'food_menus'), | ||||
|             array('FoodMenu', 'FoodMenus'), | ||||
|             array('foot', 'feet'), | ||||
|             array('fungus', 'fungi'), | ||||
|             array('glove', 'gloves'), | ||||
|             array('half', 'halves'), | ||||
|             array('hero', 'heroes'), | ||||
|             array('hippopotamus', 'hippopotami'), | ||||
|             array('hoax', 'hoaxes'), | ||||
|             array('house', 'houses'), | ||||
|             array('human', 'humans'), | ||||
|             array('identity', 'identities'), | ||||
|             array('index', 'indices'), | ||||
|             array('iris', 'irises'), | ||||
|             array('kiss', 'kisses'), | ||||
|             array('knife', 'knives'), | ||||
|             array('leaf', 'leaves'), | ||||
|             array('life', 'lives'), | ||||
|             array('loaf', 'loaves'), | ||||
|             array('man', 'men'), | ||||
|             array('matrix', 'matrices'), | ||||
|             array('matrix_row', 'matrix_rows'), | ||||
|             array('medium', 'media'), | ||||
|             array('memorandum', 'memoranda'), | ||||
|             array('menu', 'menus'), | ||||
|             array('Menu', 'Menus'), | ||||
|             array('mess', 'messes'), | ||||
|             array('moose', 'moose'), | ||||
|             array('motto', 'mottoes'), | ||||
|             array('mouse', 'mice'), | ||||
|             array('neurosis', 'neuroses'), | ||||
|             array('news', 'news'), | ||||
|             array('NodeMedia', 'NodeMedia'), | ||||
|             array('nucleus', 'nuclei'), | ||||
|             array('oasis', 'oases'), | ||||
|             array('octopus', 'octopuses'), | ||||
|             array('pass', 'passes'), | ||||
|             array('person', 'people'), | ||||
|             array('plateau', 'plateaux'), | ||||
|             array('potato', 'potatoes'), | ||||
|             array('powerhouse', 'powerhouses'), | ||||
|             array('quiz', 'quizzes'), | ||||
|             array('radius', 'radii'), | ||||
|             array('reflex', 'reflexes'), | ||||
|             array('roof', 'roofs'), | ||||
|             array('runner-up', 'runners-up'), | ||||
|             array('scarf', 'scarves'), | ||||
|             array('scratch', 'scratches'), | ||||
|             array('series', 'series'), | ||||
|             array('sheep', 'sheep'), | ||||
|             array('shelf', 'shelves'), | ||||
|             array('shoe', 'shoes'), | ||||
|             array('son-in-law', 'sons-in-law'), | ||||
|             array('species', 'species'), | ||||
|             array('splash', 'splashes'), | ||||
|             array('spy', 'spies'), | ||||
|             array('stimulus', 'stimuli'), | ||||
|             array('stitch', 'stitches'), | ||||
|             array('story', 'stories'), | ||||
|             array('syllabus', 'syllabi'), | ||||
|             array('tax', 'taxes'), | ||||
|             array('terminus', 'termini'), | ||||
|             array('thesis', 'theses'), | ||||
|             array('thief', 'thieves'), | ||||
|             array('tomato', 'tomatoes'), | ||||
|             array('tooth', 'teeth'), | ||||
|             array('tornado', 'tornadoes'), | ||||
|             array('try', 'tries'), | ||||
|             array('vertex', 'vertices'), | ||||
|             array('virus', 'viri'), | ||||
|             array('volcano', 'volcanoes'), | ||||
|             array('wash', 'washes'), | ||||
|             array('watch', 'watches'), | ||||
|             array('wave', 'waves'), | ||||
|             array('wharf', 'wharves'), | ||||
|             array('wife', 'wives'), | ||||
|             array('woman', 'women'), | ||||
|         ); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * testInflectingSingulars method | ||||
|      * | ||||
|      * @dataProvider dataSampleWords | ||||
|      * @return void | ||||
|      */ | ||||
|     public function testInflectingSingulars($singular, $plural)  | ||||
|     { | ||||
|         $this->assertEquals( | ||||
|             $singular,  | ||||
|             Inflector::singularize($plural),  | ||||
|             "'$plural' should be singularized to '$singular'" | ||||
|         ); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * testInflectingPlurals method | ||||
|      * | ||||
|      * @dataProvider dataSampleWords | ||||
|      * @return void | ||||
|      */ | ||||
|     public function testInflectingPlurals($singular, $plural)  | ||||
|     { | ||||
|         $this->assertEquals( | ||||
|             $plural,  | ||||
|             Inflector::pluralize($singular),  | ||||
|             "'$singular' should be pluralized to '$plural'" | ||||
|         ); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * testCustomPluralRule method | ||||
|      * | ||||
|      * @return void | ||||
|      */ | ||||
|     public function testCustomPluralRule()  | ||||
|     { | ||||
|         Inflector::reset(); | ||||
|         Inflector::rules('plural', array('/^(custom)$/i' => '\1izables')); | ||||
|          | ||||
|         $this->assertEquals(Inflector::pluralize('custom'), 'customizables'); | ||||
|  | ||||
|         Inflector::rules('plural', array('uninflected' => array('uninflectable'))); | ||||
|          | ||||
|         $this->assertEquals(Inflector::pluralize('uninflectable'), 'uninflectable'); | ||||
|  | ||||
|         Inflector::rules('plural', array( | ||||
|             'rules' => array('/^(alert)$/i' => '\1ables'), | ||||
|             'uninflected' => array('noflect', 'abtuse'), | ||||
|             'irregular' => array('amaze' => 'amazable', 'phone' => 'phonezes') | ||||
|         )); | ||||
|          | ||||
|         $this->assertEquals(Inflector::pluralize('noflect'), 'noflect'); | ||||
|         $this->assertEquals(Inflector::pluralize('abtuse'), 'abtuse'); | ||||
|         $this->assertEquals(Inflector::pluralize('alert'), 'alertables'); | ||||
|         $this->assertEquals(Inflector::pluralize('amaze'), 'amazable'); | ||||
|         $this->assertEquals(Inflector::pluralize('phone'), 'phonezes'); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * testCustomSingularRule method | ||||
|      * | ||||
|      * @return void | ||||
|      */ | ||||
|     public function testCustomSingularRule()  | ||||
|     { | ||||
|         Inflector::reset(); | ||||
|         Inflector::rules('singular', array('/(eple)r$/i' => '\1', '/(jente)r$/i' => '\1')); | ||||
|  | ||||
|         $this->assertEquals(Inflector::singularize('epler'), 'eple'); | ||||
|         $this->assertEquals(Inflector::singularize('jenter'), 'jente'); | ||||
|  | ||||
|         Inflector::rules('singular', array( | ||||
|             'rules' => array('/^(bil)er$/i' => '\1', '/^(inflec|contribu)tors$/i' => '\1ta'), | ||||
|             'uninflected' => array('singulars'), | ||||
|             'irregular' => array('spins' => 'spinor') | ||||
|         )); | ||||
|  | ||||
|         $this->assertEquals(Inflector::singularize('inflectors'), 'inflecta'); | ||||
|         $this->assertEquals(Inflector::singularize('contributors'), 'contributa'); | ||||
|         $this->assertEquals(Inflector::singularize('spins'), 'spinor'); | ||||
|         $this->assertEquals(Inflector::singularize('singulars'), 'singulars'); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * test that setting new rules clears the inflector caches. | ||||
|      * | ||||
|      * @return void | ||||
|      */ | ||||
|     public function testRulesClearsCaches()  | ||||
|     { | ||||
|         Inflector::reset(); | ||||
|          | ||||
|         $this->assertEquals(Inflector::singularize('Bananas'), 'Banana'); | ||||
|         $this->assertEquals(Inflector::pluralize('Banana'), 'Bananas'); | ||||
|  | ||||
|         Inflector::rules('singular', array( | ||||
|             'rules' => array('/(.*)nas$/i' => '\1zzz') | ||||
|         )); | ||||
|          | ||||
|         $this->assertEquals('Banazzz', Inflector::singularize('Bananas'), 'Was inflected with old rules.'); | ||||
|  | ||||
|         Inflector::rules('plural', array( | ||||
|             'rules' => array('/(.*)na$/i' => '\1zzz'), | ||||
|             'irregular' => array('corpus' => 'corpora') | ||||
|         )); | ||||
|          | ||||
|         $this->assertEquals(Inflector::pluralize('Banana'), 'Banazzz', 'Was inflected with old rules.'); | ||||
|         $this->assertEquals(Inflector::pluralize('corpus'), 'corpora', 'Was inflected with old irregular form.'); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Test resetting inflection rules. | ||||
|      * | ||||
|      * @return void | ||||
|      */ | ||||
|     public function testCustomRuleWithReset()  | ||||
|     { | ||||
|         Inflector::reset(); | ||||
|          | ||||
|         $uninflected = array('atlas', 'lapis', 'onibus', 'pires', 'virus', '.*x'); | ||||
|         $pluralIrregular = array('as' => 'ases'); | ||||
|  | ||||
|         Inflector::rules('singular', array( | ||||
|             'rules' => array('/^(.*)(a|e|o|u)is$/i' => '\1\2l'), | ||||
|             'uninflected' => $uninflected, | ||||
|         ), true); | ||||
|  | ||||
|         Inflector::rules('plural', array( | ||||
|             'rules' => array( | ||||
|                 '/^(.*)(a|e|o|u)l$/i' => '\1\2is', | ||||
|             ), | ||||
|             'uninflected' => $uninflected, | ||||
|             'irregular' => $pluralIrregular | ||||
|         ), true); | ||||
|  | ||||
|         $this->assertEquals(Inflector::pluralize('Alcool'), 'Alcoois'); | ||||
|         $this->assertEquals(Inflector::pluralize('Atlas'), 'Atlas'); | ||||
|         $this->assertEquals(Inflector::singularize('Alcoois'), 'Alcool'); | ||||
|         $this->assertEquals(Inflector::singularize('Atlas'), 'Atlas'); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Test basic ucwords functionality. | ||||
|      * | ||||
|      * @return void | ||||
|      */ | ||||
|     public function testUcwords() | ||||
|     { | ||||
|         $this->assertSame('Top-O-The-Morning To All_of_you!', Inflector::ucwords( 'top-o-the-morning to all_of_you!')); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Test ucwords functionality with custom delimeters. | ||||
|      * | ||||
|      * @return void | ||||
|      */ | ||||
|     public function testUcwordsWithCustomDelimeters() | ||||
|     { | ||||
|         $this->assertSame('Top-O-The-Morning To All_Of_You!', Inflector::ucwords( 'top-o-the-morning to all_of_you!', '-_ ')); | ||||
|     } | ||||
| } | ||||
|  | ||||
| @@ -1,10 +0,0 @@ | ||||
| <?php | ||||
|  | ||||
| namespace Doctrine\Tests; | ||||
|  | ||||
| /** | ||||
|  * Base testcase class for all Doctrine testcases. | ||||
|  */ | ||||
| abstract class DoctrineTestCase extends \PHPUnit_Framework_TestCase | ||||
| { | ||||
| } | ||||
| @@ -1,27 +0,0 @@ | ||||
| <?php | ||||
| /* | ||||
|  * This file bootstraps the test environment. | ||||
|  */ | ||||
| namespace Doctrine\Tests; | ||||
|  | ||||
| error_reporting(E_ALL | E_STRICT); | ||||
|  | ||||
| // register silently failing autoloader | ||||
| spl_autoload_register(function($class) | ||||
| { | ||||
|     if (0 === strpos($class, 'Doctrine\Tests\\')) { | ||||
|         $path = __DIR__.'/../../'.strtr($class, '\\', '/').'.php'; | ||||
|         if (is_file($path) && is_readable($path)) { | ||||
|             require_once $path; | ||||
|  | ||||
|             return true; | ||||
|         } | ||||
|     } else if (0 === strpos($class, 'Doctrine\Common\\')) { | ||||
|         $path = __DIR__.'/../../../lib/'.($class = strtr($class, '\\', '/')).'.php'; | ||||
|         if (is_file($path) && is_readable($path)) { | ||||
|             require_once $path; | ||||
|  | ||||
|             return true; | ||||
|         } | ||||
|     } | ||||
| }); | ||||
		Reference in New Issue
	
	Block a user
	 Bhanu Slathia
					Bhanu Slathia