diff options
author | Côme Chilliet <come.chilliet@nextcloud.com> | 2021-12-13 16:02:59 +0100 |
---|---|---|
committer | Carl Schwan <carl@carlschwan.eu> | 2022-10-20 12:09:06 +0200 |
commit | 02ccce17f7ea86d0a8e0df31a954cfdbef8affa7 (patch) | |
tree | a8985b03d75f453039007e0d90cd29c6d3b3af05 /apps/user_ldap | |
parent | 8b19cfcd885451080a5114dc451a3c78a8dccc81 (diff) | |
download | nextcloud-server-02ccce17f7ea86d0a8e0df31a954cfdbef8affa7.tar.gz nextcloud-server-02ccce17f7ea86d0a8e0df31a954cfdbef8affa7.zip |
Add tests for nested groups
Signed-off-by: Côme Chilliet <come.chilliet@nextcloud.com>
Diffstat (limited to 'apps/user_ldap')
-rw-r--r-- | apps/user_ldap/tests/Group_LDAPTest.php | 53 |
1 files changed, 45 insertions, 8 deletions
diff --git a/apps/user_ldap/tests/Group_LDAPTest.php b/apps/user_ldap/tests/Group_LDAPTest.php index 236dcee3bb7..fc94c475420 100644 --- a/apps/user_ldap/tests/Group_LDAPTest.php +++ b/apps/user_ldap/tests/Group_LDAPTest.php @@ -1274,33 +1274,70 @@ class Group_LDAPTest extends TestCase { public function groupMemberProvider() { $base = 'dc=species,dc=earth'; - $groups0 = [ + $birdsDn = [ 'uid=3723,' . $base, 'uid=8372,' . $base, 'uid=8427,' . $base, 'uid=2333,' . $base, 'uid=4754,' . $base, ]; - $groups1 = [ + $birdsUid = [ '3723', '8372', '8427', '2333', '4754', ]; - $groups2Nested = ['6642', '1424']; - $expGroups2 = array_merge($groups1, $groups2Nested); + $animalsDn = [ + 'uid=lion,' . $base, + 'uid=tiger,' . $base, + ]; + $plantsDn = [ + 'uid=flower,' . $base, + 'uid=tree,' . $base, + ]; + $thingsDn = [ + 'uid=thing1,' . $base, + 'uid=thing2,' . $base, + ]; return [ [ #0 – test DNs 'cn=Birds,' . $base, - $groups0, - ['cn=Birds,' . $base => $groups0] + $birdsDn, + ['cn=Birds,' . $base => $birdsDn] ], [ #1 – test uids 'cn=Birds,' . $base, - $groups1, - ['cn=Birds,' . $base => $groups1] + $birdsUid, + ['cn=Birds,' . $base => $birdsUid] + ], + [ #2 – test simple nested group + 'cn=Animals,' . $base, + array_merge($birdsDn, $animalsDn), + [ + 'cn=Animals,' . $base => array_merge(['cn=Birds,' . $base], $animalsDn), + 'cn=Birds,' . $base => $birdsDn, + ] + ], + [ #3 – test recursive nested group + 'cn=Animals,' . $base, + // Because of complicated nesting the group gets returned as a member + array_merge(['cn=Birds,' . $base], $birdsDn, $animalsDn), + [ + 'cn=Animals,' . $base => array_merge(['cn=Birds,' . $base,'cn=Birds,' . $base,'cn=Animals,' . $base], $animalsDn), + 'cn=Birds,' . $base => array_merge(['cn=Animals,' . $base,'cn=Birds,' . $base], $birdsDn), + ] + ], + [ #4 – Complicated nested group + 'cn=Things,' . $base, + array_merge($birdsDn, $animalsDn, $thingsDn, $plantsDn), + [ + 'cn=Animals,' . $base => array_merge(['cn=Birds,' . $base], $animalsDn), + 'cn=Birds,' . $base => $birdsDn, + 'cn=Plants,' . $base => $plantsDn, + 'cn=Things,' . $base => array_merge(['cn=Animals,' . $base,'cn=Plants,' . $base], $thingsDn), + ] ], ]; } |