diff options
author | Lukas Reschke <lukas@statuscode.ch> | 2017-11-06 15:54:56 +0300 |
---|---|---|
committer | Andras Timar <andras.timar@collabora.com> | 2017-11-06 15:54:56 +0300 |
commit | 9bf62db3aaf332b867f69c368bc366358a908ebd (patch) | |
tree | c0b8d14053cd1b35a7d37df8c096e238c8ffd8b1 /tests | |
parent | 418b5aceaf7eb7b161976525b55d18482242de98 (diff) |
Add option to enable the app only for users in a specific group (#135)
Signed-off-by: Lukas Reschke <lukas@statuscode.ch>
Diffstat (limited to 'tests')
-rw-r--r-- | tests/lib/PermissionManagerTest.php | 118 |
1 files changed, 118 insertions, 0 deletions
diff --git a/tests/lib/PermissionManagerTest.php b/tests/lib/PermissionManagerTest.php new file mode 100644 index 00000000..ed498e63 --- /dev/null +++ b/tests/lib/PermissionManagerTest.php @@ -0,0 +1,118 @@ +<?php +/** + * @copyright Copyright (c) 2017 Lukas Reschke <lukas@statuscode.ch> + * + * @license GNU AGPL version 3 or any later version + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU Affero General Public License as + * published by the Free Software Foundation, either version 3 of the + * License, or (at your option) any later version. + * + * 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 + * along with this program. If not, see <http://www.gnu.org/licenses/>. + * + */ + +namespace Tests\Richdocuments; + +use OCA\Richdocuments\PermissionManager; +use OCP\IConfig; +use OCP\IGroupManager; +use OCP\IUser; +use Test\TestCase; + +class PermissionManagerTest extends TestCase { + /** @var IConfig|\PHPUnit_Framework_MockObject_MockBuilder */ + private $config; + /** @var IGroupManager|\PHPUnit_Framework_MockObject_MockBuilder */ + private $groupManager; + /** @var PermissionManager */ + private $permissionManager; + + public function setUp() { + parent::setUp(); + $this->config = $this->createMock(IConfig::class); + $this->groupManager = $this->createMock(IGroupManager::class); + $this->permissionManager = new PermissionManager($this->config, $this->groupManager); + } + + public function testIsEnabledForUserEnabledNoRestrictions() { + /** @var IUser|\PHPUnit_Framework_MockObject_MockBuilder $user */ + $user = $this->createMock(IUser::class); + + $this->config + ->expects($this->once()) + ->method('getAppValue') + ->with('richdocuments', 'use_groups', '') + ->willReturn(''); + + $this->assertTrue($this->permissionManager->isEnabledForUser($user)); + } + + public function testIsEnabledForUserEnabledNotInGroup() { + /** @var IUser|\PHPUnit_Framework_MockObject_MockBuilder $user */ + $user = $this->createMock(IUser::class); + $user + ->expects($this->once()) + ->method('getUID') + ->willReturn('TestUser'); + + $this->config + ->expects($this->once()) + ->method('getAppValue') + ->with('richdocuments', 'use_groups', '') + ->willReturn('Enabled1|Enabled2|Enabled3'); + + $this->groupManager + ->expects($this->at(0)) + ->method('isInGroup') + ->with('TestUser', 'Enabled1') + ->willReturn(false); + $this->groupManager + ->expects($this->at(1)) + ->method('isInGroup') + ->with('TestUser', 'Enabled2') + ->willReturn(false); + $this->groupManager + ->expects($this->at(2)) + ->method('isInGroup') + ->with('TestUser', 'Enabled3') + ->willReturn(false); + + $this->assertFalse($this->permissionManager->isEnabledForUser($user)); + } + + public function testIsEnabledForUserEnabledInGroup() { + /** @var IUser|\PHPUnit_Framework_MockObject_MockBuilder $user */ + $user = $this->createMock(IUser::class); + $user + ->expects($this->once()) + ->method('getUID') + ->willReturn('TestUser'); + + $this->config + ->expects($this->once()) + ->method('getAppValue') + ->with('richdocuments', 'use_groups', '') + ->willReturn('Enabled1|Enabled2|Enabled3'); + + $this->groupManager + ->expects($this->at(0)) + ->method('isInGroup') + ->with('TestUser', 'Enabled1') + ->willReturn(false); + $this->groupManager + ->expects($this->at(1)) + ->method('isInGroup') + ->with('TestUser', 'Enabled2') + ->willReturn(true); + + $this->assertTrue($this->permissionManager->isEnabledForUser($user)); + } +} |