wiki.techinc.nl/tests/phpunit/unit/includes/user/TempUser/ScrambleMappingTest.php
Tim Starling a124d003cf TempUser: ScrambleMapping
Add a mapping function which converts sequential integers to a sequence
in which most of the digits change each time, but without significantly
increasing the length.

Change-Id: I1011a96894fbf0b92d20a96149e68014f53e3c3c
2022-05-16 17:36:22 +00:00

31 lines
966 B
PHP

<?php
namespace MediaWiki\Tests\User\TempUser;
use MediaWiki\User\TempUser\ScrambleMapping;
use PHPUnit\Framework\TestCase;
/**
* @covers \MediaWiki\User\TempUser\ScrambleMapping
*/
class ScrambleMappingTest extends TestCase {
public function testMap() {
$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' );
}
}