2014-03-13 13:20:02 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
use Flow\Model\AbstractRevision;
|
|
|
|
use Flow\Model\PostRevision;
|
|
|
|
use Flow\Model\UUID;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Integration tests for the Thanks Flow api module
|
|
|
|
*
|
|
|
|
* @covers ApiFlowThank
|
|
|
|
*
|
|
|
|
* @group Thanks
|
|
|
|
* @gropu Database
|
|
|
|
* @group medium
|
|
|
|
* @group API
|
|
|
|
* @group Flow
|
|
|
|
*
|
|
|
|
* @author Benjamin Chen
|
|
|
|
*/
|
|
|
|
class ApiFlowThankTest extends ApiTestCase {
|
|
|
|
/**
|
|
|
|
* @var PostRevision
|
|
|
|
*/
|
|
|
|
public
|
|
|
|
$topic,
|
|
|
|
$postByOtherUser,
|
|
|
|
$postByMe;
|
|
|
|
|
|
|
|
public function setUp() {
|
|
|
|
parent::setUp();
|
|
|
|
|
|
|
|
if ( !class_exists( 'FlowHooks' ) ) {
|
|
|
|
$this->markTestSkipped( 'Flow is not installed' );
|
|
|
|
}
|
|
|
|
|
|
|
|
// mock topic and post
|
|
|
|
$this->topic = $this->generateObject();
|
|
|
|
$this->postByOtherUser = $this->generateObject( array(
|
|
|
|
'tree_orig_user_id' => self::$users[ 'uploader' ]->user->getId(),
|
|
|
|
'tree_parent_id' => $this->topic->getPostId()->getBinary(),
|
|
|
|
), array(), 1 );
|
|
|
|
$this->postByMe = $this->generateObject( array(
|
|
|
|
'tree_orig_user_id' => self::$users[ 'sysop' ]->user->getId(),
|
|
|
|
'tree_parent_id' => $this->topic->getPostId()->getBinary(),
|
|
|
|
), array(), 1 );
|
|
|
|
|
|
|
|
// Set up mock classes in Container.
|
|
|
|
$mockLoader = $this->getMockBuilder( '\Flow\Data\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 array(
|
|
|
|
'post' => $that->postByOtherUser,
|
|
|
|
'root' => $that->topic
|
|
|
|
);
|
|
|
|
|
|
|
|
case $that->postByMe->getPostId():
|
|
|
|
return array(
|
|
|
|
'post' => $that->postByMe,
|
|
|
|
'root' => $that->topic
|
|
|
|
);
|
|
|
|
|
|
|
|
default:
|
|
|
|
return array( 'post' => null );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
) );
|
|
|
|
|
|
|
|
$container = Flow\Container::getContainer();
|
|
|
|
$container[ 'loader.root_post' ] = $mockLoader;
|
|
|
|
|
|
|
|
$mockWorkflow = $this->getMock( '\Flow\Model\Workflow' );
|
|
|
|
$mockWorkflow->expects( $this->any() )
|
2014-08-20 10:38:15 +00:00
|
|
|
->method( 'getOwnerTitle' )
|
2014-03-13 13:20:02 +00:00
|
|
|
->will( $this->returnValue( new Title() ));
|
|
|
|
|
|
|
|
$mockStorage = $this->getMockBuilder( '\Flow\Data\ManagerGroup' )
|
|
|
|
->disableOriginalConstructor()
|
|
|
|
->getMock();
|
|
|
|
|
|
|
|
$mockStorage->expects( $this->any() )
|
|
|
|
->method( 'get' )
|
|
|
|
->will( $this->returnValue( $mockWorkflow ) );
|
|
|
|
|
|
|
|
$container[ 'storage' ] = $mockStorage;
|
|
|
|
|
2014-04-02 21:39:26 +00:00
|
|
|
$mockTemplating = $this->getMockBuilder( 'Flow\Templating' )
|
2014-03-13 13:20:02 +00:00
|
|
|
->disableOriginalConstructor()
|
|
|
|
->getMock();
|
|
|
|
|
|
|
|
$mockTemplating->expects( $this->any() )
|
|
|
|
->method( 'getContent' )
|
|
|
|
->will( $this->returnValue( 'test content' ) );
|
|
|
|
|
|
|
|
$container[ 'templating' ] = $mockTemplating;
|
|
|
|
|
|
|
|
$this->doLogin( 'sysop' );
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testRequestWithoutToken(){
|
|
|
|
$this->setExpectedException( 'UsageException', 'The token parameter must be set' );
|
|
|
|
$this->doApiRequest( array(
|
|
|
|
'action' => 'flowthank',
|
2014-04-15 03:36:13 +00:00
|
|
|
'postid' => UUID::create( '42' )->getAlphadecimal(),
|
2014-03-13 13:20:02 +00:00
|
|
|
) );
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testInvalidRequest(){
|
|
|
|
$this->setExpectedException( 'UsageException', 'The postid parameter must be set' );
|
|
|
|
$this->doApiRequestWithToken( array( 'action' => 'flowthank' ) );
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testValidRequest(){
|
|
|
|
list( $result,, ) = $this->doApiRequestWithToken( array(
|
|
|
|
'action' => 'flowthank',
|
2014-04-15 03:36:13 +00:00
|
|
|
'postid' => $this->postByOtherUser->getPostId()->getAlphadecimal(),
|
2014-03-13 13:20:02 +00:00
|
|
|
) );
|
|
|
|
$this->assertSuccess( $result );
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testRequestWithInvalidId(){
|
|
|
|
$this->setExpectedException( 'UsageException', 'Post ID is invalid' );
|
|
|
|
list( $result,, ) = $this->doApiRequestWithToken( array(
|
|
|
|
'action' => 'flowthank',
|
2014-04-15 03:36:13 +00:00
|
|
|
'postid' => UUID::create( '42' )->getAlphadecimal(),
|
2014-03-13 13:20:02 +00:00
|
|
|
) );
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testRequestWithOwnId(){
|
|
|
|
$this->setExpectedException( 'UsageException', 'You cannot thank yourself' );
|
|
|
|
list( $result,, ) = $this->doApiRequestWithToken( array(
|
|
|
|
'action' => 'flowthank',
|
2014-04-15 03:36:13 +00:00
|
|
|
'postid' => $this->postByMe->getPostId()->getAlphadecimal(),
|
2014-03-13 13:20:02 +00:00
|
|
|
) );
|
|
|
|
}
|
|
|
|
|
|
|
|
protected function assertSuccess( $result ){
|
|
|
|
$this->assertEquals( 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[optional] $row DB row data (only specify override columns)
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
protected function generateRow( array $row = array() ) {
|
|
|
|
$uuidPost = UUID::create();
|
|
|
|
$uuidRevision = UUID::create();
|
|
|
|
|
|
|
|
$user = User::newFromName( 'UTSysop' );
|
|
|
|
list( $userId, $userIp ) = PostRevision::userFields( $user );
|
|
|
|
|
|
|
|
return $row + array(
|
|
|
|
// flow_revision
|
|
|
|
'rev_id' => $uuidRevision->getBinary(),
|
|
|
|
'rev_type' => 'post',
|
|
|
|
'rev_user_id' => $userId,
|
|
|
|
'rev_user_ip' => $userIp,
|
|
|
|
'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_timestamp' => null,
|
|
|
|
'rev_mod_reason' => null,
|
|
|
|
'rev_last_edit_id' => null,
|
|
|
|
'rev_edit_user_id' => null,
|
|
|
|
'rev_edit_user_ip' => null,
|
|
|
|
|
|
|
|
// flow_tree_revision
|
|
|
|
'tree_rev_descendant_id' => $uuidPost->getBinary(),
|
2014-04-15 01:29:38 +00:00
|
|
|
'rev_type_id' => $uuidPost->getBinary(),
|
2014-03-13 13:20:02 +00:00
|
|
|
'tree_rev_id' => $uuidRevision->getBinary(),
|
|
|
|
'tree_orig_create_time' => wfTimestampNow(),
|
|
|
|
'tree_orig_user_id' => $userId,
|
|
|
|
'tree_orig_user_ip' => $userIp,
|
|
|
|
'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[optional] $row DB row data (only specify override columns)
|
|
|
|
* @param array[optional] $children Array of child PostRevision objects
|
|
|
|
* @param int[optional] $depth Depth of the PostRevision object
|
|
|
|
* @return PostRevision
|
|
|
|
*/
|
|
|
|
protected function generateObject( array $row = array(), $children = array(), $depth = 0 ) {
|
|
|
|
$row = $this->generateRow( $row );
|
|
|
|
|
|
|
|
$revision = PostRevision::fromStorageRow( $row );
|
|
|
|
$revision->setChildren( $children );
|
|
|
|
$revision->setDepth( $depth );
|
|
|
|
|
|
|
|
return $revision;
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|