2014-03-20 23:17:51 +00:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* ownCloud
|
|
|
|
*
|
|
|
|
* @author Arthur Schiwon
|
|
|
|
* @copyright 2014 Arthur Schiwon blizzz@owncloud.com
|
|
|
|
*
|
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU AFFERO GENERAL PUBLIC LICENSE
|
|
|
|
* License as published by the Free Software Foundation; either
|
|
|
|
* version 3 of the License, or any later version.
|
|
|
|
*
|
|
|
|
* This library 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 along with this library. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
namespace OCA\user_ldap\tests;
|
|
|
|
|
|
|
|
use \OCA\user_ldap\lib\Wizard;
|
|
|
|
|
|
|
|
// use \OCA\user_ldap\USER_LDAP as UserLDAP;
|
|
|
|
// use \OCA\user_ldap\lib\Access;
|
|
|
|
// use \OCA\user_ldap\lib\Configuration;
|
|
|
|
// use \OCA\user_ldap\lib\ILDAPWrapper;
|
|
|
|
|
|
|
|
class Test_Wizard extends \PHPUnit_Framework_TestCase {
|
2014-03-21 09:08:17 +00:00
|
|
|
public function setUp() {
|
|
|
|
//we need to make sure the consts are defined, otherwise tests will fail
|
|
|
|
//on systems without php5_ldap
|
|
|
|
$ldapConsts = array('LDAP_OPT_PROTOCOL_VERSION',
|
|
|
|
'LDAP_OPT_REFERRALS', 'LDAP_OPT_NETWORK_TIMEOUT');
|
|
|
|
foreach($ldapConsts as $const) {
|
|
|
|
if(!defined($const)) {
|
|
|
|
define($const, 42);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-03-20 23:17:51 +00:00
|
|
|
private function getWizardAndMocks() {
|
|
|
|
static $conMethods;
|
|
|
|
|
|
|
|
if(is_null($conMethods)) {
|
2014-06-25 15:36:19 +00:00
|
|
|
$confMethods = get_class_methods('\OCA\user_ldap\lib\Configuration');
|
|
|
|
$connMethods = get_class_methods('\OCA\user_ldap\lib\Connection');
|
|
|
|
$accMethods = get_class_methods('\OCA\user_ldap\lib\Access');
|
2014-03-20 23:17:51 +00:00
|
|
|
}
|
|
|
|
$lw = $this->getMock('\OCA\user_ldap\lib\ILDAPWrapper');
|
|
|
|
$conf = $this->getMock('\OCA\user_ldap\lib\Configuration',
|
2014-06-25 15:36:19 +00:00
|
|
|
$confMethods,
|
2014-03-20 23:17:51 +00:00
|
|
|
array($lw, null, null));
|
2014-06-25 15:36:19 +00:00
|
|
|
|
|
|
|
$connector = $this->getMock('\OCA\user_ldap\lib\Connection',
|
|
|
|
$connMethods, array($lw, null, null));
|
|
|
|
$um = $this->getMockBuilder('\OCA\user_ldap\lib\user\Manager')
|
|
|
|
->disableOriginalConstructor()
|
|
|
|
->getMock();
|
|
|
|
$access = $this->getMock('\OCA\user_ldap\lib\Access',
|
|
|
|
$accMethods, array($connector, $lw, $um));
|
|
|
|
|
|
|
|
return array(new Wizard($conf, $lw, $access), $conf, $lw);
|
2014-03-20 23:17:51 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
private function prepareLdapWrapperForConnections(&$ldap) {
|
|
|
|
$ldap->expects($this->once())
|
|
|
|
->method('connect')
|
|
|
|
//dummy value, usually invalid
|
|
|
|
->will($this->returnValue(true));
|
|
|
|
|
|
|
|
$ldap->expects($this->exactly(3))
|
|
|
|
->method('setOption')
|
|
|
|
->will($this->returnValue(true));
|
|
|
|
|
|
|
|
$ldap->expects($this->once())
|
|
|
|
->method('bind')
|
|
|
|
->will($this->returnValue(true));
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testCumulativeSearchOnAttributeLimited() {
|
|
|
|
list($wizard, $configuration, $ldap) = $this->getWizardAndMocks();
|
|
|
|
|
|
|
|
$configuration->expects($this->any())
|
|
|
|
->method('__get')
|
|
|
|
->will($this->returnCallback(function($name) {
|
|
|
|
if($name === 'ldapBase') {
|
|
|
|
return array('base');
|
|
|
|
}
|
|
|
|
return null;
|
|
|
|
}));
|
|
|
|
|
|
|
|
$this->prepareLdapWrapperForConnections($ldap);
|
|
|
|
|
|
|
|
$ldap->expects($this->any())
|
|
|
|
->method('isResource')
|
|
|
|
->will($this->returnValue(true));
|
|
|
|
|
|
|
|
$ldap->expects($this->exactly(2))
|
|
|
|
->method('search')
|
|
|
|
//dummy value, usually invalid
|
|
|
|
->will($this->returnValue(true));
|
|
|
|
|
|
|
|
$ldap->expects($this->exactly(2))
|
|
|
|
->method('countEntries')
|
|
|
|
//an is_resource check will follow, so we need to return a dummy resource
|
|
|
|
->will($this->returnValue(23));
|
|
|
|
|
|
|
|
//5 DNs per filter means 2x firstEntry and 8x nextEntry
|
|
|
|
$ldap->expects($this->exactly(2))
|
|
|
|
->method('firstEntry')
|
|
|
|
//dummy value, usually invalid
|
|
|
|
->will($this->returnValue(true));
|
|
|
|
|
|
|
|
$ldap->expects($this->exactly(8))
|
|
|
|
->method('nextEntry')
|
|
|
|
//dummy value, usually invalid
|
|
|
|
->will($this->returnValue(true));
|
|
|
|
|
|
|
|
$ldap->expects($this->exactly(10))
|
|
|
|
->method('getAttributes')
|
|
|
|
//dummy value, usually invalid
|
|
|
|
->will($this->returnValue(array('cn' => array('foo'), 'count' => 1)));
|
|
|
|
|
|
|
|
global $uidnumber;
|
|
|
|
$uidnumber = 1;
|
|
|
|
$ldap->expects($this->exactly(10))
|
|
|
|
->method('getDN')
|
|
|
|
//dummy value, usually invalid
|
|
|
|
->will($this->returnCallback(function($a, $b) {
|
|
|
|
global $uidnumber;
|
|
|
|
return $uidnumber++;
|
|
|
|
}));
|
|
|
|
|
|
|
|
# The following expectations are the real test #
|
|
|
|
$filters = array('f1', 'f2', '*');
|
2014-06-11 11:35:35 +00:00
|
|
|
$wizard->cumulativeSearchOnAttribute($filters, 'cn', 5);
|
2014-03-20 23:17:51 +00:00
|
|
|
unset($uidnumber);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testCumulativeSearchOnAttributeUnlimited() {
|
|
|
|
list($wizard, $configuration, $ldap) = $this->getWizardAndMocks();
|
|
|
|
|
|
|
|
$configuration->expects($this->any())
|
|
|
|
->method('__get')
|
|
|
|
->will($this->returnCallback(function($name) {
|
|
|
|
if($name === 'ldapBase') {
|
|
|
|
return array('base');
|
|
|
|
}
|
|
|
|
return null;
|
|
|
|
}));
|
|
|
|
|
|
|
|
$this->prepareLdapWrapperForConnections($ldap);
|
|
|
|
|
|
|
|
$ldap->expects($this->any())
|
|
|
|
->method('isResource')
|
|
|
|
->will($this->returnCallback(function($r) {
|
|
|
|
if($r === true) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
if($r % 24 === 0) {
|
|
|
|
global $uidnumber;
|
|
|
|
$uidnumber++;
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}));
|
|
|
|
|
|
|
|
$ldap->expects($this->exactly(2))
|
|
|
|
->method('search')
|
|
|
|
//dummy value, usually invalid
|
|
|
|
->will($this->returnValue(true));
|
|
|
|
|
|
|
|
$ldap->expects($this->exactly(2))
|
|
|
|
->method('countEntries')
|
|
|
|
//an is_resource check will follow, so we need to return a dummy resource
|
|
|
|
->will($this->returnValue(23));
|
|
|
|
|
|
|
|
//5 DNs per filter means 2x firstEntry and 8x nextEntry
|
|
|
|
$ldap->expects($this->exactly(2))
|
|
|
|
->method('firstEntry')
|
|
|
|
//dummy value, usually invalid
|
|
|
|
->will($this->returnCallback(function($r) {
|
|
|
|
global $uidnumber;
|
|
|
|
return $uidnumber;
|
|
|
|
}));
|
|
|
|
|
|
|
|
$ldap->expects($this->exactly(46))
|
|
|
|
->method('nextEntry')
|
|
|
|
//dummy value, usually invalid
|
|
|
|
->will($this->returnCallback(function($r) {
|
|
|
|
global $uidnumber;
|
|
|
|
return $uidnumber;
|
|
|
|
}));
|
|
|
|
|
|
|
|
$ldap->expects($this->exactly(46))
|
|
|
|
->method('getAttributes')
|
|
|
|
//dummy value, usually invalid
|
|
|
|
->will($this->returnValue(array('cn' => array('foo'), 'count' => 1)));
|
|
|
|
|
|
|
|
global $uidnumber;
|
|
|
|
$uidnumber = 1;
|
|
|
|
$ldap->expects($this->exactly(46))
|
|
|
|
->method('getDN')
|
|
|
|
//dummy value, usually invalid
|
|
|
|
->will($this->returnCallback(function($a, $b) {
|
|
|
|
global $uidnumber;
|
|
|
|
return $uidnumber++;
|
|
|
|
}));
|
|
|
|
|
|
|
|
# The following expectations are the real test #
|
|
|
|
$filters = array('f1', 'f2', '*');
|
2014-06-11 11:35:35 +00:00
|
|
|
$wizard->cumulativeSearchOnAttribute($filters, 'cn', 0);
|
2014-03-20 23:17:51 +00:00
|
|
|
unset($uidnumber);
|
|
|
|
}
|
|
|
|
|
2014-05-16 16:03:15 +00:00
|
|
|
public function testCumulativeSearchOnAttributeSkipReadDN() {
|
|
|
|
// tests that there is no infinite loop, when skipping already processed
|
|
|
|
// DNs (they can be returned multiple times for multiple filters )
|
|
|
|
list($wizard, $configuration, $ldap) = $this->getWizardAndMocks();
|
|
|
|
|
|
|
|
$configuration->expects($this->any())
|
|
|
|
->method('__get')
|
|
|
|
->will($this->returnCallback(function($name) {
|
|
|
|
if($name === 'ldapBase') {
|
|
|
|
return array('base');
|
|
|
|
}
|
|
|
|
return null;
|
|
|
|
}));
|
|
|
|
|
|
|
|
$this->prepareLdapWrapperForConnections($ldap);
|
|
|
|
|
|
|
|
$ldap->expects($this->any())
|
|
|
|
->method('isResource')
|
|
|
|
->will($this->returnCallback(function($res) {
|
|
|
|
return (bool)$res;
|
|
|
|
}));
|
|
|
|
|
|
|
|
$ldap->expects($this->any())
|
|
|
|
->method('search')
|
|
|
|
//dummy value, usually invalid
|
|
|
|
->will($this->returnValue(true));
|
|
|
|
|
|
|
|
$ldap->expects($this->any())
|
|
|
|
->method('countEntries')
|
|
|
|
//an is_resource check will follow, so we need to return a dummy resource
|
|
|
|
->will($this->returnValue(7));
|
|
|
|
|
|
|
|
//5 DNs per filter means 2x firstEntry and 8x nextEntry
|
|
|
|
$ldap->expects($this->any())
|
|
|
|
->method('firstEntry')
|
|
|
|
//dummy value, usually invalid
|
|
|
|
->will($this->returnValue(1));
|
|
|
|
|
|
|
|
global $mark;
|
|
|
|
$mark = false;
|
|
|
|
// entries return order: 1, 2, 3, 4, 4, 5, 6
|
|
|
|
$ldap->expects($this->any())
|
|
|
|
->method('nextEntry')
|
|
|
|
//dummy value, usually invalid
|
|
|
|
->will($this->returnCallback(function($a, $prev){
|
|
|
|
$current = $prev + 1;
|
|
|
|
if($current === 7) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
global $mark;
|
|
|
|
if($prev === 4 && !$mark) {
|
|
|
|
$mark = true;
|
|
|
|
return 4;
|
|
|
|
}
|
|
|
|
return $current;
|
|
|
|
}));
|
|
|
|
|
|
|
|
$ldap->expects($this->any())
|
|
|
|
->method('getAttributes')
|
|
|
|
//dummy value, usually invalid
|
|
|
|
->will($this->returnCallback(function($a, $entry) {
|
|
|
|
return array('cn' => array($entry), 'count' => 1);
|
|
|
|
}));
|
|
|
|
|
|
|
|
$ldap->expects($this->any())
|
|
|
|
->method('getDN')
|
|
|
|
//dummy value, usually invalid
|
|
|
|
->will($this->returnCallback(function($a, $b) {
|
|
|
|
return $b;
|
|
|
|
}));
|
|
|
|
|
|
|
|
# The following expectations are the real test #
|
|
|
|
$filters = array('f1', 'f2', '*');
|
2014-08-26 08:50:00 +00:00
|
|
|
$resultArray = $wizard->cumulativeSearchOnAttribute($filters, 'cn', 0);
|
2014-05-16 16:03:15 +00:00
|
|
|
$this->assertSame(6, count($resultArray));
|
|
|
|
unset($mark);
|
|
|
|
}
|
|
|
|
|
2014-06-11 11:35:35 +00:00
|
|
|
}
|