3 abstract class ApiTestCase
extends MediaWikiLangTestCase
{
4 protected static $apiUrl;
11 protected function setUp() {
15 self
::$apiUrl = $wgServer . wfScript( 'api' );
17 ApiQueryInfo
::resetTokenCache(); // tokens are invalid because we cleared the session
20 'sysop' => new TestUser(
23 'api_test_sysop@example.com',
26 'uploader' => new TestUser(
29 'api_test_user@example.com',
34 $this->setMwGlobals( array(
35 'wgMemc' => new EmptyBagOStuff(),
36 'wgAuth' => new StubObject( 'wgAuth', 'AuthPlugin' ),
37 'wgRequest' => new FauxRequest( array() ),
38 'wgUser' => self
::$users['sysop']->user
,
41 $this->apiContext
= new ApiTestContext();
45 * Edits or creates a page/revision
46 * @param $pageName string page title
47 * @param $text string content of the page
48 * @param $summary string optional summary string for the revision
49 * @param $defaultNs int optional namespace id
50 * @return array as returned by WikiPage::doEditContent()
52 protected function editPage( $pageName, $text, $summary = '', $defaultNs = NS_MAIN
) {
53 $title = Title
::newFromText( $pageName, $defaultNs );
54 $page = WikiPage
::factory( $title );
56 return $page->doEditContent( ContentHandler
::makeContent( $text, $title ), $summary );
60 * Does the API request and returns the result.
62 * The returned value is an array containing
63 * - the result data (array)
64 * - the request (WebRequest)
65 * - the session data of the request (array)
66 * - if $appendModule is true, the Api module $module
68 * @param array $params
69 * @param array|null $session
70 * @param bool $appendModule
71 * @param User|null $user
75 protected function doApiRequest( array $params, array $session = null, $appendModule = false, User
$user = null ) {
76 global $wgRequest, $wgUser;
78 if ( is_null( $session ) ) {
79 // re-use existing global session by default
80 $session = $wgRequest->getSessionArray();
83 // set up global environment
88 $wgRequest = new FauxRequest( $params, true, $session );
89 RequestContext
::getMain()->setRequest( $wgRequest );
91 // set up local environment
92 $context = $this->apiContext
->newTestContext( $wgRequest, $wgUser );
94 $module = new ApiMain( $context, true );
101 $module->getResultData(),
102 $context->getRequest(),
103 $context->getRequest()->getSessionArray()
106 if ( $appendModule ) {
107 $results[] = $module;
114 * Add an edit token to the API request
115 * This is cheating a bit -- we grab a token in the correct format and then add it to the pseudo-session and to the
116 * request, without actually requesting a "real" edit token
117 * @param $params Array: key-value API params
118 * @param $session Array|null: session array
119 * @param $user User|null A User object for the context
120 * @return result of the API call
121 * @throws Exception in case wsToken is not set in the session
123 protected function doApiRequestWithToken( array $params, array $session = null, User
$user = null ) {
126 if ( $session === null ) {
127 $session = $wgRequest->getSessionArray();
130 if ( $session['wsToken'] ) {
131 // add edit token to fake session
132 $session['wsEditToken'] = $session['wsToken'];
133 // add token to request parameters
134 $params['token'] = md5( $session['wsToken'] ) . User
::EDIT_TOKEN_SUFFIX
;
136 return $this->doApiRequest( $params, $session, false, $user );
138 throw new Exception( "request data not in right format" );
142 protected function doLogin( $user = 'sysop' ) {
143 if( !array_key_exists( $user, self
::$users ) ){
144 throw new MWException( "Can not log in to undefined user $user" );
147 $data = $this->doApiRequest( array(
149 'lgname' => self
::$users[ $user ]->username
,
150 'lgpassword' => self
::$users[ $user ]->password
) );
152 $token = $data[0]['login']['token'];
154 $data = $this->doApiRequest(
158 'lgname' => self
::$users[ $user ]->username
,
159 'lgpassword' => self
::$users[ $user ]->password
,
167 protected function getTokenList( $user, $session = null ) {
168 $data = $this->doApiRequest( array(
169 'action' => 'tokens',
170 'type' => 'edit|delete|protect|move|block|unblock|watch'
171 ), $session, false, $user->user
);
173 if( !array_key_exists( 'tokens', $data[0] ) ){
174 throw new MWException( 'Api failed to return a token list' );
177 return $data[0]['tokens'];
180 public function testApiTestGroup() {
181 $groups = PHPUnit_Util_Test
::getGroups( get_class( $this ) );
182 $constraint = PHPUnit_Framework_Assert
::logicalOr(
183 $this->contains( 'medium' ),
184 $this->contains( 'large' )
186 $this->assertThat( $groups, $constraint,
187 'ApiTestCase::setUp can be slow, tests must be "medium" or "large"'
197 public function __construct( $userName, $password, $group = '' ) {
198 $this->userName
= $userName;
199 $this->password
= $password;
201 $this->user
= User
::newFromName( $this->userName
);
202 if ( !$this->user
->getID() ) {
203 $this->user
= User
::createNew( $this->userName
, array(
204 "email" => "test@example.com",
205 "real_name" => "Test User" ) );
207 $this->user
->setPassword( $this->password
);
209 if ( $group !== '' ) {
210 $this->user
->addGroup( $group );
212 $this->user
->saveSettings();
216 class MockApi
extends ApiBase
{
217 public function execute() {
220 public function getVersion() {
223 public function __construct() {
226 public function getAllowedParams() {
229 'enablechunks' => false,
230 'sessionkey' => null,
235 class ApiTestContext
extends RequestContext
{
238 * Returns a DerivativeContext with the request variables in place
240 * @param $request WebRequest request object including parameters and session
241 * @param $user User or null
242 * @return DerivativeContext
244 public function newTestContext( WebRequest
$request, User
$user = null ) {
245 $context = new DerivativeContext( $this );
246 $context->setRequest( $request );
247 if ( $user !== null ) {
248 $context->setUser( $user );