2011-04-06 19:50:54 +00:00
|
|
|
<?php
|
|
|
|
|
|
2013-10-21 21:09:13 +00:00
|
|
|
/**
|
2014-04-24 12:50:36 +00:00
|
|
|
* Wraps the user object, so we can also retain full access to properties
|
|
|
|
|
* like password if we log in via the API.
|
2013-10-21 21:09:13 +00:00
|
|
|
*/
|
2012-09-11 00:07:18 +00:00
|
|
|
class TestUser {
|
2014-10-18 13:29:29 +00:00
|
|
|
/**
|
|
|
|
|
* @deprecated Since 1.25. Use TestUser::getUser()->getName()
|
|
|
|
|
* @private
|
|
|
|
|
* @var string
|
|
|
|
|
*/
|
2011-04-06 19:50:54 +00:00
|
|
|
public $username;
|
2014-10-18 13:29:29 +00:00
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @deprecated Since 1.25. Use TestUser::getPassword()
|
|
|
|
|
* @private
|
|
|
|
|
* @var string
|
|
|
|
|
*/
|
2011-04-06 19:50:54 +00:00
|
|
|
public $password;
|
2014-10-18 13:29:29 +00:00
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @deprecated Since 1.25. Use TestUser::getUser()
|
|
|
|
|
* @private
|
|
|
|
|
* @var User
|
|
|
|
|
*/
|
2011-04-06 19:50:54 +00:00
|
|
|
public $user;
|
|
|
|
|
|
2014-10-18 13:29:29 +00:00
|
|
|
private function assertNotReal() {
|
|
|
|
|
global $wgDBprefix;
|
2014-10-30 16:50:19 +00:00
|
|
|
if ( $wgDBprefix !== MediaWikiTestCase::DB_PREFIX && $wgDBprefix !== MediaWikiTestCase::ORA_DB_PREFIX ) {
|
2014-10-18 13:29:29 +00:00
|
|
|
throw new MWException( "Can't create user on real database" );
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2014-04-24 12:50:36 +00:00
|
|
|
public function __construct( $username, $realname = 'Real Name',
|
|
|
|
|
$email = 'sample@example.com', $groups = array()
|
|
|
|
|
) {
|
2014-10-18 13:29:29 +00:00
|
|
|
$this->assertNotReal();
|
2011-04-06 19:50:54 +00:00
|
|
|
|
2014-10-18 13:29:29 +00:00
|
|
|
$this->username = $username;
|
|
|
|
|
$this->password = 'TestUser';
|
2011-04-06 19:50:54 +00:00
|
|
|
|
|
|
|
|
$this->user = User::newFromName( $this->username );
|
|
|
|
|
$this->user->load();
|
|
|
|
|
|
|
|
|
|
// In an ideal world we'd have a new wiki (or mock data store) for every single test.
|
|
|
|
|
// But for now, we just need to create or update the user with the desired properties.
|
|
|
|
|
// we particularly need the new password, since we just generated it randomly.
|
|
|
|
|
// In core MediaWiki, there is no functionality to delete users, so this is the best we can do.
|
2014-10-18 13:29:29 +00:00
|
|
|
if ( !$this->user->isLoggedIn() ) {
|
2011-04-06 19:50:54 +00:00
|
|
|
// create the user
|
|
|
|
|
$this->user = User::createNew(
|
|
|
|
|
$this->username, array(
|
2014-10-18 13:29:29 +00:00
|
|
|
"email" => $email,
|
|
|
|
|
"real_name" => $realname
|
2011-04-06 19:50:54 +00:00
|
|
|
)
|
|
|
|
|
);
|
2014-10-18 13:29:29 +00:00
|
|
|
|
2011-04-06 19:50:54 +00:00
|
|
|
if ( !$this->user ) {
|
2014-10-18 13:29:29 +00:00
|
|
|
throw new MWException( "Error creating TestUser " . $username );
|
2011-04-06 19:50:54 +00:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2014-10-18 13:29:29 +00:00
|
|
|
// Update the user to use the password and other details
|
2014-10-19 22:22:02 +00:00
|
|
|
$change = $this->setPassword( $this->password ) ||
|
|
|
|
|
$this->setEmail( $email ) ||
|
|
|
|
|
$this->setRealName( $realname );
|
2013-12-05 17:41:24 +00:00
|
|
|
|
|
|
|
|
// Adjust groups by adding any missing ones and removing any extras
|
|
|
|
|
$currentGroups = $this->user->getGroups();
|
2014-10-18 13:29:29 +00:00
|
|
|
foreach ( array_diff( $groups, $currentGroups ) as $group ) {
|
2013-12-05 17:41:24 +00:00
|
|
|
$this->user->addGroup( $group );
|
2011-04-06 19:50:54 +00:00
|
|
|
}
|
2014-10-18 13:29:29 +00:00
|
|
|
foreach ( array_diff( $currentGroups, $groups ) as $group ) {
|
2013-12-05 17:41:24 +00:00
|
|
|
$this->user->removeGroup( $group );
|
2011-04-06 19:50:54 +00:00
|
|
|
}
|
2014-10-19 22:22:02 +00:00
|
|
|
if ( $change ) {
|
|
|
|
|
$this->user->saveSettings();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @param string $realname
|
|
|
|
|
* @return bool
|
|
|
|
|
*/
|
|
|
|
|
private function setRealName( $realname ) {
|
|
|
|
|
if ( $this->user->getRealName() !== $realname ) {
|
|
|
|
|
$this->user->setRealName( $realname );
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @param string $email
|
|
|
|
|
* @return bool
|
|
|
|
|
*/
|
|
|
|
|
private function setEmail( $email ) {
|
|
|
|
|
if ( $this->user->getEmail() !== $email ) {
|
|
|
|
|
$this->user->setEmail( $email );
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @param string $password
|
|
|
|
|
* @return bool
|
|
|
|
|
*/
|
|
|
|
|
private function setPassword( $password ) {
|
|
|
|
|
$passwordFactory = $this->user->getPasswordFactory();
|
|
|
|
|
$oldDefaultType = $passwordFactory->getDefaultType();
|
|
|
|
|
|
2014-10-30 16:50:19 +00:00
|
|
|
// A is unsalted MD5 (thus fast) ... we don't care about security here, this is test only
|
2014-10-19 23:54:16 +00:00
|
|
|
$passwordFactory->setDefaultType( 'A' );
|
2014-10-30 16:50:19 +00:00
|
|
|
$newPassword = $passwordFactory->newFromPlaintext( $password, $this->user->getPassword() );
|
2014-10-19 22:22:02 +00:00
|
|
|
|
|
|
|
|
$change = false;
|
|
|
|
|
if ( !$this->user->getPassword()->equals( $newPassword ) ) {
|
|
|
|
|
// Password changed
|
|
|
|
|
$this->user->setPassword( $password );
|
|
|
|
|
$change = true;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$passwordFactory->setDefaultType( $oldDefaultType );
|
|
|
|
|
|
|
|
|
|
return $change;
|
2011-04-06 19:50:54 +00:00
|
|
|
}
|
2014-10-18 13:29:29 +00:00
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @return User
|
|
|
|
|
*/
|
|
|
|
|
public function getUser() {
|
|
|
|
|
return $this->user;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @return string
|
|
|
|
|
*/
|
|
|
|
|
public function getPassword() {
|
|
|
|
|
return $this->password;
|
|
|
|
|
}
|
2011-04-06 19:50:54 +00:00
|
|
|
}
|