Merge pull request #8059 from owncloud/countUsersInGroup
add optional countUsersInGroup method to group backendsremotes/origin/ldap_group_count
commit
340089f270
@ -0,0 +1,115 @@ |
|||||||
|
<?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; |
||||||
|
|
||||||
|
namespace OCA\user_ldap\tests; |
||||||
|
|
||||||
|
use \OCA\user_ldap\GROUP_LDAP as GroupLDAP; |
||||||
|
use \OCA\user_ldap\lib\Access; |
||||||
|
use \OCA\user_ldap\lib\Connection; |
||||||
|
use \OCA\user_ldap\lib\ILDAPWrapper; |
||||||
|
|
||||||
|
class Test_Group_Ldap extends \PHPUnit_Framework_TestCase { |
||||||
|
private function getAccessMock() { |
||||||
|
static $conMethods; |
||||||
|
static $accMethods; |
||||||
|
|
||||||
|
if(is_null($conMethods) || is_null($accMethods)) { |
||||||
|
$conMethods = get_class_methods('\OCA\user_ldap\lib\Connection'); |
||||||
|
$accMethods = get_class_methods('\OCA\user_ldap\lib\Access'); |
||||||
|
} |
||||||
|
$lw = $this->getMock('\OCA\user_ldap\lib\ILDAPWrapper'); |
||||||
|
$connector = $this->getMock('\OCA\user_ldap\lib\Connection', |
||||||
|
$conMethods, |
||||||
|
array($lw, null, null)); |
||||||
|
$access = $this->getMock('\OCA\user_ldap\lib\Access', |
||||||
|
$accMethods, |
||||||
|
array($connector, $lw)); |
||||||
|
|
||||||
|
return $access; |
||||||
|
} |
||||||
|
|
||||||
|
private function enableGroups($access) { |
||||||
|
$access->connection->expects($this->any()) |
||||||
|
->method('__get') |
||||||
|
->will($this->returnCallback(function($name) { |
||||||
|
// if($name === 'ldapLoginFilter') { |
||||||
|
// return '%uid'; |
||||||
|
// } |
||||||
|
return 1; |
||||||
|
})); |
||||||
|
} |
||||||
|
|
||||||
|
public function testCountEmptySearchString() { |
||||||
|
$access = $this->getAccessMock(); |
||||||
|
|
||||||
|
$this->enableGroups($access); |
||||||
|
|
||||||
|
$access->expects($this->any()) |
||||||
|
->method('groupname2dn') |
||||||
|
->will($this->returnValue('cn=group,dc=foo,dc=bar')); |
||||||
|
|
||||||
|
$access->expects($this->any()) |
||||||
|
->method('readAttribute') |
||||||
|
->will($this->returnValue(array('u11', 'u22', 'u33', 'u34'))); |
||||||
|
|
||||||
|
$groupBackend = new GroupLDAP($access); |
||||||
|
$users = $groupBackend->countUsersInGroup('group'); |
||||||
|
|
||||||
|
$this->assertSame(4, $users); |
||||||
|
} |
||||||
|
|
||||||
|
public function testCountWithSearchString() { |
||||||
|
$access = $this->getAccessMock(); |
||||||
|
|
||||||
|
$this->enableGroups($access); |
||||||
|
|
||||||
|
$access->expects($this->any()) |
||||||
|
->method('groupname2dn') |
||||||
|
->will($this->returnValue('cn=group,dc=foo,dc=bar')); |
||||||
|
|
||||||
|
$access->expects($this->any()) |
||||||
|
->method('readAttribute') |
||||||
|
->will($this->returnCallback(function($name) { |
||||||
|
//the search operation will call readAttribute, thus we need |
||||||
|
//to anaylze the "dn". All other times we just need to return |
||||||
|
//something that is neither null or false, but once an array |
||||||
|
//with the users in the group – so we do so all other times for |
||||||
|
//simplicicity. |
||||||
|
if(strpos($name, 'u') === 0) { |
||||||
|
return strpos($name, '3'); |
||||||
|
} |
||||||
|
return array('u11', 'u22', 'u33', 'u34'); |
||||||
|
})); |
||||||
|
|
||||||
|
$access->expects($this->any()) |
||||||
|
->method('dn2username') |
||||||
|
->will($this->returnValue('foobar')); |
||||||
|
|
||||||
|
$groupBackend = new GroupLDAP($access); |
||||||
|
$users = $groupBackend->countUsersInGroup('group', '3'); |
||||||
|
|
||||||
|
$this->assertSame(2, $users); |
||||||
|
} |
||||||
|
|
||||||
|
} |
Loading…
Reference in new issue