wiki.techinc.nl/tests/phpunit/includes/AutopromoteTest.php

66 lines
1.8 KiB
PHP

<?php
use MediaWiki\User\UserEditTracker;
/**
* @covers Autopromote
*/
class AutopromoteTest extends MediaWikiIntegrationTestCase {
/**
* Autopromote must not perform edit count lookup if requirement is 0 or invalid (T157718).
*
* @see Autopromote::getAutopromoteGroups()
* @dataProvider provideEditCountsAndRequirements
* @param int $editCount edit count of user to be checked by Autopromote
* @param int $requirement edit count required to autopromote user
*/
public function testEditCountLookupIsSkippedIfRequirementIsZero( $editCount, $requirement ) {
$this->hideDeprecated( 'Autopromote::getAutopromoteGroups' );
$this->setMwGlobals( [
'wgAutopromote' => [
'autoconfirmed' => [ APCOND_EDITCOUNT, $requirement ]
]
] );
$user = $this->getTestUser()->getUser();
$userEditTrackerMock = $this->createNoOpMock(
UserEditTracker::class,
[ 'getUserEditCount' ]
);
if ( $requirement > 0 ) {
$userEditTrackerMock->expects( $this->once() )
->method( 'getUserEditCount' )
->with( $user )
->willReturn( $editCount );
} else {
$userEditTrackerMock->expects( $this->never() )
->method( 'getUserEditCount' );
}
$this->setService( 'UserEditTracker', $userEditTrackerMock );
$result = Autopromote::getAutopromoteGroups( $user );
if ( $editCount >= $requirement ) {
$this->assertContains(
'autoconfirmed',
$result,
'User must be promoted if they meet edit count requirement'
);
} else {
$this->assertNotContains(
'autoconfirmed',
$result,
'User must not be promoted if they fail edit count requirement'
);
}
}
public static function provideEditCountsAndRequirements() {
return [
'user with sufficient editcount' => [ 100, 10 ],
'user with insufficient editcount' => [ 4, 10 ],
'edit count requirement set to 0' => [ 1, 0 ],
];
}
}