mediawiki-extensions-Thanks/tests/ApiRevThankIntegrationTest.php
Brad Jorsch a0e4ccfa30 Add i18n for API module help
MediaWiki core change I04b1a384 added support for i18n of API module
help. This takes advantage of that while still maintaining backwards
compatibility with earlier versions of MediaWiki.

Once support for MediaWiki before 1.25 is dropped, the methods marked
deprecated in this patch may be removed.

Change-Id: I67395aff48185f3e09da31b51a08aa2541fe6a17
2014-11-03 13:32:23 -08:00

79 lines
1.8 KiB
PHP

<?php
/**
* Integration tests for the Thanks API module
*
* @covers ApiRevThank
*
* @group Thanks
* @group Database
* @group medium
* @group API
*
* @author Adam Shorland
*/
class ApiRevThankTest extends ApiTestCase {
public function setUp() {
parent::setUp();
$this->doLogin( 'sysop' );
\DeferredUpdates::clearPendingUpdates();
}
public function testRequestWithoutToken(){
$this->setExpectedException( 'UsageException', 'The token parameter must be set' );
$this->doApiRequest( array(
'action' => 'thank',
'source' => 'someSource',
'rev' => 1,
) );
}
public function testValidRequest(){
list( $result,, ) = $this->doApiRequestWithToken( array(
'action' => 'thank',
'rev' => $this->newRevId(),
) );
$this->assertSuccess( $result );
}
public function testValidRequestWithSource(){
list( $result,, ) = $this->doApiRequestWithToken( array(
'action' => 'thank',
'source' => 'someSource',
'rev' => $this->newRevId(),
) );
$this->assertSuccess( $result );
}
protected function newRevId(){
// You can't thank yourself, kind of hacky
$this->setMwGlobals( 'wgUser' , self::$users['uploader']->user );
/** @var Status $result */
$result = $this->editPage( 'thanks' . rand( 0, 100 ), 'thanks' . rand( 0, 100 ), 'thanksSummary' );
$result = $result->getValue();
/** @var Revision $revision */
$revision = $result['revision'];
$this->setMwGlobals( 'wgUser' , self::$users['sysop']->user );
return $revision->getId();
}
protected function assertSuccess( $result ){
$this->assertEquals( array(
'result' => array(
'success' => 1,
'recipient' => self::$users['uploader']->username,
),
), $result );
}
public function testInvalidRequest(){
$this->setExpectedException( 'UsageException' );
$this->doApiRequestWithToken( array( 'action' => 'thank' ) );
}
}