mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/Thanks
synced 2024-12-11 22:46:06 +00:00
2c2b79f9b9
composer: * mediawiki/mediawiki-codesniffer: 34.0.0 → 35.0.0 * mediawiki/minus-x: 1.1.0 → 1.1.1 npm: * eslint-config-wikimedia: 0.17.0 → 0.18.1 Additional changes: * Added the "composer phan" command to conveniently run phan. Change-Id: I9f93be1e4480b38031295771aa2a8b540268b2db
251 lines
7.1 KiB
PHP
251 lines
7.1 KiB
PHP
<?php
|
|
|
|
use Flow\Model\AbstractRevision;
|
|
use Flow\Model\PostRevision;
|
|
use Flow\Model\UUID;
|
|
use Flow\Model\Workflow;
|
|
|
|
/**
|
|
* Integration tests for the Thanks Flow api module
|
|
*
|
|
* @covers ApiFlowThank
|
|
*
|
|
* @group Thanks
|
|
* @group Database
|
|
* @group medium
|
|
* @group API
|
|
* @group Flow
|
|
*
|
|
* @author Benjamin Chen
|
|
*/
|
|
class ApiFlowThankIntegrationTest extends ApiTestCase {
|
|
|
|
/** @var PostRevision */
|
|
public $topic;
|
|
|
|
/** @var User */
|
|
public $meUser;
|
|
|
|
/** @var User */
|
|
public $otherUser;
|
|
|
|
/** @var PostRevision */
|
|
public $postByOtherUser;
|
|
|
|
/** @var PostRevision */
|
|
public $postByMe;
|
|
|
|
public function setUp() : void {
|
|
parent::setUp();
|
|
|
|
if ( !ExtensionRegistry::getInstance()->isLoaded( 'Flow' ) ) {
|
|
$this->markTestSkipped( 'Flow is not installed' );
|
|
}
|
|
|
|
// mock topic and post
|
|
if ( method_exists( $this, 'getTestUser' ) ) {
|
|
$this->meUser = $this->getMutableTestUser()->getUser();
|
|
$this->otherUser = $this->getMutableTestUser()->getUser();
|
|
} else {
|
|
$this->meUser = self::$users[ 'sysop' ]->getUser();
|
|
$this->otherUser = self::$users[ 'uploader' ]->getUser();
|
|
}
|
|
$this->topic = $this->generateObject();
|
|
$this->postByOtherUser = $this->generateObject( [
|
|
'tree_orig_user_id' => $this->otherUser->getId(),
|
|
'tree_parent_id' => $this->topic->getPostId()->getBinary(),
|
|
], [], 1 );
|
|
$this->postByMe = $this->generateObject( [
|
|
'tree_orig_user_id' => $this->meUser->getId(),
|
|
'tree_parent_id' => $this->topic->getPostId()->getBinary(),
|
|
], [], 1 );
|
|
|
|
// Set up mock classes in Container.
|
|
$mockLoader = $this->getMockBuilder( '\Flow\Repository\RootPostLoader' )
|
|
->disableOriginalConstructor()
|
|
->getMock();
|
|
$that = $this;
|
|
$mockLoader->expects( $this->any() )
|
|
->method( 'getWithRoot' )
|
|
->will( $this->returnCallback(
|
|
// Hard to work with class variables or callbacks,
|
|
// using anonymous function instead.
|
|
function ( $postId ) use ( $that ) {
|
|
switch ( $postId ) {
|
|
case $that->postByOtherUser->getPostId():
|
|
return [
|
|
'post' => $that->postByOtherUser,
|
|
'root' => $that->topic
|
|
];
|
|
|
|
case $that->postByMe->getPostId():
|
|
return [
|
|
'post' => $that->postByMe,
|
|
'root' => $that->topic
|
|
];
|
|
|
|
default:
|
|
return [ 'post' => null ];
|
|
}
|
|
}
|
|
) );
|
|
|
|
$mockWorkflow = $this->createMock( Workflow::class );
|
|
$mockWorkflow->expects( $this->any() )
|
|
->method( 'getOwnerTitle' )
|
|
->willReturn( $this->createMock( Title::class ) );
|
|
$mockWorkflow->expects( $this->any() )
|
|
->method( 'getArticleTitle' )
|
|
->willReturn( $this->createMock( Title::class ) );
|
|
|
|
$mockStorage = $this->getMockBuilder( '\Flow\Data\ManagerGroup' )
|
|
->disableOriginalConstructor()
|
|
->getMock();
|
|
|
|
$mockStorage->expects( $this->any() )
|
|
->method( 'get' )
|
|
->will( $this->returnValue( $mockWorkflow ) );
|
|
|
|
$mockTemplating = $this->getMockBuilder( 'Flow\Templating' )
|
|
->disableOriginalConstructor()
|
|
->getMock();
|
|
|
|
$mockTemplating->expects( $this->any() )
|
|
->method( 'getContent' )
|
|
->will( $this->returnValue( 'test content' ) );
|
|
|
|
Flow\Container::reset();
|
|
$container = Flow\Container::getContainer();
|
|
$container[ 'loader.root_post' ] = $mockLoader;
|
|
$container[ 'storage' ] = $mockStorage;
|
|
$container[ 'templating' ] = $mockTemplating;
|
|
|
|
\DeferredUpdates::clearPendingUpdates();
|
|
}
|
|
|
|
public function testRequestWithoutToken() {
|
|
$this->expectException( ApiUsageException::class );
|
|
$this->expectExceptionMessage( 'The "token" parameter must be set.' );
|
|
$this->doApiRequest( [
|
|
'action' => 'flowthank',
|
|
'postid' => UUID::create( '42' )->getAlphadecimal(),
|
|
] );
|
|
}
|
|
|
|
public function testInvalidRequest() {
|
|
$this->expectException( ApiUsageException::class );
|
|
$this->expectExceptionMessage( 'The "postid" parameter must be set.' );
|
|
$this->doApiRequestWithToken( [ 'action' => 'flowthank' ] );
|
|
}
|
|
|
|
public function testValidRequest() {
|
|
list( $result,, ) = $this->doApiRequestWithToken( [
|
|
'action' => 'flowthank',
|
|
'postid' => $this->postByOtherUser->getPostId()->getAlphadecimal(),
|
|
] );
|
|
$this->assertSuccess( $result );
|
|
}
|
|
|
|
public function testRequestWithInvalidId() {
|
|
$this->expectException( ApiUsageException::class );
|
|
$this->expectExceptionMessage( 'Post ID is not valid' );
|
|
list( $result,, ) = $this->doApiRequestWithToken( [
|
|
'action' => 'flowthank',
|
|
'postid' => UUID::create( '42' )->getAlphadecimal(),
|
|
] );
|
|
}
|
|
|
|
public function testRequestWithOwnId() {
|
|
$this->expectException( ApiUsageException::class );
|
|
$this->expectExceptionMessage( 'You cannot thank yourself' );
|
|
list( $result,, ) = $this->doApiRequestWithToken( [
|
|
'action' => 'flowthank',
|
|
'postid' => $this->postByMe->getPostId()->getAlphadecimal(),
|
|
], null, $this->meUser );
|
|
}
|
|
|
|
protected function assertSuccess( $result ) {
|
|
$this->assertSame( 1, $result[ 'result' ][ 'success' ] );
|
|
}
|
|
|
|
/**
|
|
* This method is obtained from Flow/tests/PostRevisionTestCase.php
|
|
*
|
|
* Returns an array, representing flow_revision & flow_tree_revision db
|
|
* columns.
|
|
*
|
|
* You can pass in arguments to override default data.
|
|
* With no arguments tossed in, default data (resembling a newly-created
|
|
* topic title) will be returned.
|
|
*
|
|
* @param array $row DB row data (only specify override columns)
|
|
* @return array
|
|
*/
|
|
protected function generateRow( array $row = [] ) {
|
|
$uuidPost = UUID::create();
|
|
$uuidRevision = UUID::create();
|
|
|
|
$user = $this->meUser;
|
|
$userId = $user->getId();
|
|
$userIp = null;
|
|
|
|
return $row + [
|
|
// flow_revision
|
|
'rev_id' => $uuidRevision->getBinary(),
|
|
'rev_type' => 'post',
|
|
'rev_user_id' => $userId,
|
|
'rev_user_ip' => $userIp,
|
|
'rev_user_wiki' => wfWikiID(),
|
|
'rev_parent_id' => null,
|
|
'rev_flags' => 'html',
|
|
'rev_content' => 'test content',
|
|
'rev_change_type' => 'new-post',
|
|
'rev_mod_state' => AbstractRevision::MODERATED_NONE,
|
|
'rev_mod_user_id' => null,
|
|
'rev_mod_user_ip' => null,
|
|
'rev_mod_user_wiki' => null,
|
|
'rev_mod_timestamp' => null,
|
|
'rev_mod_reason' => null,
|
|
'rev_last_edit_id' => null,
|
|
'rev_edit_user_id' => null,
|
|
'rev_edit_user_ip' => null,
|
|
'rev_edit_user_wiki' => null,
|
|
|
|
// flow_tree_revision
|
|
'tree_rev_descendant_id' => $uuidPost->getBinary(),
|
|
'rev_type_id' => $uuidPost->getBinary(),
|
|
'tree_rev_id' => $uuidRevision->getBinary(),
|
|
'tree_orig_create_time' => wfTimestampNow(),
|
|
'tree_orig_user_id' => $userId,
|
|
'tree_orig_user_ip' => $userIp,
|
|
'tree_orig_user_wiki' => wfWikiID(),
|
|
'tree_parent_id' => null,
|
|
];
|
|
}
|
|
|
|
/**
|
|
* This method is obtained from Flow/tests/PostRevisionTestCase.php
|
|
*
|
|
* Returns a PostRevision object.
|
|
*
|
|
* You can pass in arguments to override default data.
|
|
* With no arguments tossed in, a default revision (resembling a newly-
|
|
* created topic title) will be returned.
|
|
*
|
|
* @param array $row DB row data (only specify override columns)
|
|
* @param array $children Array of child PostRevision objects
|
|
* @param int $depth Depth of the PostRevision object
|
|
* @return PostRevision
|
|
*/
|
|
protected function generateObject( array $row = [], $children = [], $depth = 0 ) {
|
|
$row = $this->generateRow( $row );
|
|
|
|
$revision = PostRevision::fromStorageRow( $row );
|
|
$revision->setChildren( $children );
|
|
$revision->setDepth( $depth );
|
|
|
|
return $revision;
|
|
}
|
|
|
|
}
|