PaymentTest.php 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. <?php
  2. namespace Faker\Test\Provider\es_ES;
  3. use Faker\Generator;
  4. use Faker\Provider\es_ES\Payment;
  5. use PHPUnit\Framework\TestCase;
  6. class PaymentTest extends TestCase
  7. {
  8. /**
  9. * @var Generator
  10. */
  11. private $faker;
  12. public function setUp()
  13. {
  14. $faker = new Generator();
  15. $faker->addProvider(new Payment($faker));
  16. $this->faker = $faker;
  17. }
  18. public function testVAT()
  19. {
  20. $vat = $this->faker->vat();
  21. $this->assertTrue($this->isValidCIF($vat));
  22. }
  23. /**
  24. * Validation taken from https://github.com/amnesty/drupal-nif-nie-cif-validator/
  25. * @link https://github.com/amnesty/drupal-nif-nie-cif-validator/blob/master/includes/nif-nie-cif.php
  26. */
  27. function isValidCIF($docNumber)
  28. {
  29. $fixedDocNumber = strtoupper($docNumber);
  30. return $this->isValidCIFFormat($fixedDocNumber);
  31. }
  32. function isValidCIFFormat($docNumber)
  33. {
  34. return $this->respectsDocPattern($docNumber, '/^[PQSNWR][0-9][0-9][0-9][0-9][0-9][0-9][0-9][A-Z0-9]/')
  35. ||
  36. $this->respectsDocPattern($docNumber, '/^[ABCDEFGHJUV][0-9][0-9][0-9][0-9][0-9][0-9][0-9][0-9]/');
  37. }
  38. function respectsDocPattern($givenString, $pattern)
  39. {
  40. $isValid = FALSE;
  41. $fixedString = strtoupper($givenString);
  42. if (is_int(substr($fixedString, 0, 1))) {
  43. $fixedString = substr("000000000" . $givenString, -9);
  44. }
  45. if (preg_match($pattern, $fixedString)) {
  46. $isValid = TRUE;
  47. }
  48. return $isValid;
  49. }
  50. }