wiki.techinc.nl/tests/phpunit/includes/poolcounter/PoolCounterTest.php
addshore 959bc315f2 MediaWikiTestCase to MediaWikiIntegrationTestCase
The name change happened some time ago, and I think its
about time to start using the name name!
(Done with a find and replace)

My personal motivation for doing this is that I have started
trying out vscode as an IDE for mediawiki development, and
right now it doesn't appear to handle php aliases very well
or at all.

Change-Id: I412235d91ae26e4c1c6a62e0dbb7e7cf3c5ed4a6
2020-06-30 17:02:22 +01:00

84 lines
2.8 KiB
PHP

<?php
/**
* @covers PoolCounter
*/
class PoolCounterTest extends MediaWikiIntegrationTestCase {
public function testConstruct() {
$poolCounterConfig = [
'class' => 'PoolCounterMock',
'timeout' => 10,
'workers' => 10,
'maxqueue' => 100,
];
$poolCounter = $this->getMockBuilder( PoolCounterAbstractMock::class )
->setConstructorArgs( [ $poolCounterConfig, 'testCounter', 'someKey' ] )
// don't mock anything - the proper syntax would be setMethods(null), but due
// to a PHPUnit bug that does not work with getMockForAbstractClass()
->setMethods( [ 'idontexist' ] )
->getMockForAbstractClass();
$this->assertInstanceOf( PoolCounter::class, $poolCounter );
}
public function testConstructWithSlots() {
$poolCounterConfig = [
'class' => 'PoolCounterMock',
'timeout' => 10,
'workers' => 10,
'slots' => 2,
'maxqueue' => 100,
];
$poolCounter = $this->getMockBuilder( PoolCounterAbstractMock::class )
->setConstructorArgs( [ $poolCounterConfig, 'testCounter', 'key' ] )
->setMethods( [ 'idontexist' ] ) // don't mock anything
->getMockForAbstractClass();
$this->assertInstanceOf( PoolCounter::class, $poolCounter );
}
public function testHashKeyIntoSlots() {
$poolCounter = $this->getMockBuilder( PoolCounterAbstractMock::class )
// don't mock anything - the proper syntax would be setMethods(null), but due
// to a PHPUnit bug that does not work with getMockForAbstractClass()
->setMethods( [ 'idontexist' ] )
->disableOriginalConstructor()
->getMockForAbstractClass();
$hashKeyIntoSlots = new ReflectionMethod( $poolCounter, 'hashKeyIntoSlots' );
$hashKeyIntoSlots->setAccessible( true );
$keysWithTwoSlots = $keysWithFiveSlots = [];
foreach ( range( 1, 100 ) as $i ) {
$keysWithTwoSlots[] = $hashKeyIntoSlots->invoke( $poolCounter, 'test', 'key ' . $i, 2 );
$keysWithFiveSlots[] = $hashKeyIntoSlots->invoke( $poolCounter, 'test', 'key ' . $i, 5 );
}
$twoSlotKeys = [];
for ( $i = 0; $i <= 1; $i++ ) {
$twoSlotKeys[] = "test:$i";
}
$fiveSlotKeys = [];
for ( $i = 0; $i <= 4; $i++ ) {
$fiveSlotKeys[] = "test:$i";
}
$this->assertArrayEquals( $twoSlotKeys, array_unique( $keysWithTwoSlots ) );
$this->assertArrayEquals( $fiveSlotKeys, array_unique( $keysWithFiveSlots ) );
// make sure it is deterministic
$this->assertEquals(
$hashKeyIntoSlots->invoke( $poolCounter, 'test', 'asdfgh', 1000 ),
$hashKeyIntoSlots->invoke( $poolCounter, 'test', 'asdfgh', 1000 )
);
}
}
// We will use this class with getMockForAbstractClass to create a concrete mock class.
// That call will die if the contructor is not public, unless we use disableOriginalConstructor(),
// in which case we could not test the constructor.
abstract class PoolCounterAbstractMock extends PoolCounter {
public function __construct( ...$args ) {
parent::__construct( ...$args );
}
}