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
|
<?php
namespace MediaWiki\Tests\User\TempUser;
use MediaWiki\User\TempUser\ScrambleMapping;
use OutOfBoundsException;
use PHPUnit\Framework\TestCase;
/**
* @covers \MediaWiki\User\TempUser\ScrambleMapping
*/
class ScrambleMappingTest extends TestCase {
public function testMap() {
if ( !extension_loaded( 'gmp' ) && !extension_loaded( 'bcmath' ) ) {
$this->markTestSkipped( 'need extension gmp or bcmath' );
}
$map = new ScrambleMapping( [] );
$duplicates = 0;
// This has been verified up to 1e8 but for CI purposes we will use 200
$n = 200;
// Make a bit array for duplicate detection, with enough space for one extra digit
$bitArray = str_repeat( "\0", $n * 10 / 8 );
for ( $i = 0; $i < $n; $i++ ) {
$value = (int)$map->getSerialIdForIndex( $i );
$minor = $value % 8;
$major = ( $value - $minor ) / 8;
$prevBits = ord( $bitArray[$major] );
$prevStatus = ( $prevBits & ( 1 << $minor ) );
$duplicates += ( $prevStatus ? 1 : 0 );
$newBits = $prevBits | ( 1 << $minor );
$bitArray[$major] = chr( $newBits );
}
$this->assertSame( 0, $duplicates, 'duplicate detected' );
}
public function testOffsetTooLarge() {
$map = new ScrambleMapping( [ 'offset' => 10 ] );
$this->expectException( OutOfBoundsException::class );
$map->getSerialIdForIndex( 1 );
}
}
|