1222 lines
34 KiB
PHP
1222 lines
34 KiB
PHP
<?php
|
|
/**
|
|
* @copyright Copyright (c) 2016, ownCloud, Inc.
|
|
*
|
|
* @author Arthur Schiwon <blizzz@arthur-schiwon.de>
|
|
* @author Joas Schilling <coding@schilljs.com>
|
|
* @author Juan Pablo Villafáñez <jvillafanez@solidgear.es>
|
|
* @author Morris Jobke <hey@morrisjobke.de>
|
|
* @author Roeland Jago Douma <roeland@famdouma.nl>
|
|
* @author Roger Szabo <roger.szabo@web.de>
|
|
* @author Thomas Müller <thomas.mueller@tmit.eu>
|
|
* @author Victor Dubiniuk <dubiniuk@owncloud.com>
|
|
*
|
|
* @license AGPL-3.0
|
|
*
|
|
* This code is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU Affero General Public License, version 3,
|
|
* as published by the Free Software Foundation.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU Affero General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Affero General Public License, version 3,
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>
|
|
*
|
|
*/
|
|
|
|
namespace OCA\User_LDAP\Tests\User;
|
|
|
|
use OCA\User_LDAP\Access;
|
|
use OCA\User_LDAP\Connection;
|
|
use OCA\User_LDAP\FilesystemHelper;
|
|
use OCA\User_LDAP\LogWrapper;
|
|
use OCA\User_LDAP\User\IUserTools;
|
|
use OCA\User_LDAP\User\User;
|
|
use OCP\IAvatar;
|
|
use OCP\IAvatarManager;
|
|
use OCP\IConfig;
|
|
use OCP\Image;
|
|
use OCP\IUser;
|
|
use OCP\IUserManager;
|
|
use OCP\Notification\IManager as INotificationManager;
|
|
use OCP\Notification\INotification;
|
|
|
|
/**
|
|
* Class UserTest
|
|
*
|
|
* @group DB
|
|
*
|
|
* @package OCA\User_LDAP\Tests\User
|
|
*/
|
|
class UserTest extends \Test\TestCase {
|
|
/** @var Access|\PHPUnit_Framework_MockObject_MockObject */
|
|
protected $access;
|
|
/** @var Connection|\PHPUnit_Framework_MockObject_MockObject */
|
|
protected $connection;
|
|
|
|
public function setUp() {
|
|
/** @var Access|\PHPUnit_Framework_MockObject_MockObject access */
|
|
$this->access = $this->createMock(Access::class);
|
|
$this->connection = $this->createMock(Connection::class);
|
|
|
|
$this->access->connection = $this->connection;
|
|
$this->access->expects($this->any())
|
|
->method('getConnection')
|
|
->willReturn($this->connection);
|
|
|
|
parent::setUp();
|
|
}
|
|
|
|
private function getTestInstances() {
|
|
$access = $this->createMock(IUserTools::class);
|
|
$config = $this->createMock(IConfig::class);
|
|
$filesys = $this->createMock(FilesystemHelper::class);
|
|
$log = $this->createMock(LogWrapper::class);
|
|
$avaMgr = $this->createMock(IAvatarManager::class);
|
|
$image = $this->createMock(Image::class);
|
|
$userMgr = $this->createMock(IUserManager::class);
|
|
$notiMgr = $this->createMock(INotificationManager::class);
|
|
|
|
return array($access, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr);
|
|
}
|
|
|
|
public function testGetDNandUsername() {
|
|
list($access, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr) =
|
|
$this->getTestInstances();
|
|
|
|
$uid = 'alice';
|
|
$dn = 'uid=alice,dc=foo,dc=bar';
|
|
|
|
$user = new User(
|
|
$uid, $dn, $access, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr);
|
|
|
|
$this->assertSame($dn, $user->getDN());
|
|
$this->assertSame($uid, $user->getUsername());
|
|
}
|
|
|
|
public function testUpdateEmailProvided() {
|
|
list(, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr) =
|
|
$this->getTestInstances();
|
|
|
|
$this->connection->expects($this->once())
|
|
->method('__get')
|
|
->with($this->equalTo('ldapEmailAttribute'))
|
|
->will($this->returnValue('email'));
|
|
|
|
$this->access->expects($this->once())
|
|
->method('readAttribute')
|
|
->with($this->equalTo('uid=alice,dc=foo,dc=bar'),
|
|
$this->equalTo('email'))
|
|
->will($this->returnValue(array('alice@foo.bar')));
|
|
|
|
$uid = 'alice';
|
|
$dn = 'uid=alice,dc=foo,dc=bar';
|
|
|
|
$uuser = $this->getMockBuilder(IUser::class)
|
|
->disableOriginalConstructor()
|
|
->getMock();
|
|
$uuser->expects($this->once())
|
|
->method('setEMailAddress')
|
|
->with('alice@foo.bar');
|
|
/** @var IUserManager | \PHPUnit_Framework_MockObject_MockObject $userMgr */
|
|
$userMgr->expects($this->any())
|
|
->method('get')
|
|
->willReturn($uuser);
|
|
$user = new User(
|
|
$uid, $dn, $this->access, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr);
|
|
|
|
$user->updateEmail();
|
|
}
|
|
|
|
public function testUpdateEmailNotProvided() {
|
|
list(, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr) =
|
|
$this->getTestInstances();
|
|
|
|
$this->connection->expects($this->once())
|
|
->method('__get')
|
|
->with($this->equalTo('ldapEmailAttribute'))
|
|
->will($this->returnValue('email'));
|
|
$this->access->expects($this->once())
|
|
->method('readAttribute')
|
|
->with($this->equalTo('uid=alice,dc=foo,dc=bar'),
|
|
$this->equalTo('email'))
|
|
->will($this->returnValue(false));
|
|
|
|
$config->expects($this->never())
|
|
->method('setUserValue');
|
|
|
|
$uid = 'alice';
|
|
$dn = 'uid=alice,dc=foo,dc=bar';
|
|
|
|
$user = new User(
|
|
$uid, $dn, $this->access, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr);
|
|
|
|
$user->updateEmail();
|
|
}
|
|
|
|
public function testUpdateEmailNotConfigured() {
|
|
list(, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr) =
|
|
$this->getTestInstances();
|
|
|
|
$this->connection->expects($this->once())
|
|
->method('__get')
|
|
->with($this->equalTo('ldapEmailAttribute'))
|
|
->will($this->returnValue(''));
|
|
|
|
$this->access->expects($this->never())
|
|
->method('readAttribute');
|
|
|
|
$config->expects($this->never())
|
|
->method('setUserValue');
|
|
|
|
$uid = 'alice';
|
|
$dn = 'uid=alice,dc=foo,dc=bar';
|
|
|
|
$user = new User(
|
|
$uid, $dn, $this->access, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr);
|
|
|
|
$user->updateEmail();
|
|
}
|
|
|
|
public function testUpdateQuotaAllProvided() {
|
|
list(, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr) =
|
|
$this->getTestInstances();
|
|
|
|
$this->connection->expects($this->exactly(2))
|
|
->method('__get')
|
|
->willReturnMap([
|
|
['ldapQuotaAttribute', 'myquota'],
|
|
['ldapQuotaDefault', '']
|
|
]);
|
|
|
|
$this->access->expects($this->once())
|
|
->method('readAttribute')
|
|
->with($this->equalTo('uid=alice,dc=foo,dc=bar'),
|
|
$this->equalTo('myquota'))
|
|
->will($this->returnValue(array('42 GB')));
|
|
|
|
$user = $this->createMock(IUser::class);
|
|
$user->expects($this->once())
|
|
->method('setQuota')
|
|
->with('42 GB');
|
|
|
|
$userMgr->expects($this->atLeastOnce())
|
|
->method('get')
|
|
->with('alice')
|
|
->will($this->returnValue($user));
|
|
|
|
$uid = 'alice';
|
|
$dn = 'uid=alice,dc=foo,dc=bar';
|
|
|
|
$user = new User(
|
|
$uid, $dn, $this->access, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr);
|
|
|
|
$user->updateQuota();
|
|
}
|
|
|
|
public function testUpdateQuotaToDefaultAllProvided() {
|
|
list(, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr) =
|
|
$this->getTestInstances();
|
|
|
|
$this->connection->expects($this->exactly(2))
|
|
->method('__get')
|
|
->willReturnMap([
|
|
['ldapQuotaAttribute', 'myquota'],
|
|
['ldapQuotaDefault', '']
|
|
]);
|
|
|
|
$this->access->expects($this->once())
|
|
->method('readAttribute')
|
|
->with($this->equalTo('uid=alice,dc=foo,dc=bar'),
|
|
$this->equalTo('myquota'))
|
|
->will($this->returnValue(array('default')));
|
|
|
|
$user = $this->createMock('\OCP\IUser');
|
|
$user->expects($this->once())
|
|
->method('setQuota')
|
|
->with('default');
|
|
|
|
$userMgr->expects($this->once())
|
|
->method('get')
|
|
->with('alice')
|
|
->will($this->returnValue($user));
|
|
|
|
$uid = 'alice';
|
|
$dn = 'uid=alice,dc=foo,dc=bar';
|
|
|
|
$user = new User(
|
|
$uid, $dn, $this->access, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr);
|
|
|
|
$user->updateQuota();
|
|
}
|
|
|
|
public function testUpdateQuotaToNoneAllProvided() {
|
|
list(, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr) =
|
|
$this->getTestInstances();
|
|
|
|
$this->connection->expects($this->exactly(2))
|
|
->method('__get')
|
|
->willReturnMap([
|
|
['ldapQuotaAttribute', 'myquota'],
|
|
['ldapQuotaDefault', '']
|
|
]);
|
|
|
|
$this->access->expects($this->once())
|
|
->method('readAttribute')
|
|
->with($this->equalTo('uid=alice,dc=foo,dc=bar'),
|
|
$this->equalTo('myquota'))
|
|
->will($this->returnValue(array('none')));
|
|
|
|
$user = $this->createMock('\OCP\IUser');
|
|
$user->expects($this->once())
|
|
->method('setQuota')
|
|
->with('none');
|
|
|
|
$userMgr->expects($this->once())
|
|
->method('get')
|
|
->with('alice')
|
|
->will($this->returnValue($user));
|
|
|
|
$uid = 'alice';
|
|
$dn = 'uid=alice,dc=foo,dc=bar';
|
|
|
|
$user = new User(
|
|
$uid, $dn, $this->access, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr);
|
|
|
|
$user->updateQuota();
|
|
}
|
|
|
|
public function testUpdateQuotaDefaultProvided() {
|
|
list(, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr) =
|
|
$this->getTestInstances();
|
|
|
|
$this->connection->expects($this->at(0))
|
|
->method('__get')
|
|
->with($this->equalTo('ldapQuotaAttribute'))
|
|
->will($this->returnValue('myquota'));
|
|
$this->connection->expects($this->at(1))
|
|
->method('__get')
|
|
->with($this->equalTo('ldapQuotaDefault'))
|
|
->will($this->returnValue('25 GB'));
|
|
$this->connection->expects($this->exactly(2))
|
|
->method('__get');
|
|
|
|
$this->access->expects($this->once())
|
|
->method('readAttribute')
|
|
->with($this->equalTo('uid=alice,dc=foo,dc=bar'),
|
|
$this->equalTo('myquota'))
|
|
->will($this->returnValue(false));
|
|
|
|
$user = $this->createMock(IUser::class);
|
|
$user->expects($this->once())
|
|
->method('setQuota')
|
|
->with('25 GB');
|
|
|
|
$userMgr->expects($this->once())
|
|
->method('get')
|
|
->with('alice')
|
|
->will($this->returnValue($user));
|
|
|
|
$uid = 'alice';
|
|
$dn = 'uid=alice,dc=foo,dc=bar';
|
|
|
|
$user = new User(
|
|
$uid, $dn, $this->access, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr);
|
|
|
|
$user->updateQuota();
|
|
}
|
|
|
|
public function testUpdateQuotaIndividualProvided() {
|
|
list(, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr) =
|
|
$this->getTestInstances();
|
|
|
|
$this->connection->expects($this->exactly(2))
|
|
->method('__get')
|
|
->willReturnMap([
|
|
['ldapQuotaAttribute', 'myquota'],
|
|
['ldapQuotaDefault', '']
|
|
]);
|
|
|
|
$this->access->expects($this->once())
|
|
->method('readAttribute')
|
|
->with($this->equalTo('uid=alice,dc=foo,dc=bar'),
|
|
$this->equalTo('myquota'))
|
|
->will($this->returnValue(array('27 GB')));
|
|
|
|
$user = $this->createMock(IUser::class);
|
|
$user->expects($this->once())
|
|
->method('setQuota')
|
|
->with('27 GB');
|
|
|
|
$userMgr->expects($this->once())
|
|
->method('get')
|
|
->with('alice')
|
|
->will($this->returnValue($user));
|
|
|
|
$uid = 'alice';
|
|
$dn = 'uid=alice,dc=foo,dc=bar';
|
|
|
|
$user = new User(
|
|
$uid, $dn, $this->access, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr);
|
|
|
|
$user->updateQuota();
|
|
}
|
|
|
|
public function testUpdateQuotaNoneProvided() {
|
|
list(, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr) =
|
|
$this->getTestInstances();
|
|
|
|
$this->connection->expects($this->exactly(2))
|
|
->method('__get')
|
|
->willReturnMap([
|
|
['ldapQuotaAttribute', 'myquota'],
|
|
['ldapQuotaDefault', '']
|
|
]);
|
|
|
|
$this->access->expects($this->once())
|
|
->method('readAttribute')
|
|
->with($this->equalTo('uid=alice,dc=foo,dc=bar'),
|
|
$this->equalTo('myquota'))
|
|
->will($this->returnValue(false));
|
|
|
|
$user = $this->createMock('\OCP\IUser');
|
|
$user->expects($this->never())
|
|
->method('setQuota');
|
|
|
|
$userMgr->expects($this->never())
|
|
->method('get')
|
|
->with('alice');
|
|
|
|
$config->expects($this->never())
|
|
->method('setUserValue');
|
|
|
|
$uid = 'alice';
|
|
$dn = 'uid=alice,dc=foo,dc=bar';
|
|
|
|
$user = new User(
|
|
$uid, $dn, $this->access, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr);
|
|
|
|
$user->updateQuota();
|
|
}
|
|
|
|
public function testUpdateQuotaNoneConfigured() {
|
|
list(, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr) =
|
|
$this->getTestInstances();
|
|
|
|
$this->connection->expects($this->exactly(2))
|
|
->method('__get')
|
|
->willReturnMap([
|
|
['ldapQuotaAttribute', ''],
|
|
['ldapQuotaDefault', '']
|
|
]);
|
|
|
|
$user = $this->createMock('\OCP\IUser');
|
|
$user->expects($this->never())
|
|
->method('setQuota');
|
|
|
|
$userMgr->expects($this->never())
|
|
->method('get');
|
|
|
|
$this->access->expects($this->never())
|
|
->method('readAttribute');
|
|
|
|
$config->expects($this->never())
|
|
->method('setUserValue');
|
|
|
|
$uid = 'alice';
|
|
$dn = 'uid=alice,dc=foo,dc=bar';
|
|
|
|
$user = new User(
|
|
$uid, $dn, $this->access, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr);
|
|
|
|
$user->updateQuota();
|
|
}
|
|
|
|
public function testUpdateQuotaFromValue() {
|
|
list(, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr) =
|
|
$this->getTestInstances();
|
|
|
|
$readQuota = '19 GB';
|
|
|
|
$this->connection->expects($this->exactly(2))
|
|
->method('__get')
|
|
->willReturnMap([
|
|
['ldapQuotaAttribute', 'myquota'],
|
|
['ldapQuotaDefault', '']
|
|
]);
|
|
|
|
$this->access->expects($this->never())
|
|
->method('readAttribute');
|
|
|
|
$user = $this->createMock(IUser::class);
|
|
$user->expects($this->once())
|
|
->method('setQuota')
|
|
->with($readQuota);
|
|
|
|
$userMgr->expects($this->once())
|
|
->method('get')
|
|
->with('alice')
|
|
->will($this->returnValue($user));
|
|
|
|
$uid = 'alice';
|
|
$dn = 'uid=alice,dc=foo,dc=bar';
|
|
|
|
$user = new User(
|
|
$uid, $dn, $this->access, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr);
|
|
|
|
$user->updateQuota($readQuota);
|
|
}
|
|
|
|
/**
|
|
* Unparseable quota will fallback to use the LDAP default
|
|
*/
|
|
public function testUpdateWrongQuotaAllProvided() {
|
|
list(, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr) =
|
|
$this->getTestInstances();
|
|
|
|
$this->connection->expects($this->exactly(2))
|
|
->method('__get')
|
|
->willReturnMap([
|
|
['ldapQuotaAttribute', 'myquota'],
|
|
['ldapQuotaDefault', '23 GB']
|
|
]);
|
|
|
|
$this->access->expects($this->once())
|
|
->method('readAttribute')
|
|
->with($this->equalTo('uid=alice,dc=foo,dc=bar'),
|
|
$this->equalTo('myquota'))
|
|
->will($this->returnValue(array('42 GBwos')));
|
|
|
|
$user = $this->createMock('\OCP\IUser');
|
|
$user->expects($this->once())
|
|
->method('setQuota')
|
|
->with('23 GB');
|
|
|
|
$userMgr->expects($this->once())
|
|
->method('get')
|
|
->with('alice')
|
|
->will($this->returnValue($user));
|
|
|
|
$uid = 'alice';
|
|
$dn = 'uid=alice,dc=foo,dc=bar';
|
|
|
|
$user = new User(
|
|
$uid, $dn, $this->access, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr);
|
|
|
|
$user->updateQuota();
|
|
}
|
|
|
|
/**
|
|
* No user quota and wrong default will set 'default' as quota
|
|
*/
|
|
public function testUpdateWrongDefaultQuotaProvided() {
|
|
list(, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr) =
|
|
$this->getTestInstances();
|
|
|
|
$this->connection->expects($this->exactly(2))
|
|
->method('__get')
|
|
->willReturnMap([
|
|
['ldapQuotaAttribute', 'myquota'],
|
|
['ldapQuotaDefault', '23 GBwowowo']
|
|
]);
|
|
|
|
$this->access->expects($this->once())
|
|
->method('readAttribute')
|
|
->with($this->equalTo('uid=alice,dc=foo,dc=bar'),
|
|
$this->equalTo('myquota'))
|
|
->will($this->returnValue(false));
|
|
|
|
$user = $this->createMock('\OCP\IUser');
|
|
$user->expects($this->never())
|
|
->method('setQuota');
|
|
|
|
$userMgr->expects($this->never())
|
|
->method('get');
|
|
|
|
$uid = 'alice';
|
|
$dn = 'uid=alice,dc=foo,dc=bar';
|
|
|
|
$user = new User(
|
|
$uid, $dn, $this->access, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr);
|
|
|
|
$user->updateQuota();
|
|
}
|
|
|
|
/**
|
|
* Wrong user quota and wrong default will set 'default' as quota
|
|
*/
|
|
public function testUpdateWrongQuotaAndDefaultAllProvided() {
|
|
list(, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr) =
|
|
$this->getTestInstances();
|
|
|
|
$this->connection->expects($this->exactly(2))
|
|
->method('__get')
|
|
->willReturnMap([
|
|
['ldapQuotaAttribute', 'myquota'],
|
|
['ldapQuotaDefault', '23 GBwowowo']
|
|
]);
|
|
|
|
$this->access->expects($this->once())
|
|
->method('readAttribute')
|
|
->with($this->equalTo('uid=alice,dc=foo,dc=bar'),
|
|
$this->equalTo('myquota'))
|
|
->will($this->returnValue(array('23 flush')));
|
|
|
|
$user = $this->createMock('\OCP\IUser');
|
|
$user->expects($this->never())
|
|
->method('setQuota');
|
|
|
|
$userMgr->expects($this->never())
|
|
->method('get');
|
|
|
|
$uid = 'alice';
|
|
$dn = 'uid=alice,dc=foo,dc=bar';
|
|
|
|
$user = new User(
|
|
$uid, $dn, $this->access, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr);
|
|
|
|
$user->updateQuota();
|
|
}
|
|
|
|
/**
|
|
* No quota attribute set and wrong default will set 'default' as quota
|
|
*/
|
|
public function testUpdateWrongDefaultQuotaNotProvided() {
|
|
list(, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr) =
|
|
$this->getTestInstances();
|
|
|
|
$this->connection->expects($this->exactly(2))
|
|
->method('__get')
|
|
->willReturnMap([
|
|
['ldapQuotaAttribute', ''],
|
|
['ldapQuotaDefault', '23 GBwowowo']
|
|
]);
|
|
|
|
$this->access->expects($this->never())
|
|
->method('readAttribute');
|
|
|
|
$user = $this->createMock('\OCP\IUser');
|
|
$user->expects($this->never())
|
|
->method('setQuota');
|
|
|
|
$userMgr->expects($this->never())
|
|
->method('get');
|
|
|
|
$uid = 'alice';
|
|
$dn = 'uid=alice,dc=foo,dc=bar';
|
|
|
|
$user = new User(
|
|
$uid, $dn, $this->access, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr);
|
|
|
|
$user->updateQuota();
|
|
}
|
|
|
|
//the testUpdateAvatar series also implicitely tests getAvatarImage
|
|
public function testUpdateAvatarJpegPhotoProvided() {
|
|
list(, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr) =
|
|
$this->getTestInstances();
|
|
|
|
$this->access->expects($this->once())
|
|
->method('readAttribute')
|
|
->with($this->equalTo('uid=alice,dc=foo,dc=bar'),
|
|
$this->equalTo('jpegPhoto'))
|
|
->will($this->returnValue(array('this is a photo')));
|
|
|
|
$image->expects($this->once())
|
|
->method('valid')
|
|
->will($this->returnValue(true));
|
|
$image->expects($this->once())
|
|
->method('width')
|
|
->will($this->returnValue(128));
|
|
$image->expects($this->once())
|
|
->method('height')
|
|
->will($this->returnValue(128));
|
|
$image->expects($this->once())
|
|
->method('centerCrop')
|
|
->will($this->returnValue(true));
|
|
|
|
$filesys->expects($this->once())
|
|
->method('isLoaded')
|
|
->will($this->returnValue(true));
|
|
|
|
$avatar = $this->createMock(IAvatar::class);
|
|
$avatar->expects($this->once())
|
|
->method('set')
|
|
->with($this->isInstanceOf($image));
|
|
|
|
$avaMgr->expects($this->once())
|
|
->method('getAvatar')
|
|
->with($this->equalTo('alice'))
|
|
->will($this->returnValue($avatar));
|
|
|
|
$uid = 'alice';
|
|
$dn = 'uid=alice,dc=foo,dc=bar';
|
|
|
|
$user = new User(
|
|
$uid, $dn, $this->access, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr);
|
|
|
|
$user->updateAvatar();
|
|
}
|
|
|
|
public function testUpdateAvatarThumbnailPhotoProvided() {
|
|
list(, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr) =
|
|
$this->getTestInstances();
|
|
|
|
$this->access->expects($this->any())
|
|
->method('readAttribute')
|
|
->willReturnCallback(function($dn, $attr) {
|
|
if($dn === 'uid=alice,dc=foo,dc=bar'
|
|
&& $attr === 'jpegPhoto')
|
|
{
|
|
return false;
|
|
} elseif($dn === 'uid=alice,dc=foo,dc=bar'
|
|
&& $attr === 'thumbnailPhoto')
|
|
{
|
|
return ['this is a photo'];
|
|
}
|
|
return null;
|
|
});
|
|
|
|
$image->expects($this->once())
|
|
->method('valid')
|
|
->will($this->returnValue(true));
|
|
$image->expects($this->once())
|
|
->method('width')
|
|
->will($this->returnValue(128));
|
|
$image->expects($this->once())
|
|
->method('height')
|
|
->will($this->returnValue(128));
|
|
$image->expects($this->once())
|
|
->method('centerCrop')
|
|
->will($this->returnValue(true));
|
|
|
|
$filesys->expects($this->once())
|
|
->method('isLoaded')
|
|
->will($this->returnValue(true));
|
|
|
|
$avatar = $this->createMock(IAvatar::class);
|
|
$avatar->expects($this->once())
|
|
->method('set')
|
|
->with($this->isInstanceOf($image));
|
|
|
|
$avaMgr->expects($this->once())
|
|
->method('getAvatar')
|
|
->with($this->equalTo('alice'))
|
|
->will($this->returnValue($avatar));
|
|
|
|
$uid = 'alice';
|
|
$dn = 'uid=alice,dc=foo,dc=bar';
|
|
|
|
$user = new User(
|
|
$uid, $dn, $this->access, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr);
|
|
|
|
$user->updateAvatar();
|
|
}
|
|
|
|
public function testUpdateAvatarNotProvided() {
|
|
list(, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr) =
|
|
$this->getTestInstances();
|
|
|
|
$this->access->expects($this->any())
|
|
->method('readAttribute')
|
|
->willReturnCallback(function($dn, $attr) {
|
|
if($dn === 'uid=alice,dc=foo,dc=bar'
|
|
&& $attr === 'jpegPhoto')
|
|
{
|
|
return false;
|
|
} elseif($dn === 'uid=alice,dc=foo,dc=bar'
|
|
&& $attr === 'thumbnailPhoto')
|
|
{
|
|
return false;
|
|
}
|
|
return null;
|
|
});
|
|
|
|
$image->expects($this->never())
|
|
->method('valid');
|
|
$image->expects($this->never())
|
|
->method('width');
|
|
$image->expects($this->never())
|
|
->method('height');
|
|
$image->expects($this->never())
|
|
->method('centerCrop');
|
|
|
|
$filesys->expects($this->never())
|
|
->method('isLoaded');
|
|
|
|
$avaMgr->expects($this->never())
|
|
->method('getAvatar');
|
|
|
|
$uid = 'alice';
|
|
$dn = 'uid=alice,dc=foo,dc=bar';
|
|
|
|
$user = new User(
|
|
$uid, $dn, $this->access, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr);
|
|
|
|
$user->updateAvatar();
|
|
}
|
|
|
|
public function testUpdateBeforeFirstLogin() {
|
|
list(, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr) =
|
|
$this->getTestInstances();
|
|
|
|
$config->expects($this->at(0))
|
|
->method('getUserValue')
|
|
->with($this->equalTo('alice'), $this->equalTo('user_ldap'),
|
|
$this->equalTo(User::USER_PREFKEY_FIRSTLOGIN),
|
|
$this->equalTo(0))
|
|
->will($this->returnValue(0));
|
|
$config->expects($this->at(1))
|
|
->method('getUserValue')
|
|
->with($this->equalTo('alice'), $this->equalTo('user_ldap'),
|
|
$this->equalTo(User::USER_PREFKEY_LASTREFRESH),
|
|
$this->equalTo(0))
|
|
->will($this->returnValue(0));
|
|
$config->expects($this->exactly(2))
|
|
->method('getUserValue');
|
|
$config->expects($this->never())
|
|
->method('setUserValue');
|
|
|
|
$uid = 'alice';
|
|
$dn = 'uid=alice,dc=foo,dc=bar';
|
|
|
|
$user = new User(
|
|
$uid, $dn, $this->access, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr);
|
|
|
|
$user->update();
|
|
}
|
|
|
|
public function testUpdateAfterFirstLogin() {
|
|
list(, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr) =
|
|
$this->getTestInstances();
|
|
|
|
$config->expects($this->at(0))
|
|
->method('getUserValue')
|
|
->with($this->equalTo('alice'), $this->equalTo('user_ldap'),
|
|
$this->equalTo(User::USER_PREFKEY_FIRSTLOGIN),
|
|
$this->equalTo(0))
|
|
->will($this->returnValue(1));
|
|
$config->expects($this->at(1))
|
|
->method('getUserValue')
|
|
->with($this->equalTo('alice'), $this->equalTo('user_ldap'),
|
|
$this->equalTo(User::USER_PREFKEY_LASTREFRESH),
|
|
$this->equalTo(0))
|
|
->will($this->returnValue(0));
|
|
$config->expects($this->exactly(2))
|
|
->method('getUserValue');
|
|
$config->expects($this->once())
|
|
->method('setUserValue')
|
|
->with($this->equalTo('alice'), $this->equalTo('user_ldap'),
|
|
$this->equalTo(User::USER_PREFKEY_LASTREFRESH),
|
|
$this->anything())
|
|
->will($this->returnValue(true));
|
|
|
|
$uid = 'alice';
|
|
$dn = 'uid=alice,dc=foo,dc=bar';
|
|
|
|
$user = new User(
|
|
$uid, $dn, $this->access, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr);
|
|
|
|
$user->update();
|
|
}
|
|
|
|
public function testUpdateNoRefresh() {
|
|
list(, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr) =
|
|
$this->getTestInstances();
|
|
|
|
$config->expects($this->at(0))
|
|
->method('getUserValue')
|
|
->with($this->equalTo('alice'), $this->equalTo('user_ldap'),
|
|
$this->equalTo(User::USER_PREFKEY_FIRSTLOGIN),
|
|
$this->equalTo(0))
|
|
->will($this->returnValue(1));
|
|
$config->expects($this->at(1))
|
|
->method('getUserValue')
|
|
->with($this->equalTo('alice'), $this->equalTo('user_ldap'),
|
|
$this->equalTo(User::USER_PREFKEY_LASTREFRESH),
|
|
$this->equalTo(0))
|
|
->will($this->returnValue(time() - 10));
|
|
|
|
$config->expects($this->once())
|
|
->method('getAppValue')
|
|
->with($this->equalTo('user_ldap'),
|
|
$this->equalTo('updateAttributesInterval'),
|
|
$this->anything())
|
|
->will($this->returnValue(1800));
|
|
$config->expects($this->exactly(2))
|
|
->method('getUserValue');
|
|
$config->expects($this->never())
|
|
->method('setUserValue');
|
|
|
|
$uid = 'alice';
|
|
$dn = 'uid=alice,dc=foo,dc=bar';
|
|
|
|
$user = new User(
|
|
$uid, $dn, $this->access, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr);
|
|
|
|
$user->update();
|
|
}
|
|
|
|
public function testMarkLogin() {
|
|
list(, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr) =
|
|
$this->getTestInstances();
|
|
|
|
$config->expects($this->once())
|
|
->method('setUserValue')
|
|
->with($this->equalTo('alice'),
|
|
$this->equalTo('user_ldap'),
|
|
$this->equalTo(User::USER_PREFKEY_FIRSTLOGIN),
|
|
$this->equalTo(1))
|
|
->will($this->returnValue(true));
|
|
|
|
$uid = 'alice';
|
|
$dn = 'uid=alice,dc=foo,dc=bar';
|
|
|
|
$user = new User(
|
|
$uid, $dn, $this->access, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr);
|
|
|
|
$user->markLogin();
|
|
}
|
|
|
|
public function testGetAvatarImageProvided() {
|
|
list(, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr) =
|
|
$this->getTestInstances();
|
|
|
|
$this->access->expects($this->once())
|
|
->method('readAttribute')
|
|
->with($this->equalTo('uid=alice,dc=foo,dc=bar'),
|
|
$this->equalTo('jpegPhoto'))
|
|
->will($this->returnValue(array('this is a photo')));
|
|
|
|
$uid = 'alice';
|
|
$dn = 'uid=alice,dc=foo,dc=bar';
|
|
|
|
$user = new User(
|
|
$uid, $dn, $this->access, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr);
|
|
|
|
$photo = $user->getAvatarImage();
|
|
$this->assertSame('this is a photo', $photo);
|
|
//make sure readAttribute is not called again but the already fetched
|
|
//photo is returned
|
|
$photo = $user->getAvatarImage();
|
|
}
|
|
|
|
public function testProcessAttributes() {
|
|
list(, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr) =
|
|
$this->getTestInstances();
|
|
|
|
$uid = 'alice';
|
|
$dn = 'uid=alice';
|
|
|
|
$requiredMethods = array(
|
|
'markRefreshTime',
|
|
'updateQuota',
|
|
'updateEmail',
|
|
'composeAndStoreDisplayName',
|
|
'storeLDAPUserName',
|
|
'getHomePath',
|
|
'updateAvatar'
|
|
);
|
|
|
|
/** @var User|\PHPUnit_Framework_MockObject_MockObject $userMock */
|
|
$userMock = $this->getMockBuilder(User::class)
|
|
->setConstructorArgs(array($uid, $dn, $this->access, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr))
|
|
->setMethods($requiredMethods)
|
|
->getMock();
|
|
|
|
$this->connection->setConfiguration(array(
|
|
'homeFolderNamingRule' => 'homeDirectory'
|
|
));
|
|
$this->connection->expects($this->any())
|
|
->method('__get')
|
|
//->will($this->returnArgument(0));
|
|
->will($this->returnCallback(function($name) {
|
|
if($name === 'homeFolderNamingRule') {
|
|
return 'attr:homeDirectory';
|
|
}
|
|
return $name;
|
|
}));
|
|
|
|
$record = array(
|
|
strtolower($this->connection->ldapQuotaAttribute) => array('4096'),
|
|
strtolower($this->connection->ldapEmailAttribute) => array('alice@wonderland.org'),
|
|
strtolower($this->connection->ldapUserDisplayName) => array('Aaaaalice'),
|
|
'uid' => array($uid),
|
|
'homedirectory' => array('Alice\'s Folder'),
|
|
'memberof' => array('cn=groupOne', 'cn=groupTwo'),
|
|
'jpegphoto' => array('here be an image')
|
|
);
|
|
|
|
foreach($requiredMethods as $method) {
|
|
$userMock->expects($this->once())
|
|
->method($method);
|
|
}
|
|
\OC_Hook::clear();//disconnect irrelevant hooks
|
|
$userMock->processAttributes($record);
|
|
\OC_Hook::emit('OC_User', 'post_login', array('uid' => $uid));
|
|
}
|
|
|
|
public function emptyHomeFolderAttributeValueProvider() {
|
|
return array(
|
|
'empty' => array(''),
|
|
'prefixOnly' => array('attr:'),
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @dataProvider emptyHomeFolderAttributeValueProvider
|
|
*/
|
|
public function testGetHomePathNotConfigured($attributeValue) {
|
|
list(, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr) =
|
|
$this->getTestInstances();
|
|
|
|
$this->connection->expects($this->any())
|
|
->method('__get')
|
|
->with($this->equalTo('homeFolderNamingRule'))
|
|
->will($this->returnValue($attributeValue));
|
|
|
|
$this->access->expects($this->never())
|
|
->method('readAttribute');
|
|
|
|
$config->expects($this->never())
|
|
->method('getAppValue');
|
|
|
|
$uid = 'alice';
|
|
$dn = 'uid=alice,dc=foo,dc=bar';
|
|
|
|
$user = new User(
|
|
$uid, $dn, $this->access, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr);
|
|
|
|
$path = $user->getHomePath();
|
|
$this->assertSame($path, false);
|
|
}
|
|
|
|
public function testGetHomePathConfiguredNotAvailableAllowed() {
|
|
list(, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr) =
|
|
$this->getTestInstances();
|
|
|
|
$this->connection->expects($this->any())
|
|
->method('__get')
|
|
->with($this->equalTo('homeFolderNamingRule'))
|
|
->will($this->returnValue('attr:foobar'));
|
|
|
|
$this->access->expects($this->once())
|
|
->method('readAttribute')
|
|
->will($this->returnValue(false));
|
|
|
|
// asks for "enforce_home_folder_naming_rule"
|
|
$config->expects($this->once())
|
|
->method('getAppValue')
|
|
->will($this->returnValue(false));
|
|
|
|
$uid = 'alice';
|
|
$dn = 'uid=alice,dc=foo,dc=bar';
|
|
|
|
$user = new User(
|
|
$uid, $dn, $this->access, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr);
|
|
|
|
$path = $user->getHomePath();
|
|
|
|
$this->assertSame($path, false);
|
|
}
|
|
|
|
/**
|
|
* @expectedException \Exception
|
|
*/
|
|
public function testGetHomePathConfiguredNotAvailableNotAllowed() {
|
|
list(, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr) =
|
|
$this->getTestInstances();
|
|
|
|
$this->connection->expects($this->any())
|
|
->method('__get')
|
|
->with($this->equalTo('homeFolderNamingRule'))
|
|
->will($this->returnValue('attr:foobar'));
|
|
|
|
$this->access->expects($this->once())
|
|
->method('readAttribute')
|
|
->will($this->returnValue(false));
|
|
|
|
// asks for "enforce_home_folder_naming_rule"
|
|
$config->expects($this->once())
|
|
->method('getAppValue')
|
|
->will($this->returnValue(true));
|
|
|
|
$uid = 'alice';
|
|
$dn = 'uid=alice,dc=foo,dc=bar';
|
|
|
|
$user = new User(
|
|
$uid, $dn, $this->access, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr);
|
|
|
|
$user->getHomePath();
|
|
}
|
|
|
|
public function displayNameProvider() {
|
|
return [
|
|
['Roland Deschain', '', 'Roland Deschain'],
|
|
['Roland Deschain', null, 'Roland Deschain'],
|
|
['Roland Deschain', 'gunslinger@darktower.com', 'Roland Deschain (gunslinger@darktower.com)'],
|
|
];
|
|
}
|
|
|
|
/**
|
|
* @dataProvider displayNameProvider
|
|
*/
|
|
public function testComposeAndStoreDisplayName($part1, $part2, $expected) {
|
|
list(, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr) =
|
|
$this->getTestInstances();
|
|
|
|
$config->expects($this->once())
|
|
->method('setUserValue');
|
|
|
|
$user = new User(
|
|
'user', 'cn=user', $this->access, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr);
|
|
|
|
$displayName = $user->composeAndStoreDisplayName($part1, $part2);
|
|
$this->assertSame($expected, $displayName);
|
|
}
|
|
|
|
public function testHandlePasswordExpiryWarningDefaultPolicy() {
|
|
list(, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr) =
|
|
$this->getTestInstances();
|
|
|
|
$uid = 'alice';
|
|
$dn = 'uid=alice';
|
|
|
|
$this->connection->expects($this->any())
|
|
->method('__get')
|
|
->will($this->returnCallback(function($name) {
|
|
if($name === 'ldapDefaultPPolicyDN') {
|
|
return 'cn=default,ou=policies,dc=foo,dc=bar';
|
|
}
|
|
if($name === 'turnOnPasswordChange') {
|
|
return '1';
|
|
}
|
|
return $name;
|
|
}));
|
|
|
|
$this->access->expects($this->any())
|
|
->method('search')
|
|
->will($this->returnCallback(function($filter, $base) {
|
|
if($base === array('uid=alice')) {
|
|
return array(
|
|
array(
|
|
'pwdchangedtime' => array((new \DateTime())->sub(new \DateInterval('P28D'))->format('Ymdhis').'Z'),
|
|
'pwdgraceusetime' => [],
|
|
),
|
|
);
|
|
}
|
|
if($base === array('cn=default,ou=policies,dc=foo,dc=bar')) {
|
|
return array(
|
|
array(
|
|
'pwdmaxage' => array('2592000'),
|
|
'pwdexpirewarning' => array('2591999'),
|
|
),
|
|
);
|
|
}
|
|
return array();
|
|
}));
|
|
|
|
$notification = $this->getMockBuilder(INotification::class)
|
|
->disableOriginalConstructor()
|
|
->getMock();
|
|
$notification->expects($this->any())
|
|
->method('setApp')
|
|
->will($this->returnValue($notification));
|
|
$notification->expects($this->any())
|
|
->method('setUser')
|
|
->will($this->returnValue($notification));
|
|
$notification->expects($this->any())
|
|
->method('setObject')
|
|
->will($this->returnValue($notification));
|
|
$notification->expects($this->any())
|
|
->method('setDateTime')
|
|
->will($this->returnValue($notification));
|
|
$notiMgr->expects($this->exactly(2))
|
|
->method('createNotification')
|
|
->will($this->returnValue($notification));
|
|
$notiMgr->expects($this->exactly(1))
|
|
->method('notify');
|
|
|
|
$user = new User(
|
|
$uid, $dn, $this->access, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr);
|
|
|
|
\OC_Hook::clear();//disconnect irrelevant hooks
|
|
\OCP\Util::connectHook('OC_User', 'post_login', $user, 'handlePasswordExpiry');
|
|
\OC_Hook::emit('OC_User', 'post_login', array('uid' => $uid));
|
|
}
|
|
|
|
public function testHandlePasswordExpiryWarningCustomPolicy() {
|
|
list(, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr) =
|
|
$this->getTestInstances();
|
|
|
|
$uid = 'alice';
|
|
$dn = 'uid=alice';
|
|
|
|
$this->connection->expects($this->any())
|
|
->method('__get')
|
|
->will($this->returnCallback(function($name) {
|
|
if($name === 'ldapDefaultPPolicyDN') {
|
|
return 'cn=default,ou=policies,dc=foo,dc=bar';
|
|
}
|
|
if($name === 'turnOnPasswordChange') {
|
|
return '1';
|
|
}
|
|
return $name;
|
|
}));
|
|
|
|
$this->access->expects($this->any())
|
|
->method('search')
|
|
->will($this->returnCallback(function($filter, $base) {
|
|
if($base === array('uid=alice')) {
|
|
return array(
|
|
array(
|
|
'pwdpolicysubentry' => array('cn=custom,ou=policies,dc=foo,dc=bar'),
|
|
'pwdchangedtime' => array((new \DateTime())->sub(new \DateInterval('P28D'))->format('Ymdhis').'Z'),
|
|
'pwdgraceusetime' => [],
|
|
)
|
|
);
|
|
}
|
|
if($base === array('cn=custom,ou=policies,dc=foo,dc=bar')) {
|
|
return array(
|
|
array(
|
|
'pwdmaxage' => array('2592000'),
|
|
'pwdexpirewarning' => array('2591999'),
|
|
)
|
|
);
|
|
}
|
|
return array();
|
|
}));
|
|
|
|
$notification = $this->getMockBuilder(INotification::class)
|
|
->disableOriginalConstructor()
|
|
->getMock();
|
|
$notification->expects($this->any())
|
|
->method('setApp')
|
|
->will($this->returnValue($notification));
|
|
$notification->expects($this->any())
|
|
->method('setUser')
|
|
->will($this->returnValue($notification));
|
|
$notification->expects($this->any())
|
|
->method('setObject')
|
|
->will($this->returnValue($notification));
|
|
$notification->expects($this->any())
|
|
->method('setDateTime')
|
|
->will($this->returnValue($notification));
|
|
$notiMgr->expects($this->exactly(2))
|
|
->method('createNotification')
|
|
->will($this->returnValue($notification));
|
|
$notiMgr->expects($this->exactly(1))
|
|
->method('notify');
|
|
|
|
$user = new User(
|
|
$uid, $dn, $this->access, $config, $filesys, $image, $log, $avaMgr, $userMgr, $notiMgr);
|
|
|
|
\OC_Hook::clear();//disconnect irrelevant hooks
|
|
\OCP\Util::connectHook('OC_User', 'post_login', $user, 'handlePasswordExpiry');
|
|
\OC_Hook::emit('OC_User', 'post_login', array('uid' => $uid));
|
|
}
|
|
}
|