2011-04-06 19:50:54 +00:00
|
|
|
<?php
|
|
|
|
|
|
2011-05-01 23:02:27 +00:00
|
|
|
abstract class ApiTestCase extends MediaWikiLangTestCase {
|
2011-07-01 16:34:02 +00:00
|
|
|
/**
|
|
|
|
|
* @var Array of ApiTestUser
|
|
|
|
|
*/
|
2011-04-06 19:50:54 +00:00
|
|
|
public static $users;
|
2011-07-01 16:34:02 +00:00
|
|
|
protected static $apiUrl;
|
2011-04-06 19:50:54 +00:00
|
|
|
|
2011-10-27 01:06:50 +00:00
|
|
|
/**
|
|
|
|
|
* @var ApiTestContext
|
|
|
|
|
*/
|
|
|
|
|
protected $apiContext;
|
|
|
|
|
|
2011-04-06 19:50:54 +00:00
|
|
|
function setUp() {
|
2011-07-01 16:34:02 +00:00
|
|
|
global $wgContLang, $wgAuth, $wgMemc, $wgRequest, $wgUser, $wgServer;
|
2011-04-06 19:50:54 +00:00
|
|
|
|
2011-05-01 23:02:27 +00:00
|
|
|
parent::setUp();
|
2011-07-01 16:34:02 +00:00
|
|
|
self::$apiUrl = $wgServer . wfScript( 'api' );
|
2011-04-06 19:50:54 +00:00
|
|
|
$wgMemc = new EmptyBagOStuff();
|
|
|
|
|
$wgContLang = Language::factory( 'en' );
|
|
|
|
|
$wgAuth = new StubObject( 'wgAuth', 'AuthPlugin' );
|
|
|
|
|
$wgRequest = new FauxRequest( array() );
|
|
|
|
|
|
|
|
|
|
self::$users = array(
|
|
|
|
|
'sysop' => new ApiTestUser(
|
|
|
|
|
'Apitestsysop',
|
|
|
|
|
'Api Test Sysop',
|
|
|
|
|
'api_test_sysop@sample.com',
|
|
|
|
|
array( 'sysop' )
|
|
|
|
|
),
|
|
|
|
|
'uploader' => new ApiTestUser(
|
|
|
|
|
'Apitestuser',
|
|
|
|
|
'Api Test User',
|
|
|
|
|
'api_test_user@sample.com',
|
|
|
|
|
array()
|
|
|
|
|
)
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
$wgUser = self::$users['sysop']->user;
|
|
|
|
|
|
2011-10-27 01:06:50 +00:00
|
|
|
$this->apiContext = new ApiTestContext();
|
|
|
|
|
|
2011-04-06 19:50:54 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
protected function doApiRequest( $params, $session = null, $appendModule = false ) {
|
|
|
|
|
if ( is_null( $session ) ) {
|
|
|
|
|
$session = array();
|
|
|
|
|
}
|
|
|
|
|
|
2011-10-27 01:06:50 +00:00
|
|
|
$context = $this->apiContext->newTestContext( $params, $session );
|
|
|
|
|
$module = new ApiMain( $context, true );
|
2011-04-06 19:50:54 +00:00
|
|
|
$module->execute();
|
|
|
|
|
|
2011-10-27 01:06:50 +00:00
|
|
|
$results = array(
|
|
|
|
|
$module->getResultData(),
|
|
|
|
|
$context->getRequest(),
|
|
|
|
|
$context->getRequest()->getSessionArray()
|
|
|
|
|
);
|
2011-07-01 16:34:02 +00:00
|
|
|
if( $appendModule ) {
|
|
|
|
|
$results[] = $module;
|
|
|
|
|
}
|
2011-08-13 14:00:22 +00:00
|
|
|
|
2011-07-01 16:34:02 +00:00
|
|
|
return $results;
|
2011-04-06 19:50:54 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Add an edit token to the API request
|
|
|
|
|
* This is cheating a bit -- we grab a token in the correct format and then add it to the pseudo-session and to the
|
|
|
|
|
* request, without actually requesting a "real" edit token
|
|
|
|
|
* @param $params: key-value API params
|
|
|
|
|
* @param $session: session array
|
|
|
|
|
*/
|
|
|
|
|
protected function doApiRequestWithToken( $params, $session ) {
|
|
|
|
|
if ( $session['wsToken'] ) {
|
|
|
|
|
// add edit token to fake session
|
|
|
|
|
$session['wsEditToken'] = $session['wsToken'];
|
|
|
|
|
// add token to request parameters
|
|
|
|
|
$params['token'] = md5( $session['wsToken'] ) . User::EDIT_TOKEN_SUFFIX;
|
|
|
|
|
return $this->doApiRequest( $params, $session );
|
|
|
|
|
} else {
|
|
|
|
|
throw new Exception( "request data not in right format" );
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2011-07-01 16:34:02 +00:00
|
|
|
protected function doLogin() {
|
|
|
|
|
$data = $this->doApiRequest( array(
|
|
|
|
|
'action' => 'login',
|
|
|
|
|
'lgname' => self::$users['sysop']->username,
|
|
|
|
|
'lgpassword' => self::$users['sysop']->password ) );
|
|
|
|
|
|
|
|
|
|
$token = $data[0]['login']['token'];
|
|
|
|
|
|
|
|
|
|
$data = $this->doApiRequest( array(
|
|
|
|
|
'action' => 'login',
|
|
|
|
|
'lgtoken' => $token,
|
|
|
|
|
'lgname' => self::$users['sysop']->username,
|
|
|
|
|
'lgpassword' => self::$users['sysop']->password
|
|
|
|
|
), $data );
|
|
|
|
|
|
|
|
|
|
return $data;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
protected function getTokenList( $user ) {
|
|
|
|
|
$GLOBALS['wgUser'] = $user->user;
|
|
|
|
|
$data = $this->doApiRequest( array(
|
|
|
|
|
'action' => 'query',
|
|
|
|
|
'titles' => 'Main Page',
|
|
|
|
|
'intoken' => 'edit|delete|protect|move|block|unblock',
|
|
|
|
|
'prop' => 'info' ) );
|
|
|
|
|
return $data;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
class UserWrapper {
|
|
|
|
|
public $userName, $password, $user;
|
|
|
|
|
|
|
|
|
|
public function __construct( $userName, $password, $group = '' ) {
|
|
|
|
|
$this->userName = $userName;
|
|
|
|
|
$this->password = $password;
|
|
|
|
|
|
|
|
|
|
$this->user = User::newFromName( $this->userName );
|
|
|
|
|
if ( !$this->user->getID() ) {
|
|
|
|
|
$this->user = User::createNew( $this->userName, array(
|
|
|
|
|
"email" => "test@example.com",
|
|
|
|
|
"real_name" => "Test User" ) );
|
|
|
|
|
}
|
|
|
|
|
$this->user->setPassword( $this->password );
|
|
|
|
|
|
|
|
|
|
if ( $group !== '' ) {
|
|
|
|
|
$this->user->addGroup( $group );
|
|
|
|
|
}
|
|
|
|
|
$this->user->saveSettings();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
class MockApi extends ApiBase {
|
|
|
|
|
public function execute() { }
|
|
|
|
|
public function getVersion() { }
|
|
|
|
|
|
|
|
|
|
public function __construct() { }
|
|
|
|
|
|
|
|
|
|
public function getAllowedParams() {
|
|
|
|
|
return array(
|
|
|
|
|
'filename' => null,
|
|
|
|
|
'enablechunks' => false,
|
|
|
|
|
'sessionkey' => null,
|
|
|
|
|
);
|
|
|
|
|
}
|
2011-04-06 19:50:54 +00:00
|
|
|
}
|
2011-10-27 01:06:50 +00:00
|
|
|
|
|
|
|
|
class ApiTestContext extends RequestContext {
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Returns a DerivativeContext with the request variables in place
|
|
|
|
|
*
|
|
|
|
|
* @param $params Array key-value API params
|
|
|
|
|
* @param $session Array session data
|
|
|
|
|
* @return DerivativeContext
|
|
|
|
|
*/
|
|
|
|
|
public function newTestContext( $params, $session ) {
|
|
|
|
|
$context = new DerivativeContext( $this );
|
|
|
|
|
$context->setRequest( new FauxRequest( $params, true, $session ) );
|
|
|
|
|
return $context;
|
|
|
|
|
}
|
|
|
|
|
}
|