radarrplexorganizrnginxsonarrdashboardhtpcserverhomepagesabnzbdheimdallembycouchpotatonzbgetbookmarkapplication-dashboardmuximuxlandingpagestartpagelanding
		
		
		
		
			You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							555 lines
						
					
					
						
							19 KiB
						
					
					
				
			
		
		
		
			
			
			
				
					
				
				
					
				
			
		
		
	
	
							555 lines
						
					
					
						
							19 KiB
						
					
					
				| <?php | |
| 
 | |
| namespace Faker\Test\Provider; | |
| 
 | |
| use Faker\Provider\Base as BaseProvider; | |
| 
 | |
| class BaseTest extends \PHPUnit_Framework_TestCase | |
| { | |
|     public function testRandomDigitReturnsInteger() | |
|     { | |
|         $this->assertTrue(is_integer(BaseProvider::randomDigit())); | |
|     } | |
| 
 | |
|     public function testRandomDigitReturnsDigit() | |
|     { | |
|         $this->assertTrue(BaseProvider::randomDigit() >= 0); | |
|         $this->assertTrue(BaseProvider::randomDigit() < 10); | |
|     } | |
| 
 | |
|     public function testRandomDigitNotNullReturnsNotNullDigit() | |
|     { | |
|         $this->assertTrue(BaseProvider::randomDigitNotNull() > 0); | |
|         $this->assertTrue(BaseProvider::randomDigitNotNull() < 10); | |
|     } | |
| 
 | |
| 
 | |
|     public function testRandomDigitNotReturnsValidDigit() | |
|     { | |
|         for ($i = 0; $i <= 9; $i++) { | |
|             $this->assertTrue(BaseProvider::randomDigitNot($i) >= 0); | |
|             $this->assertTrue(BaseProvider::randomDigitNot($i) < 10); | |
|             $this->assertTrue(BaseProvider::randomDigitNot($i) !== $i); | |
|         } | |
|     } | |
| 
 | |
|     /** | |
|      * @expectedException \InvalidArgumentException | |
|      */ | |
|     public function testRandomNumberThrowsExceptionWhenCalledWithAMax() | |
|     { | |
|         BaseProvider::randomNumber(5, 200); | |
|     } | |
| 
 | |
|     /** | |
|      * @expectedException \InvalidArgumentException | |
|      */ | |
|     public function testRandomNumberThrowsExceptionWhenCalledWithATooHighNumberOfDigits() | |
|     { | |
|         BaseProvider::randomNumber(10); | |
|     } | |
| 
 | |
|     public function testRandomNumberReturnsInteger() | |
|     { | |
|         $this->assertTrue(is_integer(BaseProvider::randomNumber())); | |
|         $this->assertTrue(is_integer(BaseProvider::randomNumber(5, false))); | |
|     } | |
| 
 | |
|     public function testRandomNumberReturnsDigit() | |
|     { | |
|         $this->assertTrue(BaseProvider::randomNumber(3) >= 0); | |
|         $this->assertTrue(BaseProvider::randomNumber(3) < 1000); | |
|     } | |
| 
 | |
|     public function testRandomNumberAcceptsStrictParamToEnforceNumberSize() | |
|     { | |
|         $this->assertEquals(5, strlen((string) BaseProvider::randomNumber(5, true))); | |
|     } | |
| 
 | |
|     public function testNumberBetween() | |
|     { | |
|         $min = 5; | |
|         $max = 6; | |
| 
 | |
|         $this->assertGreaterThanOrEqual($min, BaseProvider::numberBetween($min, $max)); | |
|         $this->assertGreaterThanOrEqual(BaseProvider::numberBetween($min, $max), $max); | |
|     } | |
| 
 | |
|     public function testNumberBetweenAcceptsZeroAsMax() | |
|     { | |
|         $this->assertEquals(0, BaseProvider::numberBetween(0, 0)); | |
|     } | |
| 
 | |
|     public function testRandomFloat() | |
|     { | |
|         $min = 4; | |
|         $max = 10; | |
|         $nbMaxDecimals = 8; | |
| 
 | |
|         $result = BaseProvider::randomFloat($nbMaxDecimals, $min, $max); | |
| 
 | |
|         $parts = explode('.', $result); | |
| 
 | |
|         $this->assertInternalType('float', $result); | |
|         $this->assertGreaterThanOrEqual($min, $result); | |
|         $this->assertLessThanOrEqual($max, $result); | |
|         $this->assertLessThanOrEqual($nbMaxDecimals, strlen($parts[1])); | |
|     } | |
| 
 | |
|     public function testRandomLetterReturnsString() | |
|     { | |
|         $this->assertTrue(is_string(BaseProvider::randomLetter())); | |
|     } | |
| 
 | |
|     public function testRandomLetterReturnsSingleLetter() | |
|     { | |
|         $this->assertEquals(1, strlen(BaseProvider::randomLetter())); | |
|     } | |
| 
 | |
|     public function testRandomLetterReturnsLowercaseLetter() | |
|     { | |
|         $lowercaseLetters = 'abcdefghijklmnopqrstuvwxyz'; | |
|         $this->assertTrue(strpos($lowercaseLetters, BaseProvider::randomLetter()) !== false); | |
|     } | |
| 
 | |
|     public function testRandomAsciiReturnsString() | |
|     { | |
|         $this->assertTrue(is_string(BaseProvider::randomAscii())); | |
|     } | |
| 
 | |
|     public function testRandomAsciiReturnsSingleCharacter() | |
|     { | |
|         $this->assertEquals(1, strlen(BaseProvider::randomAscii())); | |
|     } | |
| 
 | |
|     public function testRandomAsciiReturnsAsciiCharacter() | |
|     { | |
|         $lowercaseLetters = '!"#$%&\'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~'; | |
|         $this->assertTrue(strpos($lowercaseLetters, BaseProvider::randomAscii()) !== false); | |
|     } | |
| 
 | |
|     public function testRandomElementReturnsNullWhenArrayEmpty() | |
|     { | |
|         $this->assertNull(BaseProvider::randomElement(array())); | |
|     } | |
| 
 | |
|     public function testRandomElementReturnsElementFromArray() | |
|     { | |
|         $elements = array('23', 'e', 32, '#'); | |
|         $this->assertContains(BaseProvider::randomElement($elements), $elements); | |
|     } | |
| 
 | |
|     public function testRandomElementReturnsElementFromAssociativeArray() | |
|     { | |
|         $elements = array('tata' => '23', 'toto' => 'e', 'tutu' => 32, 'titi' => '#'); | |
|         $this->assertContains(BaseProvider::randomElement($elements), $elements); | |
|     } | |
| 
 | |
|     public function testShuffleReturnsStringWhenPassedAStringArgument() | |
|     { | |
|         $this->assertInternalType('string', BaseProvider::shuffle('foo')); | |
|     } | |
| 
 | |
|     public function testShuffleReturnsArrayWhenPassedAnArrayArgument() | |
|     { | |
|         $this->assertInternalType('array', BaseProvider::shuffle(array(1, 2, 3))); | |
|     } | |
| 
 | |
|     /** | |
|      * @expectedException \InvalidArgumentException | |
|      */ | |
|     public function testShuffleThrowsExceptionWhenPassedAnInvalidArgument() | |
|     { | |
|         BaseProvider::shuffle(false); | |
|     } | |
| 
 | |
|     public function testShuffleArraySupportsEmptyArrays() | |
|     { | |
|         $this->assertEquals(array(), BaseProvider::shuffleArray(array())); | |
|     } | |
| 
 | |
|     public function testShuffleArrayReturnsAnArrayOfTheSameSize() | |
|     { | |
|         $array = array(1, 2, 3, 4, 5); | |
|         $this->assertSameSize($array, BaseProvider::shuffleArray($array)); | |
|     } | |
| 
 | |
|     public function testShuffleArrayReturnsAnArrayWithSameElements() | |
|     { | |
|         $array = array(2, 4, 6, 8, 10); | |
|         $shuffleArray = BaseProvider::shuffleArray($array); | |
|         $this->assertContains(2, $shuffleArray); | |
|         $this->assertContains(4, $shuffleArray); | |
|         $this->assertContains(6, $shuffleArray); | |
|         $this->assertContains(8, $shuffleArray); | |
|         $this->assertContains(10, $shuffleArray); | |
|     } | |
| 
 | |
|     public function testShuffleArrayReturnsADifferentArrayThanTheOriginal() | |
|     { | |
|         $arr = array(1, 2, 3, 4, 5); | |
|         $shuffledArray = BaseProvider::shuffleArray($arr); | |
|         $this->assertNotEquals($arr, $shuffledArray); | |
|     } | |
| 
 | |
|     public function testShuffleArrayLeavesTheOriginalArrayUntouched() | |
|     { | |
|         $arr = array(1, 2, 3, 4, 5); | |
|         BaseProvider::shuffleArray($arr); | |
|         $this->assertEquals($arr, array(1, 2, 3, 4, 5)); | |
|     } | |
| 
 | |
|     public function testShuffleStringSupportsEmptyStrings() | |
|     { | |
|         $this->assertEquals('', BaseProvider::shuffleString('')); | |
|     } | |
| 
 | |
|     public function testShuffleStringReturnsAnStringOfTheSameSize() | |
|     { | |
|         $string = 'abcdef'; | |
|         $this->assertEquals(strlen($string), strlen(BaseProvider::shuffleString($string))); | |
|     } | |
| 
 | |
|     public function testShuffleStringReturnsAnStringWithSameElements() | |
|     { | |
|         $string = 'acegi'; | |
|         $shuffleString = BaseProvider::shuffleString($string); | |
|         $this->assertContains('a', $shuffleString); | |
|         $this->assertContains('c', $shuffleString); | |
|         $this->assertContains('e', $shuffleString); | |
|         $this->assertContains('g', $shuffleString); | |
|         $this->assertContains('i', $shuffleString); | |
|     } | |
| 
 | |
|     public function testShuffleStringReturnsADifferentStringThanTheOriginal() | |
|     { | |
|         $string = 'abcdef'; | |
|         $shuffledString = BaseProvider::shuffleString($string); | |
|         $this->assertNotEquals($string, $shuffledString); | |
|     } | |
| 
 | |
|     public function testShuffleStringLeavesTheOriginalStringUntouched() | |
|     { | |
|         $string = 'abcdef'; | |
|         BaseProvider::shuffleString($string); | |
|         $this->assertEquals($string, 'abcdef'); | |
|     } | |
| 
 | |
|     public function testNumerifyReturnsSameStringWhenItContainsNoHashSign() | |
|     { | |
|         $this->assertEquals('fooBar?', BaseProvider::numerify('fooBar?')); | |
|     } | |
| 
 | |
|     public function testNumerifyReturnsStringWithHashSignsReplacedByDigits() | |
|     { | |
|         $this->assertRegExp('/foo\dBa\dr/', BaseProvider::numerify('foo#Ba#r')); | |
|     } | |
| 
 | |
|     public function testNumerifyReturnsStringWithPercentageSignsReplacedByDigits() | |
|     { | |
|         $this->assertRegExp('/foo\dBa\dr/', BaseProvider::numerify('foo%Ba%r')); | |
|     } | |
| 
 | |
|     public function testNumerifyReturnsStringWithPercentageSignsReplacedByNotNullDigits() | |
|     { | |
|         $this->assertNotEquals('0', BaseProvider::numerify('%')); | |
|     } | |
| 
 | |
|     public function testNumerifyCanGenerateALargeNumberOfDigits() | |
|     { | |
|         $largePattern = str_repeat('#', 20); // definitely larger than PHP_INT_MAX on all systems | |
|         $this->assertEquals(20, strlen(BaseProvider::numerify($largePattern))); | |
|     } | |
| 
 | |
|     public function testLexifyReturnsSameStringWhenItContainsNoQuestionMark() | |
|     { | |
|         $this->assertEquals('fooBar#', BaseProvider::lexify('fooBar#')); | |
|     } | |
| 
 | |
|     public function testLexifyReturnsStringWithQuestionMarksReplacedByLetters() | |
|     { | |
|         $this->assertRegExp('/foo[a-z]Ba[a-z]r/', BaseProvider::lexify('foo?Ba?r')); | |
|     } | |
| 
 | |
|     public function testBothifyCombinesNumerifyAndLexify() | |
|     { | |
|         $this->assertRegExp('/foo[a-z]Ba\dr/', BaseProvider::bothify('foo?Ba#r')); | |
|     } | |
| 
 | |
|     public function testBothifyAsterisk() | |
|     { | |
|         $this->assertRegExp('/foo([a-z]|\d)Ba([a-z]|\d)r/', BaseProvider::bothify('foo*Ba*r')); | |
|     } | |
| 
 | |
|     public function testBothifyUtf() | |
|     { | |
|         $utf = 'œ∑´®†¥¨ˆøπ“‘和製╯°□°╯︵ ┻━┻🐵 🙈 ﺚﻣ ﻦﻔﺳ ﺲﻘﻄﺗ ﻮﺑﺎﻠﺘﺣﺪﻳﺩ،, ﺝﺰﻳﺮﺘﻳ ﺏﺎﺴﺘﺧﺩﺎﻣ ﺄﻧ ﺪﻧﻭ. ﺇﺫ ﻪﻧﺍ؟ ﺎﻠﺴﺗﺍﺭ ﻮﺘ'; | |
|         $this->assertRegExp('/'.$utf.'foo\dB[a-z]a([a-z]|\d)r/u', BaseProvider::bothify($utf.'foo#B?a*r')); | |
|     } | |
| 
 | |
|     public function testAsciifyReturnsSameStringWhenItContainsNoStarSign() | |
|     { | |
|         $this->assertEquals('fooBar?', BaseProvider::asciify('fooBar?')); | |
|     } | |
| 
 | |
|     public function testAsciifyReturnsStringWithStarSignsReplacedByAsciiChars() | |
|     { | |
|         $this->assertRegExp('/foo.Ba.r/', BaseProvider::asciify('foo*Ba*r')); | |
|     } | |
| 
 | |
|     public function regexifyBasicDataProvider() | |
|     { | |
|         return array( | |
|             array('azeQSDF1234', 'azeQSDF1234', 'does not change non regex chars'), | |
|             array('foo(bar){1}', 'foobar', 'replaces regex characters'), | |
|             array('', '', 'supports empty string'), | |
|             array('/^foo(bar){1}$/', 'foobar', 'ignores regex delimiters') | |
|         ); | |
|     } | |
| 
 | |
|     /** | |
|      * @dataProvider regexifyBasicDataProvider | |
|      */ | |
|     public function testRegexifyBasicFeatures($input, $output, $message) | |
|     { | |
|         $this->assertEquals($output, BaseProvider::regexify($input), $message); | |
|     } | |
| 
 | |
|     public function regexifyDataProvider() | |
|     { | |
|         return array( | |
|             array('\d', 'numbers'), | |
|             array('\w', 'letters'), | |
|             array('(a|b)', 'alternation'), | |
|             array('[aeiou]', 'basic character class'), | |
|             array('[a-z]', 'character class range'), | |
|             array('[a-z1-9]', 'multiple character class range'), | |
|             array('a*b+c?', 'single character quantifiers'), | |
|             array('a{2}', 'brackets quantifiers'), | |
|             array('a{2,3}', 'min-max brackets quantifiers'), | |
|             array('[aeiou]{2,3}', 'brackets quantifiers on basic character class'), | |
|             array('[a-z]{2,3}', 'brackets quantifiers on character class range'), | |
|             array('(a|b){2,3}', 'brackets quantifiers on alternation'), | |
|             array('\.\*\?\+', 'escaped characters'), | |
|             array('[A-Z0-9._%+-]+@[A-Z0-9.-]+\.[A-Z]{2,4}', 'complex regex') | |
|         ); | |
|     } | |
| 
 | |
|     /** | |
|      * @dataProvider regexifyDataProvider | |
|      */ | |
|     public function testRegexifySupportedRegexSyntax($pattern, $message) | |
|     { | |
|         $this->assertRegExp('/' . $pattern . '/', BaseProvider::regexify($pattern), 'Regexify supports ' . $message); | |
|     } | |
| 
 | |
|     public function testOptionalReturnsProviderValueWhenCalledWithWeight1() | |
|     { | |
|         $faker = new \Faker\Generator(); | |
|         $faker->addProvider(new \Faker\Provider\Base($faker)); | |
|         $this->assertNotNull($faker->optional(100)->randomDigit); | |
|     } | |
| 
 | |
|     public function testOptionalReturnsNullWhenCalledWithWeight0() | |
|     { | |
|         $faker = new \Faker\Generator(); | |
|         $faker->addProvider(new \Faker\Provider\Base($faker)); | |
|         $this->assertNull($faker->optional(0)->randomDigit); | |
|     } | |
| 
 | |
|     public function testOptionalAllowsChainingPropertyAccess() | |
|     { | |
|         $faker = new \Faker\Generator(); | |
|         $faker->addProvider(new \Faker\Provider\Base($faker)); | |
|         $faker->addProvider(new \ArrayObject(array(1))); // hack because method_exists forbids stubs | |
|         $this->assertEquals(1, $faker->optional(100)->count); | |
|         $this->assertNull($faker->optional(0)->count); | |
|     } | |
| 
 | |
|     public function testOptionalAllowsChainingMethodCall() | |
|     { | |
|         $faker = new \Faker\Generator(); | |
|         $faker->addProvider(new \Faker\Provider\Base($faker)); | |
|         $faker->addProvider(new \ArrayObject(array(1))); // hack because method_exists forbids stubs | |
|         $this->assertEquals(1, $faker->optional(100)->count()); | |
|         $this->assertNull($faker->optional(0)->count()); | |
|     } | |
| 
 | |
|     public function testOptionalAllowsChainingProviderCallRandomlyReturnNull() | |
|     { | |
|         $faker = new \Faker\Generator(); | |
|         $faker->addProvider(new \Faker\Provider\Base($faker)); | |
|         $values = array(); | |
|         for ($i=0; $i < 10; $i++) { | |
|             $values[]= $faker->optional()->randomDigit; | |
|         } | |
|         $this->assertContains(null, $values); | |
| 
 | |
|         $values = array(); | |
|         for ($i=0; $i < 10; $i++) { | |
|             $values[]= $faker->optional(50)->randomDigit; | |
|         } | |
|         $this->assertContains(null, $values); | |
|     } | |
| 
 | |
|     /** | |
|      * @link https://github.com/fzaninotto/Faker/issues/265 | |
|      */ | |
|     public function testOptionalPercentageAndWeight() | |
|     { | |
|         $faker = new \Faker\Generator(); | |
|         $faker->addProvider(new \Faker\Provider\Base($faker)); | |
|         $faker->addProvider(new \Faker\Provider\Miscellaneous($faker)); | |
| 
 | |
|         $valuesOld = array(); | |
|         $valuesNew = array(); | |
| 
 | |
|         for ($i = 0; $i < 10000; ++$i) { | |
|             $valuesOld[] = $faker->optional(0.5)->boolean(100); | |
|             $valuesNew[] = $faker->optional(50)->boolean(100); | |
|         } | |
| 
 | |
|         $this->assertEquals( | |
|             round(array_sum($valuesOld) / 10000, 2), | |
|             round(array_sum($valuesNew) / 10000, 2) | |
|         ); | |
|     } | |
| 
 | |
|     public function testUniqueAllowsChainingPropertyAccess() | |
|     { | |
|         $faker = new \Faker\Generator(); | |
|         $faker->addProvider(new \Faker\Provider\Base($faker)); | |
|         $faker->addProvider(new \ArrayObject(array(1))); // hack because method_exists forbids stubs | |
|         $this->assertEquals(1, $faker->unique()->count); | |
|     } | |
| 
 | |
|     public function testUniqueAllowsChainingMethodCall() | |
|     { | |
|         $faker = new \Faker\Generator(); | |
|         $faker->addProvider(new \Faker\Provider\Base($faker)); | |
|         $faker->addProvider(new \ArrayObject(array(1))); // hack because method_exists forbids stubs | |
|         $this->assertEquals(1, $faker->unique()->count()); | |
|     } | |
| 
 | |
|     public function testUniqueReturnsOnlyUniqueValues() | |
|     { | |
|         $faker = new \Faker\Generator(); | |
|         $faker->addProvider(new \Faker\Provider\Base($faker)); | |
|         $values = array(); | |
|         for ($i=0; $i < 10; $i++) { | |
|             $values[]= $faker->unique()->randomDigit; | |
|         } | |
|         sort($values); | |
|         $this->assertEquals(array(0, 1, 2, 3, 4, 5, 6, 7, 8, 9), $values); | |
|     } | |
| 
 | |
|     /** | |
|      * @expectedException OverflowException | |
|      */ | |
|     public function testUniqueThrowsExceptionWhenNoUniqueValueCanBeGenerated() | |
|     { | |
|         $faker = new \Faker\Generator(); | |
|         $faker->addProvider(new \Faker\Provider\Base($faker)); | |
|         for ($i=0; $i < 11; $i++) { | |
|             $faker->unique()->randomDigit; | |
|         } | |
|     } | |
| 
 | |
|     public function testUniqueCanResetUniquesWhenPassedTrueAsArgument() | |
|     { | |
|         $faker = new \Faker\Generator(); | |
|         $faker->addProvider(new \Faker\Provider\Base($faker)); | |
|         $values = array(); | |
|         for ($i=0; $i < 10; $i++) { | |
|             $values[]= $faker->unique()->randomDigit; | |
|         } | |
|         $values[]= $faker->unique(true)->randomDigit; | |
|         for ($i=0; $i < 9; $i++) { | |
|             $values[]= $faker->unique()->randomDigit; | |
|         } | |
|         sort($values); | |
|         $this->assertEquals(array(0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9), $values); | |
|     } | |
| 
 | |
|     public function testValidAllowsChainingPropertyAccess() | |
|     { | |
|         $faker = new \Faker\Generator(); | |
|         $faker->addProvider(new \Faker\Provider\Base($faker)); | |
|         $this->assertLessThan(10, $faker->valid()->randomDigit); | |
|     } | |
| 
 | |
|     public function testValidAllowsChainingMethodCall() | |
|     { | |
|         $faker = new \Faker\Generator(); | |
|         $faker->addProvider(new \Faker\Provider\Base($faker)); | |
|         $this->assertLessThan(10, $faker->valid()->numberBetween(5, 9)); | |
|     } | |
| 
 | |
|     public function testValidReturnsOnlyValidValues() | |
|     { | |
|         $faker = new \Faker\Generator(); | |
|         $faker->addProvider(new \Faker\Provider\Base($faker)); | |
|         $values = array(); | |
|         $evenValidator = function($digit) { | |
|             return $digit % 2 === 0; | |
|         }; | |
|         for ($i=0; $i < 50; $i++) { | |
|             $values[$faker->valid($evenValidator)->randomDigit] = true; | |
|         } | |
|         $uniqueValues = array_keys($values); | |
|         sort($uniqueValues); | |
|         $this->assertEquals(array(0, 2, 4, 6, 8), $uniqueValues); | |
|     } | |
| 
 | |
|     /** | |
|      * @expectedException OverflowException | |
|      */ | |
|     public function testValidThrowsExceptionWhenNoValidValueCanBeGenerated() | |
|     { | |
|         $faker = new \Faker\Generator(); | |
|         $faker->addProvider(new \Faker\Provider\Base($faker)); | |
|         $evenValidator = function($digit) { | |
|             return $digit % 2 === 0; | |
|         }; | |
|         for ($i=0; $i < 11; $i++) { | |
|             $faker->valid($evenValidator)->randomElement(array(1, 3, 5, 7, 9)); | |
|         } | |
|     } | |
| 
 | |
|     /** | |
|      * @expectedException InvalidArgumentException | |
|      */ | |
|     public function testValidThrowsExceptionWhenParameterIsNotCollable() | |
|     { | |
|         $faker = new \Faker\Generator(); | |
|         $faker->addProvider(new \Faker\Provider\Base($faker)); | |
|         $faker->valid(12)->randomElement(array(1, 3, 5, 7, 9)); | |
|     } | |
| 
 | |
|     /** | |
|      * @expectedException LengthException | |
|      * @expectedExceptionMessage Cannot get 2 elements, only 1 in array | |
|      */ | |
|     public function testRandomElementsThrowsWhenRequestingTooManyKeys() | |
|     { | |
|         BaseProvider::randomElements(array('foo'), 2); | |
|     } | |
| 
 | |
|     public function testRandomElements() | |
|     { | |
|         $this->assertCount(1, BaseProvider::randomElements(), 'Should work without any input'); | |
| 
 | |
|         $empty = BaseProvider::randomElements(array(), 0); | |
|         $this->assertInternalType('array', $empty); | |
|         $this->assertCount(0, $empty); | |
| 
 | |
|         $shuffled = BaseProvider::randomElements(array('foo', 'bar', 'baz'), 3); | |
|         $this->assertContains('foo', $shuffled); | |
|         $this->assertContains('bar', $shuffled); | |
|         $this->assertContains('baz', $shuffled); | |
| 
 | |
|         $allowDuplicates = BaseProvider::randomElements(array('foo', 'bar'), 3, true); | |
|         $this->assertCount(3, $allowDuplicates); | |
|         $this->assertContainsOnly('string', $allowDuplicates); | |
|     } | |
| }
 | |
| 
 |