* @author Morris Jobke * @author Roeland Jago Douma * @author Thomas Müller * @author Tom Needham * @author Vincent Petry * * @copyright Copyright (c) 2015, ownCloud, Inc. * @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 * */ namespace OCA\Provisioning_API\Tests; use OCP\IUserManager; use OCP\IConfig; use OCP\IGroupManager; use OCP\IUserSession; class UsersTest extends TestCase { /** @var IUserManager */ protected $userManager; /** @var IConfig */ protected $config; /** @var IGroupManager */ protected $groupManager; /** @var IUserSession */ protected $userSession; protected function resetParams() { $_GET = null; $_POST = null; } protected function setup() { parent::setup(); $this->userManager = \OC::$server->getUserManager(); $this->config = \OC::$server->getConfig(); $this->groupManager = \OC::$server->getGroupManager(); $this->userSession = \OC::$server->getUserSession(); $this->api = new \OCA\Provisioning_Api\Users( $this->userManager, $this->config, $this->groupManager, $this->userSession ); $this->userSession->setUser(null); } // Test getting the list of users public function testGetUsersAsAdmin() { $user = $this->generateUsers(); $this->groupManager->get('admin')->addUser($user); $this->userSession->setUser($user); $result = $this->api->getUsers(); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertTrue($result->succeeded()); $count = $result->getData(); $count = count($count['users']); $this->assertEquals(count($this->userManager->search('', null, null)), $count); $user = $this->generateUsers(); $_GET['search'] = $user->getUID(); $result = $this->api->getUsers(); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertTrue($result->succeeded()); $data = $result->getData(); $this->assertEquals($user->getUID(), reset($data['users'])); // Add several users $this->generateUsers(10); $this->resetParams(); $_GET['limit'] = 2; $result = $this->api->getUsers(); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertTrue($result->succeeded()); $count = $result->getData(); $count = count($count['users']); $this->assertEquals(2, $count); $this->resetParams(); $_GET['limit'] = 1; $_GET['offset'] = 1; $result = $this->api->getUsers(array()); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertTrue($result->succeeded()); $data = $result->getData(); $this->assertEquals(array_keys($this->userManager->search('', 1, 1)), $data['users']); } public function testGetUsersAsSubAdmin() { $user = $this->generateUsers(10); $this->userSession->setUser($user[0]); $group = $this->groupManager->createGroup($this->getUniqueID()); \OC_SubAdmin::createSubAdmin($user[0]->getUID(), $group->getGID()); //Empty list $result = $this->api->getUsers([]); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertTrue($result->succeeded()); $this->assertEquals(['users' => []], $result->getData()); //Some users in group $group->addUser($user[1]); $group->addUser($user[2]); $group->addUser($user[3]); $group->addUser($user[4]); $result = $this->api->getUsers([]); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertTrue($result->succeeded()); $this->assertArrayHasKey('users', $result->getData()); $this->assertContains($user[1]->getUID(), $result->getData()['users']); $this->assertContains($user[2]->getUID(), $result->getData()['users']); $this->assertContains($user[3]->getUID(), $result->getData()['users']); $this->assertContains($user[4]->getUID(), $result->getData()['users']); $uids = [ $user[1]->getUID(), $user[2]->getUID(), $user[3]->getUID(), $user[4]->getUID() ]; sort($uids); $_GET['limit'] = 2; $_GET['offset'] = 1; $result = $this->api->getUsers([]); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertTrue($result->succeeded()); $this->assertEquals(['users' => array_slice($uids, 1, 2)], $result->getData()); } public function testGetUsersNoUser() { $result = $this->api->getUsers([]); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertFalse($result->succeeded()); $this->assertEquals(\OCP\API::RESPOND_UNAUTHORISED, $result->getStatusCode()); } public function testGetUsersAsUser() { $user = $this->generateUsers(); $this->userSession->setUser($user); $result = $this->api->getUsers(); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertFalse($result->succeeded()); $this->assertEquals(\OCP\API::RESPOND_UNAUTHORISED, $result->getStatusCode()); } public function testAddUser() { $this->resetParams(); $_POST['userid'] = $this->getUniqueID(); $_POST['password'] = 'password'; $result = $this->api->addUser(); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertTrue($result->succeeded()); $this->assertTrue($this->userManager->userExists($_POST['userid'])); $this->assertEquals($_POST['userid'], $this->userManager->checkPassword($_POST['userid'], $_POST['password'])->getUID()); $this->users[] = $this->userManager->get($_POST['userid']); } public function testAddUserTwice() { $this->resetParams(); $_POST['userid'] = $this->getUniqueID(); $_POST['password'] = 'password'; $this->api->addUser(); $result = $this->api->addUser(); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertFalse($result->succeeded()); $this->assertEquals(102, $result->getStatusCode()); $this->assertEquals('User already exists', $result->getMeta()['message']); } public function testAddUserFails() { $uid = $this->getUniqueID(); $userManager = $this->getMockBuilder('\OCP\IUserManager') ->disableOriginalConstructor() ->getMock(); $userManager->expects($this->once()) ->method('userExists') ->with($uid) ->willReturn(false); $userManager->expects($this->once()) ->method('createUser') ->with($uid, 'password') ->will($this->throwException(new \Exception)); $api = new \OCA\Provisioning_Api\Users( $userManager, $this->config, $this->groupManager, $this->userSession ); $this->resetParams(); $_POST['userid'] = $uid; $_POST['password'] = 'password'; $result = $api->addUser(); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertFalse($result->succeeded()); $this->assertEquals(101, $result->getStatusCode()); $this->assertEquals('Bad request', $result->getMeta()['message']); } public function testGetUserOnSelf() { $user = $this->generateUsers(); $user->setDisplayName('foobar'); $this->userSession->setUser($user); $params['userid'] = $user->getUID(); $result = $this->api->getUser($params); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertTrue($result->succeeded()); $data = $result->getData(); $this->assertEquals('foobar', $data['displayname']); } public function testGetUserOnNonExistingUser() { $user = $this->generateUsers(); $this->groupManager->get('admin')->addUser($user); $this->userSession->setUser($user); $params = array(); $params['userid'] = $this->getUniqueID(); while($this->userManager->userExists($params['userid'])) { $params['userid'] = $this->getUniqueID(); } $result = $this->api->getUser($params); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertFalse($result->succeeded()); $this->assertEquals(\OCP\API::RESPOND_NOT_FOUND, $result->getStatusCode()); } public function testGetUserOnOtherUser() { $users = $this->generateUsers(2); $params['userid'] = $users[0]; $this->userSession->setUser($users[1]); $result = $this->api->getUser($params); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertFalse($result->succeeded()); // Now as as admin $users = $this->generateUsers(2); $params['userid'] = $users[0]->getUID(); // login to generate home $this->userSession->setUser($users[0]); $this->groupManager->get('admin')->addUser($users[1]); $this->userSession->setUser($users[1]); $result = $this->api->getUser($params); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertTrue($result->succeeded()); $data = $result->getData(); $this->assertEquals(\OC::$server->getConfig()->getUserValue($users[0]->getUID(), 'core', 'enabled', 'true'), $data['enabled']); } public function testEditOwnDisplayName() { // Test editing own name $user = $this->generateUsers(); $this->userSession->setUser($user); $result = $this->api->editUser( array( 'userid' => $user->getUID(), '_put' => array( 'key' => 'display', 'value' => 'newname', ), ) ); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertTrue($result->succeeded()); $this->assertEquals('newname', $user->getDisplayName()); } public function testAdminEditDisplayNameOfUser() { // Test admin editing users name $user = $this->generateUsers(); $this->groupManager->get('admin')->addUser($user); $this->userSession->setUser($user); $user2 = $this->generateUsers(); $result = $this->api->editUser( [ 'userid' => $user2->getUID(), '_put' => [ 'key' => 'display', 'value' => 'newname', ], ] ); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertTrue($result->succeeded()); $this->assertEquals('newname', $user2->getDisplayName()); } public function testUserEditOtherUserDisplayName() { // Test editing other users name $user = $this->generateUsers(); $this->userSession->setUser($user); $user2 = $this->generateUsers(); $result = $this->api->editUser( array( 'userid' => $user2->getUID(), '_put' => array( 'key' => 'display', 'value' => 'newname', ), ) ); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertFalse($result->succeeded()); } /** * @dataProvider providesQuotas * @param $expected * @param $quota */ public function testEditOwnQuota($expected, $quota) { $user = $this->generateUsers(); $this->userSession->setUser($user); $result = $this->api->editUser( [ 'userid' => $user->getUID(), '_put' => [ 'key' => 'quota', 'value' => $quota, ], ] ); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertFalse($result->succeeded()); $this->assertEquals(997, $result->getStatusCode()); } /** * @dataProvider providesQuotas * @param $expected * @param $quota */ public function testEditOwnQuotaAsAdmin($expected, $quota) { $user = $this->generateUsers(); $this->groupManager->get('admin')->addUser($user); $this->userSession->setUser($user); $result = $this->api->editUser( [ 'userid' => $user->getUID(), '_put' => [ 'key' => 'quota', 'value' => $quota, ], ] ); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertEquals($expected, $result->succeeded()); } public function providesQuotas() { return [ [true, '20G'], [true, '1234567'], [true, 'none'], [true, 'default'], [false, 'qwertzu'], [true, 0], [true, -1] ]; } public function testAdminEditOwnQuota() { $user = $this->generateUsers(); $this->groupManager->get('admin')->addUser($user); $this->userSession->setUser($user); $result = $this->api->editUser( array( 'userid' => $user->getUID(), '_put' => array( 'key' => 'quota', 'value' => '20G', ), ) ); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertTrue($result->succeeded()); } public function testAdminEditOtherUserQuota() { $user = $this->generateUsers(); $this->groupManager->get('admin')->addUser($user); $this->userSession->setUser($user); $user2 = $this->generateUsers(); $result = $this->api->editUser( array( 'userid' => $user2->getUID(), '_put' => array( 'key' => 'quota', 'value' => '20G', ), ) ); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertTrue($result->succeeded()); } public function testUserEditOtherUserQuota() { $user = $this->generateUsers(); $this->userSession->setUser($user); $user2 = $this->generateUsers(); $result = $this->api->editUser( array( 'userid' => $user2->getUID(), '_put' => array( 'key' => 'quota', 'value' => '20G', ), ) ); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertFalse($result->succeeded()); } public function testUserEditOwnEmail() { $user = $this->generateUsers(); $email = 'test@example.com'; $this->userSession->setUser($user); $result = $this->api->editUser( array( 'userid' => $user->getUID(), '_put' => array( 'key' => 'email', 'value' => $email, ), ) ); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertTrue($result->succeeded()); $this->assertEquals($email, \OC::$server->getConfig()->getUserValue($user->getUID(), 'settings', 'email', null)); } public function testUserEditOwnEmailInvalid() { $user = $this->generateUsers(); $email = 'test@example'; $this->userSession->setUser($user); $result = $this->api->editUser([ 'userid' => $user->getUID(), '_put' => [ 'key' => 'email', 'value' => $email, ], ]); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertFalse($result->succeeded()); $this->assertEquals(102, $result->getStatusCode()); } public function testUserEditOtherUserEmailAsUser() { $users = $this->generateUsers(2); $email = 'test@example.com'; $this->userSession->setUser($users[0]); $result = $this->api->editUser( array( 'userid' => $users[1]->getUID(), '_put' => array( 'key' => 'email', 'value' => $email, ), ) ); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertFalse($result->succeeded()); } public function testUserEditOtherUserEmailAsAdmin() { $users = $this->generateUsers(2); $email = 'test@example.com'; $this->userSession->setUser($users[0]); $this->groupManager->get('admin')->addUser($users[0]); $result = $this->api->editUser( array( 'userid' => $users[1]->getUID(), '_put' => array( 'key' => 'email', 'value' => $email, ), ) ); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertTrue($result->succeeded()); $this->assertEquals($email, \OC::$server->getConfig()->getUserValue($users[1]->getUID(), 'settings', 'email', null)); } public function testUserEditOwnPassword() { $user = $this->generateUsers(); $password = 'foo'; $this->userSession->setUser($user); $result = $this->api->editUser([ 'userid' => $user->getUID(), '_put' => [ 'key' => 'password', 'value' => $password, ], ]); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertTrue($result->succeeded()); } public function testUserEditOtherUserPasswordAsUser() { $users = $this->generateUsers(2); $password = 'foo'; $this->userSession->setUser($users[0]); $result = $this->api->editUser([ 'userid' => $users[1]->getUID(), '_put' => [ 'key' => 'password', 'value' => $password, ], ]); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertFalse($result->succeeded()); } public function testUserEditOtherUserPasswordAsAdmin() { $users = $this->generateUsers(2); $password = 'foo'; $this->userSession->setUser($users[0]); $this->groupManager->get('admin')->addUser($users[0]); $result = $this->api->editUser([ 'userid' => $users[1]->getUID(), '_put' => [ 'key' => 'password', 'value' => $password, ], ]); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertTrue($result->succeeded()); } public function testDeleteSelf() { $user = $this->generateUsers(); $this->userSession->setUser($user); $result = $this->api->deleteUser(array( 'userid' => $user->getUID(), )); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertFalse($result->succeeded()); } public function testDeleteOtherAsUser() { $user = $this->generateUsers(); $this->userSession->setUser($user); $user2 = $this->generateUsers(); $result = $this->api->deleteUser(array( 'userid' => $user2->getUID(), )); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertFalse($result->succeeded()); } public function testDeleteOtherAsSubAdmin() { $user = $this->generateUsers(); $this->userSession->setUser($user); $user2 = $this->generateUsers(); $group = $this->groupManager->createGroup($this->getUniqueID()); $group->addUser($user); $group->addUser($user2); \OC_SubAdmin::createSubAdmin($user->getUID(), $group->getGID()); $result = $this->api->deleteUser(array( 'userid' => $user2->getUID(), )); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertTrue($result->succeeded()); $group->delete(); } public function testDeleteOtherAsIrelevantSubAdmin() { $user = $this->generateUsers(); $this->userSession->setUser($user); $user2 = $this->generateUsers(); $group = $this->groupManager->createGroup($this->getUniqueID()); $group2 = $this->groupManager->createGroup($this->getUniqueID()); $group->addUser($user); $group2->addUser($user2); \OC_SubAdmin::createSubAdmin($user->getUID(), $group->getGID()); $result = $this->api->deleteUser(array( 'userid' => $user2->getUID(), )); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertFalse($result->succeeded()); $group->delete(); $group2->delete(); } public function testDeleteOtherAsAdmin() { $user = $this->generateUsers(); $this->groupManager->get('admin')->addUser($user); $this->userSession->setUser($user); $user2 = $this->generateUsers(); $result = $this->api->deleteUser(array( 'userid' => $user2->getUID(), )); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertTrue($result->succeeded()); } public function testDeleteSelfAsAdmin() { $user = $this->generateUsers(); $this->groupManager->get('admin')->addUser($user); $this->userSession->setUser($user); $result = $this->api->deleteUser(array( 'userid' => $user->getUID(), )); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertFalse($result->succeeded()); } public function testDeleteFails() { $user = $this->getMockBuilder('\OCP\IUser') ->disableOriginalConstructor() ->getMock(); $user->expects($this->once()) ->method('delete') ->willReturn(false); $user2 = $this->getMockBuilder('\OCP\IUser') ->disableOriginalConstructor() ->getMock(); $user2->expects($this->any()) ->method('getUID') ->willReturn('user2'); $userManager = $this->getMockBuilder('\OCP\IUserManager') ->disableOriginalConstructor() ->getMock(); $userManager->expects($this->once()) ->method('userExists') ->with('user') ->willReturn(true); $userManager->expects($this->once()) ->method('get') ->with('user') ->willReturn($user); $userSession = $this->getMockBuilder('\OCP\IUserSession') ->disableOriginalConstructor() ->getMock(); $userSession->expects($this->once()) ->method('getUser') ->willReturn($user2); $groupManager = $this->getMockBuilder('\OCP\IGroupManager') ->disableOriginalConstructor() ->getMock(); $groupManager->expects($this->once()) ->method('isAdmin') ->with('user2') ->willReturn(true); $api = new \OCA\Provisioning_Api\Users( $userManager, $this->config, $groupManager, $userSession ); $result = $api->deleteUser([ 'userid' => 'user', ]); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertFalse($result->succeeded()); $this->assertEquals(101, $result->getStatusCode()); } public function testGetUsersGroupsOnSelf() { $user = $this->generateUsers(); $this->userSession->setUser($user); $group = $this->getUniqueID(); $group = $this->groupManager->createGroup($group); $group->addUser($user); $result = $this->api->getUsersGroups(array( 'userid' => $user->getUID(), )); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertTrue($result->succeeded()); $data = $result->getData(); $this->assertEquals($group->getGID(), reset($data['groups'])); $this->assertEquals(1, count($data['groups'])); $group->delete(); } public function testGetUsersGroupOnOther() { $user1 = $this->generateUsers(); $user2 = $this->generateUsers(); $this->userSession->setUser($user1); $group = $this->getUniqueID(); $group = $this->groupManager->createGroup($group); $group->addUser($user2); $result = $this->api->getUsersGroups(array( 'userid' => $user2->getUID(), )); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertFalse($result->succeeded()); $group->delete(); } public function testGetUsersGroupOnOtherAsAdmin() { $user1 = $this->generateUsers(); $this->groupManager->get('admin')->addUser($user1); $user2 = $this->generateUsers(); $this->userSession->setUser($user1); $group = $this->getUniqueID(); $group = $this->groupManager->createGroup($group); $group->addUser($user2); $result = $this->api->getUsersGroups(array( 'userid' => $user2->getUID(), )); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertTrue($result->succeeded()); $data = $result->getData(); $this->assertEquals($group->getGID(), reset($data['groups'])); $this->assertEquals(1, count($data['groups'])); $group->delete(); } public function testGetUsersGroupsOnOtherAsSubAdmin() { $user1 = $this->generateUsers(); $user2 = $this->generateUsers(); $this->userSession->setUser($user1); $group1 = $this->getUniqueID(); $group2 = $this->getUniqueID(); $group1 = $this->groupManager->createGroup($group1); $group2 = $this->groupManager->createGroup($group2); $group1->addUser($user2); $group2->addUser($user2); $group1->addUser($user1); \OC_SubAdmin::createSubAdmin($user1->getUID(), $group1->getGID()); $result = $this->api->getUsersGroups(array( 'userid' => $user2->getUID(), )); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertTrue($result->succeeded()); $data = $result->getData(); $this->assertEquals($group1->getGID(), reset($data['groups'])); $this->assertEquals(1, count($data['groups'])); $group1->delete(); $group2->delete(); } public function testGetUsersGroupsOnOtherAsIrelevantSubAdmin() { $user1 = $this->generateUsers(); $user2 = $this->generateUsers(); $this->userSession->setUser($user1); $group1 = $this->getUniqueID(); $group2 = $this->getUniqueID(); $group1 = $this->groupManager->createGroup($group1); $group2 = $this->groupManager->createGroup($group2); $group2->addUser($user2); $group1->addUser($user1); \OC_SubAdmin::createSubAdmin($user1->getUID(), $group1->getGID()); $result = $this->api->getUsersGroups(array( 'userid' => $user2->getUID(), )); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertFalse($result->succeeded()); $group1->delete(); $group2->delete(); } public function testAddToGroup() { $user = $this->generateUsers(); $group = $this->getUniqueID(); $group = $this->groupManager->createGroup($group); $this->userSession->setUser($user); $_POST['groupid'] = $group->getGID(); $result = $this->api->addToGroup(array( 'userid' => $user->getUID(), )); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertFalse($result->succeeded()); $this->assertFalse($group->inGroup($user)); $group->delete(); } public function testAddToGroupAsAdmin() { $user = $this->generateUsers(); $this->groupManager->get('admin')->addUser($user); $group = $this->getUniqueID(); $group = $this->groupManager->createGroup($group); $user2 = $this->generateUsers(); $this->userSession->setUser($user); $_POST['groupid'] = $group->getGID(); $result = $this->api->addToGroup(array( 'userid' => $user2->getUID(), )); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertTrue($result->succeeded()); $this->assertTrue($group->inGroup($user2)); $group->delete(); } public function testAddToGroupAsSubAdmin() { $user1 = $this->generateUsers(); $user2 = $this->generateUsers(); $this->userSession->setUser($user1); $group1 = $this->getUniqueID(); $group1 = $this->groupManager->createGroup($group1); \OC_SubAdmin::createSubAdmin($user1->getUID(), $group1->getGID()); $_POST['groupid'] = $group1->getGID(); $result = $this->api->addToGroup(array( 'userid' => $user2->getUID(), )); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertFalse($result->succeeded()); $this->assertFalse($group1->inGroup($user2)); $group1->delete(); } public function testAddToGroupAsIrelevantSubAdmin() { $user1 = $this->generateUsers(); $user2 = $this->generateUsers(); $this->userSession->setUser($user1); $group1 = $this->getUniqueID(); $group2 = $this->getUniqueID(); $group1 = $this->groupManager->createGroup($group1); $group2 = $this->groupManager->createGroup($group2); \OC_SubAdmin::createSubAdmin($user1->getUID(), $group1->getGID()); $_POST['groupid'] = $group2->getGID(); $result = $this->api->addToGroup(array( 'userid' => $user2->getUID(), )); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertFalse($result->succeeded()); $this->assertFalse($group2->inGroup($user2)); $group1->delete(); $group2->delete(); } public function testAddToGroupNoGroupId() { $user = $this->generateUsers(); $this->userSession->setUser($user); $_POST['groupid'] = ''; $result = $this->api->addToGroup([ 'userid' => $this->getUniqueID(), ]); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertFalse($result->succeeded()); $this->assertEquals(101, $result->getStatusCode()); } public function testAddToNonExistingGroup() { $user = $this->generateUsers(); $this->groupManager->get('admin')->addUser($user); $this->userSession->setUser($user); $group = $this->groupManager->createGroup($this->getUniqueID()); $_POST['groupid'] = $group->getGID(); $result = $this->api->addToGroup([ 'userid' => $this->getUniqueID(), ]); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertFalse($result->succeeded()); $this->assertEquals(103, $result->getStatusCode()); } public function testAddNonExistingUserToGroup() { $user = $this->generateUsers(); $this->groupManager->get('admin')->addUser($user); $this->userSession->setUser($user); $_POST['groupid'] = $this->getUniqueID(); $result = $this->api->addToGroup([ 'userid' => $this->getUniqueID(), ]); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertFalse($result->succeeded()); $this->assertEquals(102, $result->getStatusCode()); } // test delete /cloud/users/{userid}/groups public function testRemoveFromGroupAsSelf() { $user1 = $this->generateUsers(); $this->userSession->setUser($user1); $group1 = $this->getUniqueID(); $group1 = $this->groupManager->createGroup($group1); $group1->addUser($user1); $result = $this->api->removeFromGroup(array( 'userid' => $user1->getUID(), '_delete' => array( 'groupid' => $group1->getGID(), ), )); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertFalse($result->succeeded()); $this->assertTrue($group1->inGroup($user1)); $group1->delete(); } public function testRemoveFromGroupAsAdmin() { $user1 = $this->generateUsers(); $user2 = $this->generateUsers(); $this->userSession->setUser($user1); $group1 = $this->getUniqueID(); $group1 = $this->groupManager->createGroup($group1); $group1->addUser($user2); $this->groupManager->get('admin')->addUser($user1); $result = $this->api->removeFromGroup(array( 'userid' => $user2->getUID(), '_delete' => array( 'groupid' => $group1->getGID(), ), )); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertTrue($result->succeeded()); $this->assertFalse($group1->inGroup($user2)); $group1->delete(); } public function testRemoveSelfFromGroupAsAdmin() { $user1 = $this->generateUsers(); $this->userSession->setUser($user1); $group1 = $this->groupManager->createGroup($this->getUniqueID()); $group1->addUser($user1); $this->groupManager->get('admin')->addUser($user1); $result = $this->api->removeFromGroup([ 'userid' => $user1->getUID(), '_delete' => [ 'groupid' => $group1->getGID(), ], ]); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertTrue($result->succeeded()); $this->assertFalse($group1->inGroup($user1)); $group1->delete(); } public function testRemoveFromGroupAsSubAdmin() { $user1 = $this->generateUsers(); $this->userSession->setUser($user1); $user2 = $this->generateUsers(); $group1 = $this->getUniqueID(); $group1 = $this->groupManager->createGroup($group1); $group1->addUser($user1); $group1->addUser($user2); \OC_SubAdmin::createSubAdmin($user1->getUID(), $group1->getGID()); $result = $this->api->removeFromGroup(array( 'userid' => $user2->getUID(), '_delete' => array( 'groupid' => $group1->getGID(), ), )); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertTrue($result->succeeded()); $this->assertFalse($group1->inGroup($user2)); $group1->delete(); } public function testRemoveFromGroupAsIrelevantSubAdmin() { $user1 = $this->generateUsers(); $this->userSession->setUser($user1); $user2 = $this->generateUsers(); $group1 = $this->getUniqueID(); $group2 = $this->getUniqueID(); $group1 = $this->groupManager->createGroup($group1); $group2 = $this->groupManager->createGroup($group2); $group1->addUser($user1); $group2->addUser($user2); \OC_SubAdmin::createSubAdmin($user1->getUID(), $group1->getGID()); $result = $this->api->removeFromGroup(array( 'userid' => $user2->getUID(), '_delete' => array( 'groupid' => $group2->getGID(), ), )); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertFalse($result->succeeded()); $this->assertTrue($group2->inGroup($user2)); $group1->delete(); $group2->delete(); } public function testRemoveFromGroupNoGroupId() { $user = $this->generateUsers(); $this->userSession->setUser($user); $result = $this->api->removeFromGroup([ '_delete' => [ 'groupid' => '' ], ]); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertFalse($result->succeeded()); $this->assertEquals(101, $result->getStatusCode()); } public function testRemoveSelfFromAdminAsAdmin() { $user = $this->generateUsers(); $this->userSession->setUser($user); $this->groupManager->get('admin')->addUser($user); $result = $this->api->removeFromGroup([ 'userid' => $user->getUID(), '_delete' => [ 'groupid' => 'admin' ], ]); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertFalse($result->succeeded()); $this->assertEquals(105, $result->getStatusCode()); $this->assertEquals('Cannot remove yourself from the admin group', $result->getMeta()['message']); } public function testRemoveSelfFromSubAdminGroupAsSubAdmin() { $user = $this->generateUsers(); $this->userSession->setUser($user); $group = $this->groupManager->createGroup($this->getUniqueID()); \OC_SubAdmin::createSubAdmin($user->getUID(), $group->getGID()); $result = $this->api->removeFromGroup([ 'userid' => $user->getUID(), '_delete' => [ 'groupid' => $group->getGID() ], ]); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertFalse($result->succeeded()); $this->assertEquals(105, $result->getStatusCode()); $this->assertEquals('Cannot remove yourself from this group as you are a SubAdmin', $result->getMeta()['message']); $group->delete(); } public function testRemoveFromNonExistingGroup() { $user1 = $this->generateUsers(); $this->userSession->setUser($user1); $this->groupManager->get('admin')->addUser($user1); $user2 = $this->generateUsers(); $result = $this->api->removeFromGroup([ 'userid' => $user2->getUID(), '_delete' => [ 'groupid' => $this->getUniqueID() ], ]); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertFalse($result->succeeded()); $this->assertEquals(102, $result->getStatusCode()); } public function testRemoveFromNonGroupNonExistingUser() { $user = $this->generateUsers(); $this->userSession->setUser($user); $this->groupManager->get('admin')->addUser($user); $group = $this->groupManager->createGroup($this->getUniqueID()); $result = $this->api->removeFromGroup([ 'userid' => $this->getUniqueID(), '_delete' => [ 'groupid' => $group->getGID() ], ]); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertFalse($result->succeeded()); $this->assertEquals(103, $result->getStatusCode()); } public function testCreateSubAdmin() { $user1 = $this->generateUsers(); $user2 = $this->generateUsers(); $this->userSession->setUser($user1); $this->groupManager->get('admin')->addUser($user1); $group1 = $this->getUniqueID(); $group1 = $this->groupManager->createGroup($group1); $_POST['groupid'] = $group1->getGID(); $result = $this->api->addSubAdmin(array( 'userid' => $user2->getUID(), )); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertTrue($result->succeeded()); $this->assertTrue(\OC_SubAdmin::isSubAdminofGroup($user2->getUID(), $group1->getGID())); $group1->delete(); $this->resetParams(); $user1 = $this->generateUsers(); $user2 = $this->generateUsers(); $this->userSession->setUser($user1); $this->groupManager->get('admin')->addUser($user1); $_POST['groupid'] = 'admin'; $result = $this->api->addSubAdmin(array( 'userid' => $user2->getUID(), )); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertEquals(103, $result->getStatusCode()); $this->assertFalse($result->succeeded()); $this->resetParams(); $user1 = $this->generateUsers(); $this->userSession->setUser($user1); $this->groupManager->get('admin')->addUser($user1); $group1 = $this->getUniqueID(); $group1 = $this->groupManager->createGroup($group1); $_POST['groupid'] = $group1->getGID(); $result = $this->api->addSubAdmin(array( 'userid' => $this->getUniqueID(), )); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertFalse($result->succeeded()); $this->assertEquals(101, $result->getStatusCode()); $group1->delete(); $user1 = $this->generateUsers(); $this->userSession->setUser($user1); $group = $this->getUniqueID(); $_POST['groupid'] = $group; $result = $this->api->addSubAdmin([ 'userid' => $user1->getUID() ]); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertFalse($result->succeeded()); $this->assertEquals(102, $result->getStatusCode()); $this->assertEquals('Group:'.$group.' does not exist', $result->getMeta()['message']); } public function testRemoveSubAdmin() { $user1 = $this->generateUsers(); $user2 = $this->generateUsers(); $this->userSession->setUser($user1); $this->groupManager->get('admin')->addUser($user1); $group1 = $this->getUniqueID(); $group1 = $this->groupManager->createGroup($group1); \OC_SubAdmin::createSubAdmin($user2->getUID(), $group1->getGID()); $result = $this->api->removeSubAdmin(array( 'userid' => $user2->getUID(), '_delete' => array( 'groupid' => $group1->getGID(), ), )); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertTrue($result->succeeded()); $this->assertTrue(!\OC_SubAdmin::isSubAdminofGroup($user2->getUID(), $group1->getGID())); $group1->delete(); $user1 = $this->generateUsers(); $this->userSession->setUser($user1); $this->groupManager->get('admin')->addUser($user1); $result = $this->api->removeSubAdmin(array( 'userid' => $this->getUniqueID(), '_delete' => array( 'groupid' => $group1->getGID(), ), )); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertEquals(101, $result->getStatusCode()); $this->assertFalse($result->succeeded()); $this->resetParams(); $user1 = $this->generateUsers(); $user2 = $this->generateUsers(); $this->userSession->setUser($user1); $this->groupManager->get('admin')->addUser($user1); $group1 = $this->getUniqueID(); $group1 = $this->groupManager->createGroup($group1); $_POST['groupid'] = $group1->getGID(); $result = $this->api->removeSubAdmin(array( 'userid' => $user2->getUID(), '_delete' => array( 'groupid' => $group1->getGID(), ), )); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertFalse($result->succeeded()); $this->assertEquals(102, $result->getStatusCode()); $group1->delete(); } public function testGetSubAdminGroups() { $user1 = $this->generateUsers(); $user2 = $this->generateUsers(); $this->userSession->setUser($user1); $this->groupManager->get('admin')->addUser($user1); $group1 = $this->getUniqueID(); $group1 = $this->groupManager->createGroup($group1); \OC_SubAdmin::createSubAdmin($user2->getUID(), $group1->getGID()); $result = $this->api->getUserSubAdminGroups(array( 'userid' => $user2->getUID(), )); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertTrue($result->succeeded()); $data = $result->getData(); $this->assertEquals($group1->getGID(), reset($data)); $group1->delete(); $user1 = $this->generateUsers(); $this->userSession->setUser($user1); $this->groupManager->get('admin')->addUser($user1); $result = $this->api->getUserSubAdminGroups(array( 'userid' => $this->getUniqueID(), )); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertFalse($result->succeeded()); $this->assertEquals(101, $result->getStatusCode()); } public function testSubAdminOfGroupAlreadySubAdmin() { $user1 = $this->generateUsers(); $user2 = $this->generateUsers(); $this->userSession->setUser($user1); $this->groupManager->get('admin')->addUser($user1); $group1 = $this->groupManager->createGroup($this->getUniqueID()); //Make user2 subadmin of group1 $_POST['groupid'] = $group1->getGID(); $result = $this->api->addSubAdmin([ 'userid' => $user2->getUID(), ]); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertTrue($result->succeeded()); //Make user2 subadmin of group1 again $_POST['groupid'] = $group1->getGID(); $result = $this->api->addSubAdmin([ 'userid' => $user2->getUID(), ]); $this->assertInstanceOf('OC_OCS_Result', $result); $this->assertTrue($result->succeeded()); $group1->delete(); } }