2012-08-08 13:58:47 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @group Database
|
|
|
|
|
* @group API
|
2013-01-18 19:02:28 +00:00
|
|
|
* @group medium
|
2013-10-23 16:01:33 +00:00
|
|
|
*
|
|
|
|
|
* @covers ApiCreateAccount
|
2012-08-08 13:58:47 +00:00
|
|
|
*/
|
|
|
|
|
class ApiCreateAccountTest extends ApiTestCase {
|
2013-10-23 16:01:33 +00:00
|
|
|
protected function setUp() {
|
2012-08-08 13:58:47 +00:00
|
|
|
parent::setUp();
|
2016-02-17 09:09:32 +00:00
|
|
|
$this->setMwGlobals( [ 'wgEnableEmail' => true ] );
|
2012-08-08 13:58:47 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Test the account creation API with a valid request. Also
|
|
|
|
|
* make sure the new account can log in and is valid.
|
2013-01-11 09:46:18 +00:00
|
|
|
*
|
|
|
|
|
* This test does multiple API requests so it might end up being
|
|
|
|
|
* a bit slow. Raise the default timeout.
|
|
|
|
|
* @group medium
|
2012-08-08 13:58:47 +00:00
|
|
|
*/
|
2013-10-23 22:51:31 +00:00
|
|
|
public function testValid() {
|
2012-08-08 13:58:47 +00:00
|
|
|
global $wgServer;
|
|
|
|
|
|
|
|
|
|
if ( !isset( $wgServer ) ) {
|
|
|
|
|
$this->markTestIncomplete( 'This test needs $wgServer to be set in LocalSettings.php' );
|
|
|
|
|
}
|
|
|
|
|
|
2015-09-04 16:17:42 +00:00
|
|
|
$password = PasswordFactory::generateRandomPasswordString();
|
2012-08-08 13:58:47 +00:00
|
|
|
|
2016-02-17 09:09:32 +00:00
|
|
|
$ret = $this->doApiRequest( [
|
2012-08-08 13:58:47 +00:00
|
|
|
'action' => 'createaccount',
|
|
|
|
|
'name' => 'Apitestnew',
|
|
|
|
|
'password' => $password,
|
2013-01-13 10:10:55 +00:00
|
|
|
'email' => 'test@domain.test',
|
2012-08-08 13:58:47 +00:00
|
|
|
'realname' => 'Test Name'
|
2016-02-17 09:09:32 +00:00
|
|
|
] );
|
2012-08-08 13:58:47 +00:00
|
|
|
|
|
|
|
|
$result = $ret[0];
|
|
|
|
|
$this->assertNotInternalType( 'bool', $result );
|
|
|
|
|
$this->assertNotInternalType( 'null', $result['createaccount'] );
|
|
|
|
|
|
|
|
|
|
// Should first ask for token.
|
|
|
|
|
$a = $result['createaccount'];
|
2014-02-20 15:06:59 +00:00
|
|
|
$this->assertEquals( 'NeedToken', $a['result'] );
|
2012-08-08 13:58:47 +00:00
|
|
|
$token = $a['token'];
|
|
|
|
|
|
|
|
|
|
// Finally create the account
|
2013-04-26 12:00:22 +00:00
|
|
|
$ret = $this->doApiRequest(
|
2016-02-17 09:09:32 +00:00
|
|
|
[
|
2013-04-26 12:00:22 +00:00
|
|
|
'action' => 'createaccount',
|
|
|
|
|
'name' => 'Apitestnew',
|
|
|
|
|
'password' => $password,
|
|
|
|
|
'token' => $token,
|
|
|
|
|
'email' => 'test@domain.test',
|
|
|
|
|
'realname' => 'Test Name'
|
2016-02-17 09:09:32 +00:00
|
|
|
],
|
2013-04-26 12:00:22 +00:00
|
|
|
$ret[2]
|
2012-08-08 13:58:47 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
|
|
$result = $ret[0];
|
|
|
|
|
$this->assertNotInternalType( 'bool', $result );
|
2014-02-20 15:06:59 +00:00
|
|
|
$this->assertEquals( 'Success', $result['createaccount']['result'] );
|
2012-08-08 13:58:47 +00:00
|
|
|
|
|
|
|
|
// Try logging in with the new user.
|
2016-02-17 09:09:32 +00:00
|
|
|
$ret = $this->doApiRequest( [
|
2012-08-08 13:58:47 +00:00
|
|
|
'action' => 'login',
|
|
|
|
|
'lgname' => 'Apitestnew',
|
|
|
|
|
'lgpassword' => $password,
|
2016-02-17 09:09:32 +00:00
|
|
|
] );
|
2012-08-08 13:58:47 +00:00
|
|
|
|
|
|
|
|
$result = $ret[0];
|
|
|
|
|
$this->assertNotInternalType( 'bool', $result );
|
|
|
|
|
$this->assertNotInternalType( 'null', $result['login'] );
|
|
|
|
|
|
|
|
|
|
$a = $result['login']['result'];
|
|
|
|
|
$this->assertEquals( 'NeedToken', $a );
|
|
|
|
|
$token = $result['login']['token'];
|
|
|
|
|
|
2013-03-25 23:27:14 +00:00
|
|
|
$ret = $this->doApiRequest(
|
2016-02-17 09:09:32 +00:00
|
|
|
[
|
2013-03-25 23:27:14 +00:00
|
|
|
'action' => 'login',
|
|
|
|
|
'lgtoken' => $token,
|
|
|
|
|
'lgname' => 'Apitestnew',
|
|
|
|
|
'lgpassword' => $password,
|
2016-02-17 09:09:32 +00:00
|
|
|
],
|
2013-03-25 23:27:14 +00:00
|
|
|
$ret[2]
|
2012-08-08 13:58:47 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
|
|
$result = $ret[0];
|
|
|
|
|
|
|
|
|
|
$this->assertNotInternalType( 'bool', $result );
|
|
|
|
|
$a = $result['login']['result'];
|
|
|
|
|
|
|
|
|
|
$this->assertEquals( 'Success', $a );
|
2013-01-13 10:10:55 +00:00
|
|
|
|
|
|
|
|
// log out to destroy the session
|
2013-03-25 23:27:14 +00:00
|
|
|
$ret = $this->doApiRequest(
|
2016-02-17 09:09:32 +00:00
|
|
|
[
|
2013-03-25 23:27:14 +00:00
|
|
|
'action' => 'logout',
|
2016-02-17 09:09:32 +00:00
|
|
|
],
|
2013-03-25 23:27:14 +00:00
|
|
|
$ret[2]
|
2013-01-13 10:10:55 +00:00
|
|
|
);
|
2016-02-17 09:09:32 +00:00
|
|
|
$this->assertEquals( [], $ret[0] );
|
2012-08-08 13:58:47 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Make sure requests with no names are invalid.
|
|
|
|
|
* @expectedException UsageException
|
|
|
|
|
*/
|
2013-10-23 22:51:31 +00:00
|
|
|
public function testNoName() {
|
2016-02-17 09:09:32 +00:00
|
|
|
$this->doApiRequest( [
|
2012-08-08 13:58:47 +00:00
|
|
|
'action' => 'createaccount',
|
2016-02-01 20:44:03 +00:00
|
|
|
'token' => LoginForm::getCreateaccountToken()->toString(),
|
2012-08-08 13:58:47 +00:00
|
|
|
'password' => 'password',
|
2016-02-17 09:09:32 +00:00
|
|
|
] );
|
2012-08-08 13:58:47 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Make sure requests with no password are invalid.
|
|
|
|
|
* @expectedException UsageException
|
|
|
|
|
*/
|
2013-10-23 22:51:31 +00:00
|
|
|
public function testNoPassword() {
|
2016-02-17 09:09:32 +00:00
|
|
|
$this->doApiRequest( [
|
2012-08-08 13:58:47 +00:00
|
|
|
'action' => 'createaccount',
|
|
|
|
|
'name' => 'testName',
|
2016-02-01 20:44:03 +00:00
|
|
|
'token' => LoginForm::getCreateaccountToken()->toString(),
|
2016-02-17 09:09:32 +00:00
|
|
|
] );
|
2012-08-08 13:58:47 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Make sure requests with existing users are invalid.
|
|
|
|
|
* @expectedException UsageException
|
|
|
|
|
*/
|
2013-10-23 22:51:31 +00:00
|
|
|
public function testExistingUser() {
|
2016-02-17 09:09:32 +00:00
|
|
|
$this->doApiRequest( [
|
2012-08-08 13:58:47 +00:00
|
|
|
'action' => 'createaccount',
|
|
|
|
|
'name' => 'Apitestsysop',
|
2016-02-01 20:44:03 +00:00
|
|
|
'token' => LoginForm::getCreateaccountToken()->toString(),
|
2012-08-08 13:58:47 +00:00
|
|
|
'password' => 'password',
|
|
|
|
|
'email' => 'test@domain.test',
|
2016-02-17 09:09:32 +00:00
|
|
|
] );
|
2012-08-08 13:58:47 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Make sure requests with invalid emails are invalid.
|
|
|
|
|
* @expectedException UsageException
|
|
|
|
|
*/
|
2013-10-23 22:51:31 +00:00
|
|
|
public function testInvalidEmail() {
|
2016-02-17 09:09:32 +00:00
|
|
|
$this->doApiRequest( [
|
2012-08-08 13:58:47 +00:00
|
|
|
'action' => 'createaccount',
|
|
|
|
|
'name' => 'Test User',
|
2016-02-01 20:44:03 +00:00
|
|
|
'token' => LoginForm::getCreateaccountToken()->toString(),
|
2012-08-08 13:58:47 +00:00
|
|
|
'password' => 'password',
|
2013-01-13 10:10:55 +00:00
|
|
|
'email' => 'invalid',
|
2016-02-17 09:09:32 +00:00
|
|
|
] );
|
2012-08-08 13:58:47 +00:00
|
|
|
}
|
|
|
|
|
}
|