sonarrradarrplexorganizrnginxdashboardmuximuxlandingpagestartpagelandinghtpcserverhomepagesabnzbdheimdallembycouchpotatonzbgetbookmarkapplication-dashboard
		
		
		
		
			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);
							 | 
						|
								    }
							 | 
						|
								}
							 | 
						|
								
							 |