139 lines
3.5 KiB
PHP
139 lines
3.5 KiB
PHP
<?php
|
|
/**
|
|
* @copyright Copyright (c) 2016 Lukas Reschke <lukas@statuscode.ch>
|
|
*
|
|
* @author 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 Test\Settings\Admin;
|
|
|
|
use OC\Encryption\Manager;
|
|
use OC\Settings\Admin\Encryption;
|
|
use OCP\AppFramework\Http\TemplateResponse;
|
|
use OCP\IUserManager;
|
|
use Test\TestCase;
|
|
|
|
class EncryptionTest extends TestCase {
|
|
/** @var Encryption */
|
|
private $admin;
|
|
/** @var Manager */
|
|
private $manager;
|
|
/** @var IUserManager */
|
|
private $userManager;
|
|
|
|
public function setUp() {
|
|
parent::setUp();
|
|
$this->manager = $this->getMockBuilder('\OC\Encryption\Manager')->disableOriginalConstructor()->getMock();
|
|
$this->userManager = $this->getMockBuilder(IUserManager::class)->getMock();
|
|
|
|
$this->admin = new Encryption(
|
|
$this->manager,
|
|
$this->userManager
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @return array
|
|
*/
|
|
public function encryptionSettingsProvider() {
|
|
return [
|
|
[true],
|
|
[false],
|
|
];
|
|
}
|
|
|
|
/**
|
|
* @dataProvider encryptionSettingsProvider
|
|
* @param bool $enabled
|
|
*/
|
|
public function testGetFormWithOnlyOneBackend($enabled) {
|
|
$this->manager
|
|
->expects($this->once())
|
|
->method('isEnabled')
|
|
->willReturn($enabled);
|
|
$this->manager
|
|
->expects($this->once())
|
|
->method('isReady')
|
|
->willReturn($enabled);
|
|
$this->manager
|
|
->expects($this->once())
|
|
->method('getEncryptionModules')
|
|
->willReturn([]);
|
|
$this->userManager
|
|
->expects($this->once())
|
|
->method('getBackends')
|
|
->willReturn(['entry']);
|
|
$expected = new TemplateResponse(
|
|
'settings',
|
|
'settings/admin/encryption',
|
|
[
|
|
'encryptionEnabled' => $enabled,
|
|
'encryptionReady' => $enabled,
|
|
'externalBackendsEnabled' => false,
|
|
'encryptionModules' => []
|
|
],
|
|
''
|
|
);
|
|
$this->assertEquals($expected, $this->admin->getForm());
|
|
}
|
|
|
|
/**
|
|
* @dataProvider encryptionSettingsProvider
|
|
* @param bool $enabled
|
|
*/
|
|
public function testGetFormWithMultipleBackends($enabled) {
|
|
$this->manager
|
|
->expects($this->once())
|
|
->method('isEnabled')
|
|
->willReturn($enabled);
|
|
$this->manager
|
|
->expects($this->once())
|
|
->method('isReady')
|
|
->willReturn($enabled);
|
|
$this->manager
|
|
->expects($this->once())
|
|
->method('getEncryptionModules')
|
|
->willReturn([]);
|
|
$this->userManager
|
|
->expects($this->once())
|
|
->method('getBackends')
|
|
->willReturn(['entry', 'entry']);
|
|
$expected = new TemplateResponse(
|
|
'settings',
|
|
'settings/admin/encryption',
|
|
[
|
|
'encryptionEnabled' => $enabled,
|
|
'encryptionReady' => $enabled,
|
|
'externalBackendsEnabled' => true,
|
|
'encryptionModules' => []
|
|
],
|
|
''
|
|
);
|
|
$this->assertEquals($expected, $this->admin->getForm());
|
|
}
|
|
|
|
public function testGetSection() {
|
|
$this->assertSame('encryption', $this->admin->getSection());
|
|
}
|
|
|
|
public function testGetPriority() {
|
|
$this->assertSame(0, $this->admin->getPriority());
|
|
}
|
|
}
|