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
|
<?php declare(strict_types=1);
/*
* This file is part of PHPUnit.
*
* (c) Sebastian Bergmann <sebastian@phpunit.de>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace PHPUnit\Util;
use Exception;
use PHPUnit\Framework\TestCase;
/**
* @small
*/
final class RegularExpressionTest extends TestCase
{
public function validRegexpProvider(): array
{
return [
['#valid regexp#', 'valid regexp', 1],
[';val.*xp;', 'valid regexp', 1],
['/val.*xp/i', 'VALID REGEXP', 1],
['/a val.*p/', 'valid regexp', 0],
];
}
public function invalidRegexpProvider(): array
{
return [
['valid regexp', 'valid regexp'],
[';val.*xp', 'valid regexp'],
['val.*xp/i', 'VALID REGEXP'],
];
}
/**
* @testdox Valid regex $pattern on $subject returns $return
* @dataProvider validRegexpProvider
*
* @throws \PHPUnit\Framework\ExpectationFailedException
* @throws Exception
*/
public function testValidRegex($pattern, $subject, $return): void
{
$this->assertEquals($return, RegularExpression::safeMatch($pattern, $subject));
}
/**
* @testdox Invalid regex $pattern on $subject
* @dataProvider invalidRegexpProvider
*
* @throws \PHPUnit\Framework\ExpectationFailedException
* @throws Exception
*/
public function testInvalidRegex($pattern, $subject): void
{
$this->assertFalse(RegularExpression::safeMatch($pattern, $subject));
}
}
|