mediawiki-extensions-Thanks/tests/ApiRevThankIntegrationTest.php
Kunal Mehta 9aa92841a6 Fix ApiRevThankTest::testValidRequest()
Bug: T130973
Change-Id: I3fc094fa0aeb7d5928fd8033bc3eefbceea72e16
2016-03-29 15:12:49 -07:00

81 lines
1.9 KiB
PHP

<?php
/**
* Integration tests for the Thanks API module
*
* @covers ApiRevThank
*
* @group Thanks
* @group Database
* @group medium
* @group API
*
* @author Addshore
*/
class ApiRevThankTest extends ApiTestCase {
public function setUp() {
parent::setUp();
$this->doLogin( 'sysop' );
\DeferredUpdates::clearPendingUpdates();
// Make one edit
$this->newRevId();
}
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']->getUser() );
/** @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']->getUser() );
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' ) );
}
}