|
|
@@ -0,0 +1,128 @@ |
|
|
|
<?php |
|
|
|
|
|
|
|
use OCA\user_ldap\lib\user\User; |
|
|
|
use OCA\User_LDAP\Mapping\UserMapping; |
|
|
|
use OCA\user_ldap\tests\integration\AbstractIntegrationTest; |
|
|
|
|
|
|
|
require_once __DIR__ . '/../../../../../../lib/base.php'; |
|
|
|
|
|
|
|
class IntegrationTestUserAvatar extends AbstractIntegrationTest { |
|
|
|
/** @var UserMapping */ |
|
|
|
protected $mapping; |
|
|
|
|
|
|
|
/** |
|
|
|
* prepares the LDAP environment and sets up a test configuration for |
|
|
|
* the LDAP backend. |
|
|
|
*/ |
|
|
|
public function init() { |
|
|
|
require(__DIR__ . '/../../setup-scripts/createExplicitUsers.php'); |
|
|
|
parent::init(); |
|
|
|
$this->mapping = new UserMapping(\OC::$server->getDatabaseConnection()); |
|
|
|
$this->mapping->clear(); |
|
|
|
$this->access->setUserMapper($this->mapping); |
|
|
|
$userBackend = new OCA\user_ldap\USER_LDAP($this->access, \OC::$server->getConfig()); |
|
|
|
\OC_User::useBackend($userBackend); |
|
|
|
} |
|
|
|
|
|
|
|
/** |
|
|
|
* A method that does the common steps of test cases 1 and 2. The evaluation |
|
|
|
* is not happening here. |
|
|
|
* |
|
|
|
* @param string $dn |
|
|
|
* @param string $username |
|
|
|
* @param string $image |
|
|
|
*/ |
|
|
|
private function execFetchTest($dn, $username, $image) { |
|
|
|
$this->setJpegPhotoAttribute($dn, $image); |
|
|
|
|
|
|
|
// assigns our self-picked oc username to the dn |
|
|
|
$this->mapping->map($dn, $username, 'fakeUUID-' . $username); |
|
|
|
|
|
|
|
// initialize home folder and make sure that the user will update |
|
|
|
// also remove an possibly existing avatar |
|
|
|
\OC_Util::tearDownFS(); |
|
|
|
\OC_Util::setupFS($username); |
|
|
|
\OC::$server->getUserFolder($username); |
|
|
|
\OC::$server->getConfig()->deleteUserValue($username, 'user_ldap', User::USER_PREFKEY_LASTREFRESH); |
|
|
|
if(\OC::$server->getAvatarManager()->getAvatar($username)->exists()) { |
|
|
|
\OC::$server->getAvatarManager()->getAvatar($username)->remove(); |
|
|
|
} |
|
|
|
|
|
|
|
// finally attempt to get the avatar set |
|
|
|
$user = $this->userManager->get($dn); |
|
|
|
$user->updateAvatar(); |
|
|
|
} |
|
|
|
|
|
|
|
/** |
|
|
|
* tests whether an avatar can be retrieved from LDAP and stored correctly |
|
|
|
* |
|
|
|
* @return bool |
|
|
|
*/ |
|
|
|
protected function case1() { |
|
|
|
$image = file_get_contents(__DIR__ . '/../../data/avatar-valid.jpg'); |
|
|
|
$dn = 'uid=alice,ou=Users,' . $this->base; |
|
|
|
$username = 'alice1337'; |
|
|
|
|
|
|
|
$this->execFetchTest($dn, $username, $image); |
|
|
|
|
|
|
|
return \OC::$server->getAvatarManager()->getAvatar($username)->exists(); |
|
|
|
} |
|
|
|
|
|
|
|
/** |
|
|
|
* tests whether an image received from LDAP which is of an invalid file |
|
|
|
* type is dealt with properly (i.e. not set and not dying). |
|
|
|
* |
|
|
|
* @return bool |
|
|
|
*/ |
|
|
|
protected function case2() { |
|
|
|
// gif by Pmspinner from https://commons.wikimedia.org/wiki/File:Avatar2469_3.gif |
|
|
|
$image = file_get_contents(__DIR__ . '/../../data/avatar-invalid.gif'); |
|
|
|
$dn = 'uid=boris,ou=Users,' . $this->base; |
|
|
|
$username = 'boris7844'; |
|
|
|
|
|
|
|
$this->execFetchTest($dn, $username, $image); |
|
|
|
|
|
|
|
return !\OC::$server->getAvatarManager()->getAvatar($username)->exists(); |
|
|
|
} |
|
|
|
|
|
|
|
/** |
|
|
|
* This writes an image to the 'jpegPhoto' attribute on LDAP. |
|
|
|
* |
|
|
|
* @param string $dn |
|
|
|
* @param string $image An image read via file_get_contents |
|
|
|
* @throws \OC\ServerNotAvailableException |
|
|
|
*/ |
|
|
|
private function setJpegPhotoAttribute($dn, $image) { |
|
|
|
$changeSet = ['jpegphoto' => $image]; |
|
|
|
ldap_mod_add($this->connection->getConnectionResource(), $dn, $changeSet); |
|
|
|
} |
|
|
|
|
|
|
|
protected function initUserManager() { |
|
|
|
$this->userManager = new \OCA\user_ldap\lib\user\Manager( |
|
|
|
\OC::$server->getConfig(), |
|
|
|
new \OCA\user_ldap\lib\FilesystemHelper(), |
|
|
|
new \OCA\user_ldap\lib\LogWrapper(), |
|
|
|
\OC::$server->getAvatarManager(), |
|
|
|
new \OCP\Image(), |
|
|
|
\OC::$server->getDatabaseConnection() |
|
|
|
); |
|
|
|
} |
|
|
|
|
|
|
|
/** |
|
|
|
* sets up the LDAP configuration to be used for the test |
|
|
|
*/ |
|
|
|
protected function initConnection() { |
|
|
|
parent::initConnection(); |
|
|
|
$this->connection->setConfiguration([ |
|
|
|
'ldapUserFilter' => 'objectclass=inetOrgPerson', |
|
|
|
'ldapUserDisplayName' => 'displayName', |
|
|
|
'ldapGroupDisplayName' => 'cn', |
|
|
|
'ldapLoginFilter' => 'uid=%uid', |
|
|
|
]); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
require_once(__DIR__ . '/../../setup-scripts/config.php'); |
|
|
|
$test = new IntegrationTestUserAvatar($host, $port, $adn, $apwd, $bdn); |
|
|
|
$test->init(); |
|
|
|
$test->run(); |