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 69 70
|
<?php
/*
* This file is part of the Symfony package.
*
* (c) Fabien Potencier <fabien@symfony.com>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace Symfony\Component\Security\Csrf\Tests\TokenGenerator;
use PHPUnit\Framework\TestCase;
use Symfony\Component\Security\Csrf\TokenGenerator\UriSafeTokenGenerator;
/**
* @author Bernhard Schussek <bschussek@gmail.com>
*/
class UriSafeTokenGeneratorTest extends TestCase
{
private const ENTROPY = 1000;
/**
* A non alpha-numeric byte string.
*/
private static string $bytes;
private UriSafeTokenGenerator $generator;
public static function setUpBeforeClass(): void
{
self::$bytes = base64_decode('aMf+Tct/RLn2WQ==');
}
protected function setUp(): void
{
$this->generator = new UriSafeTokenGenerator(self::ENTROPY);
}
public function testGenerateToken()
{
$token = $this->generator->generateToken();
$this->assertTrue(ctype_print($token), 'is printable');
$this->assertDoesNotMatchRegularExpression('#.+([+/=]).+#', $token, 'is URI safe');
}
#[\PHPUnit\Framework\Attributes\DataProvider('validDataProvider')]
public function testValidLength(int $entropy, int $length)
{
$generator = new UriSafeTokenGenerator($entropy);
$token = $generator->generateToken();
$this->assertSame($length, \strlen($token));
}
public static function validDataProvider(): \Iterator
{
yield [24, 4];
yield 'Float length' => [20, 3];
}
public function testInvalidLength()
{
$this->expectException(\InvalidArgumentException::class);
$this->expectExceptionMessage('Entropy should be greater than 7.');
new UriSafeTokenGenerator(7);
}
}
|