1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68
|
<?php
namespace Faker\Test\Provider\en_ZA;
use Faker\Provider\DateTime;
use Faker\Provider\en_ZA\Person;
use Faker\Test\TestCase;
/**
* @group legacy
*/
final class PersonTest extends TestCase
{
public function testIdNumberWithDefaults()
{
$idNumber = $this->faker->idNumber();
self::assertEquals(13, strlen($idNumber));
self::assertMatchesRegularExpression('#^\d{13}$#', $idNumber);
self::assertIsString($idNumber);
}
public function testIdNumberForMales()
{
$idNumber = $this->faker->idNumber(new \DateTime(), true, 'male');
$genderDigit = substr($idNumber, 6, 1);
self::assertContains($genderDigit, ['5', '6', '7', '8', '9']);
}
public function testIdNumberForFemales()
{
$idNumber = $this->faker->idNumber(new \DateTime(), true, 'female');
$genderDigit = substr($idNumber, 6, 1);
self::assertContains($genderDigit, ['0', '1', '2', '3', '4']);
}
public function testLicenceCode()
{
$validLicenceCodes = ['A', 'A1', 'B', 'C', 'C1', 'C2', 'EB', 'EC', 'EC1', 'I', 'L', 'L1'];
self::assertContains($this->faker->licenceCode, $validLicenceCodes);
}
public function testMaleTitles()
{
$validMaleTitles = ['Mr.', 'Dr.', 'Prof.', 'Rev.', 'Hon.'];
self::assertContains(Person::titleMale(), $validMaleTitles);
}
public function testFemaleTitles()
{
$validateFemaleTitles = ['Mrs.', 'Ms.', 'Miss', 'Dr.', 'Prof.', 'Rev.', 'Hon.'];
self::assertContains(Person::titleFemale(), $validateFemaleTitles);
}
protected function getProviders(): iterable
{
yield new Person($this->faker);
yield new DateTime($this->faker);
}
}
|