aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorThomas Müller <thomas.mueller@tmit.eu>2015-04-15 00:14:08 +0200
committerThomas Müller <thomas.mueller@tmit.eu>2015-04-15 00:14:08 +0200
commit1aa368effea00b7534bfee2f12835d4c93e5f6f1 (patch)
tree369153b7c51693676aea999b405db91f156f787b
parent2a683369526e33ea495ecce47a8de812f3320bc2 (diff)
parent717723b83e45afed3ac2935e89c3aeca9375bb4b (diff)
downloadnextcloud-server-1aa368effea00b7534bfee2f12835d4c93e5f6f1.tar.gz
nextcloud-server-1aa368effea00b7534bfee2f12835d4c93e5f6f1.zip
Merge pull request #15592 from owncloud/fix-15590-master
Avoid php message "Invalid argument supplied for foreach()"
-rw-r--r--lib/private/group/manager.php6
-rw-r--r--tests/lib/group/manager.php22
2 files changed, 26 insertions, 2 deletions
diff --git a/lib/private/group/manager.php b/lib/private/group/manager.php
index 774a76a3063..12136a1bd25 100644
--- a/lib/private/group/manager.php
+++ b/lib/private/group/manager.php
@@ -205,8 +205,10 @@ class Manager extends PublicEmitter implements IGroupManager {
$groups = array();
foreach ($this->backends as $backend) {
$groupIds = $backend->getUserGroups($uid);
- foreach ($groupIds as $groupId) {
- $groups[$groupId] = $this->get($groupId);
+ if (is_array($groupIds)) {
+ foreach ($groupIds as $groupId) {
+ $groups[$groupId] = $this->get($groupId);
+ }
}
}
$this->cachedUserGroups[$uid] = $groups;
diff --git a/tests/lib/group/manager.php b/tests/lib/group/manager.php
index 76996a2b9bb..e3e2a96e46d 100644
--- a/tests/lib/group/manager.php
+++ b/tests/lib/group/manager.php
@@ -846,4 +846,26 @@ class Manager extends \Test\TestCase {
$groups = $manager->getUserGroups($user1);
$this->assertEquals(array(), $groups);
}
+
+ public function testGetUserIdGroups() {
+ /**
+ * @var \PHPUnit_Framework_MockObject_MockObject | \OC_Group_Backend $backend
+ */
+ $backend = $this->getMock('\OC_Group_Database');
+ $backend->expects($this->any())
+ ->method('getUserGroups')
+ ->with('user1')
+ ->will($this->returnValue(null));
+
+ /**
+ * @var \OC\User\Manager $userManager
+ */
+ $userManager = $this->getMock('\OC\User\Manager');
+ $manager = new \OC\Group\Manager($userManager);
+ $manager->addBackend($backend);
+
+ $groups = $manager->getUserIdGroups('user1');
+ $this->assertEquals([], $groups);
+ }
+
}