diff options
author | Christoph Wurst <christoph@winzerhof-wurst.at> | 2018-09-26 16:46:35 +0200 |
---|---|---|
committer | Christoph Wurst <christoph@winzerhof-wurst.at> | 2018-09-27 09:44:21 +0200 |
commit | 0259792614e3ed2dd743c2c292d8d90e2b0a05aa (patch) | |
tree | 027a4bd7c17368b9ac6110fc8f03bef8131b85dc /tests | |
parent | cd05670517da0cecfa8c6277c015fa33fae3394d (diff) | |
download | nextcloud-server-0259792614e3ed2dd743c2c292d8d90e2b0a05aa.tar.gz nextcloud-server-0259792614e3ed2dd743c2c292d8d90e2b0a05aa.zip |
Reduce settings manager complexity by loading sections via DI
Signed-off-by: Christoph Wurst <christoph@winzerhof-wurst.at>
Diffstat (limited to 'tests')
-rw-r--r-- | tests/lib/Settings/ManagerTest.php | 81 |
1 files changed, 32 insertions, 49 deletions
diff --git a/tests/lib/Settings/ManagerTest.php b/tests/lib/Settings/ManagerTest.php index 6f9af39d591..af472875faf 100644 --- a/tests/lib/Settings/ManagerTest.php +++ b/tests/lib/Settings/ManagerTest.php @@ -23,27 +23,20 @@ namespace Tests\Settings; -use OC\Accounts\AccountManager; use OC\Settings\Admin\Sharing; use OC\Settings\Manager; use OC\Settings\Mapper; use OC\Settings\Personal\Security; use OC\Settings\Section; -use OCP\App\IAppManager; -use OCP\Encryption\IManager; -use OCP\IConfig; use OCP\IDBConnection; -use OCP\IGroupManager; use OCP\IL10N; use OCP\ILogger; -use OCP\IRequest; +use OCP\IServerContainer; use OCP\IURLGenerator; -use OCP\IUserManager; -use OCP\L10N\IFactory; -use OCP\Lock\ILockingProvider; use Test\TestCase; class ManagerTest extends TestCase { + /** @var Manager|\PHPUnit_Framework_MockObject_MockObject */ private $manager; /** @var ILogger|\PHPUnit_Framework_MockObject_MockObject */ @@ -52,26 +45,10 @@ class ManagerTest extends TestCase { private $dbConnection; /** @var IL10N|\PHPUnit_Framework_MockObject_MockObject */ private $l10n; - /** @var IConfig|\PHPUnit_Framework_MockObject_MockObject */ - private $config; - /** @var IManager|\PHPUnit_Framework_MockObject_MockObject */ - private $encryptionManager; - /** @var IUserManager|\PHPUnit_Framework_MockObject_MockObject */ - private $userManager; - /** @var ILockingProvider|\PHPUnit_Framework_MockObject_MockObject */ - private $lockingProvider; - /** @var IRequest|\PHPUnit_Framework_MockObject_MockObject */ - private $request; /** @var IURLGenerator|\PHPUnit_Framework_MockObject_MockObject */ private $url; - /** @var AccountManager|\PHPUnit_Framework_MockObject_MockObject */ - private $accountManager; - /** @var IGroupManager|\PHPUnit_Framework_MockObject_MockObject */ - private $groupManager; - /** @var IFactory|\PHPUnit_Framework_MockObject_MockObject */ - private $l10nFactory; - /** @var IAppManager */ - private $appManager; + /** @var IServerContainer|\PHPUnit_Framework_MockObject_MockObject */ + private $container; public function setUp() { parent::setUp(); @@ -79,31 +56,15 @@ class ManagerTest extends TestCase { $this->logger = $this->createMock(ILogger::class); $this->dbConnection = $this->createMock(IDBConnection::class); $this->l10n = $this->createMock(IL10N::class); - $this->config = $this->createMock(IConfig::class); - $this->encryptionManager = $this->createMock(IManager::class); - $this->userManager = $this->createMock(IUserManager::class); - $this->lockingProvider = $this->createMock(ILockingProvider::class); - $this->request = $this->createMock(IRequest::class); $this->url = $this->createMock(IURLGenerator::class); - $this->accountManager = $this->createMock(AccountManager::class); - $this->groupManager = $this->createMock(IGroupManager::class); - $this->l10nFactory = $this->createMock(IFactory::class); - $this->appManager = $this->createMock(IAppManager::class); + $this->container = $this->createMock(IServerContainer::class); $this->manager = new Manager( $this->logger, $this->dbConnection, $this->l10n, - $this->config, - $this->encryptionManager, - $this->userManager, - $this->lockingProvider, - $this->request, $this->url, - $this->accountManager, - $this->groupManager, - $this->l10nFactory, - $this->appManager + $this->container ); } @@ -210,15 +171,37 @@ class ManagerTest extends TestCase { } public function testGetAdminSettings() { + $section = $this->createMock(Sharing::class); + $section->expects($this->once()) + ->method('getPriority') + ->willReturn(13); + $this->container->expects($this->once()) + ->method('query') + ->with(Sharing::class) + ->willReturn($section); + + $settings = $this->manager->getAdminSettings('sharing'); + $this->assertEquals([ - 0 => [new Sharing($this->config, $this->l10n)], - ], $this->manager->getAdminSettings('sharing')); + 13 => [$section] + ], $settings); } public function testGetPersonalSettings() { + $section = $this->createMock(Security::class); + $section->expects($this->once()) + ->method('getPriority') + ->willReturn(16); + $this->container->expects($this->once()) + ->method('query') + ->with(Security::class) + ->willReturn($section); + + $settings = $this->manager->getPersonalSettings('security'); + $this->assertEquals([ - 10 => [new Security($this->userManager)], - ], $this->manager->getPersonalSettings('security')); + 16 => [$section] + ], $settings); } public function testSameSectionAsPersonalAndAdmin() { |