mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/AbuseFilter.git
synced 2024-11-25 22:45:32 +00:00
2793e7f1cf
Introduce ReversibleConsequence interface for Consequence classes whose potentially destructive actions can be reverted using Special:AbuseFilter/revert. This allows moving reverting logic from AbuseFilterViewRevert to individual Consequence classes and testing. Unfortunately, the code is definitely not very clean now. Change-Id: I558da711f1645ccf64792c6102cf743827171320
93 lines
2.7 KiB
PHP
93 lines
2.7 KiB
PHP
<?php
|
|
|
|
use MediaWiki\Extension\AbuseFilter\BlockAutopromoteStore;
|
|
use MediaWiki\Extension\AbuseFilter\Consequences\Consequence\BlockAutopromote;
|
|
use MediaWiki\Extension\AbuseFilter\Consequences\Parameters;
|
|
use MediaWiki\Extension\AbuseFilter\Filter\Filter;
|
|
use MediaWiki\Linker\LinkTarget;
|
|
use MediaWiki\User\UserIdentityValue;
|
|
|
|
/**
|
|
* @coversDefaultClass \MediaWiki\Extension\AbuseFilter\Consequences\Consequence\BlockAutopromote
|
|
* @covers ::__construct
|
|
* @todo with MessageLocalizer injected, this can be a unit test
|
|
*/
|
|
class BlockAutopromoteTest extends MediaWikiIntegrationTestCase {
|
|
|
|
/**
|
|
* @covers ::execute
|
|
*/
|
|
public function testExecute_anonymous() {
|
|
$params = new Parameters(
|
|
$this->createMock( Filter::class ),
|
|
false,
|
|
new UserIdentityValue( 0, 'Anonymous user', 1 ),
|
|
$this->createMock( LinkTarget::class ),
|
|
'edit'
|
|
);
|
|
$blockAutopromoteStore = $this->createMock( BlockAutopromoteStore::class );
|
|
$blockAutopromoteStore->expects( $this->never() )
|
|
->method( 'blockAutoPromote' );
|
|
$blockAutopromote = new BlockAutopromote(
|
|
$params,
|
|
5 * 86400,
|
|
$blockAutopromoteStore
|
|
);
|
|
$this->assertFalse( $blockAutopromote->execute() );
|
|
}
|
|
|
|
/**
|
|
* @covers ::execute
|
|
* @dataProvider provideExecute
|
|
*/
|
|
public function testExecute( bool $success ) {
|
|
$target = new UserIdentityValue( 1, 'A new user', 2 );
|
|
$params = new Parameters(
|
|
$this->createMock( Filter::class ),
|
|
false,
|
|
$target,
|
|
$this->createMock( LinkTarget::class ),
|
|
'edit'
|
|
);
|
|
$duration = 5 * 86400;
|
|
$blockAutopromoteStore = $this->createMock( BlockAutopromoteStore::class );
|
|
$blockAutopromoteStore->expects( $this->once() )
|
|
->method( 'blockAutoPromote' )
|
|
->with( $target, $this->anything(), $duration )
|
|
->willReturn( $success );
|
|
$blockAutopromote = new BlockAutopromote( $params, $duration, $blockAutopromoteStore );
|
|
$this->assertSame( $success, $blockAutopromote->execute() );
|
|
}
|
|
|
|
public function provideExecute() : array {
|
|
return [
|
|
[ true ],
|
|
[ false ]
|
|
];
|
|
}
|
|
|
|
/**
|
|
* @covers ::revert
|
|
* @dataProvider provideExecute
|
|
*/
|
|
public function testRevert( bool $success ) {
|
|
$target = new UserIdentityValue( 1, 'A new user', 2 );
|
|
$performer = new UserIdentityValue( 2, 'Reverting user', 3 );
|
|
$params = new Parameters(
|
|
$this->createMock( Filter::class ),
|
|
false,
|
|
$target,
|
|
$this->createMock( LinkTarget::class ),
|
|
'edit'
|
|
);
|
|
$blockAutopromoteStore = $this->createMock( BlockAutopromoteStore::class );
|
|
$blockAutopromoteStore->expects( $this->once() )
|
|
->method( 'unblockAutoPromote' )
|
|
->with( $target, $performer, $this->anything() )
|
|
->willReturn( $success );
|
|
$blockAutopromote = new BlockAutopromote( $params, 0, $blockAutopromoteStore );
|
|
$this->assertSame( $success, $blockAutopromote->revert( [], $performer, 'reason' ) );
|
|
}
|
|
|
|
}
|