127 lines
3.7 KiB
PHP
127 lines
3.7 KiB
PHP
<?php
|
|
/**
|
|
* @copyright Copyright (c) 2016, ownCloud, Inc.
|
|
*
|
|
* @author Joas Schilling <coding@schilljs.com>
|
|
* @author Lukas Reschke <lukas@statuscode.ch>
|
|
* @author Morris Jobke <hey@morrisjobke.de>
|
|
*
|
|
* @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 <http://www.gnu.org/licenses/>
|
|
*
|
|
*/
|
|
|
|
namespace OCA\UpdateNotification\Tests\Settings;
|
|
|
|
use OCA\UpdateNotification\Settings\Admin;
|
|
use OCA\UpdateNotification\UpdateChecker;
|
|
use OCP\AppFramework\Http\TemplateResponse;
|
|
use OCP\IConfig;
|
|
use OCP\IDateTimeFormatter;
|
|
use OCP\Util;
|
|
use Test\TestCase;
|
|
|
|
class AdminTest extends TestCase {
|
|
/** @var Admin */
|
|
private $admin;
|
|
/** @var IConfig|\PHPUnit_Framework_MockObject_MockObject */
|
|
private $config;
|
|
/** @var UpdateChecker|\PHPUnit_Framework_MockObject_MockObject */
|
|
private $updateChecker;
|
|
/** @var IDateTimeFormatter|\PHPUnit_Framework_MockObject_MockObject */
|
|
private $dateTimeFormatter;
|
|
|
|
public function setUp() {
|
|
parent::setUp();
|
|
|
|
$this->config = $this->createMock(IConfig::class);
|
|
$this->updateChecker = $this->createMock(UpdateChecker::class);
|
|
$this->dateTimeFormatter = $this->createMock(IDateTimeFormatter::class);
|
|
|
|
$this->admin = new Admin(
|
|
$this->config,
|
|
$this->updateChecker,
|
|
$this->dateTimeFormatter
|
|
);
|
|
}
|
|
|
|
public function testGetFormWithUpdate() {
|
|
$channels = [
|
|
'daily',
|
|
'beta',
|
|
'stable',
|
|
'production',
|
|
];
|
|
$currentChannel = Util::getChannel();
|
|
|
|
// Remove the currently used channel from the channels list
|
|
if(($key = array_search($currentChannel, $channels, true)) !== false) {
|
|
unset($channels[$key]);
|
|
}
|
|
|
|
$this->config
|
|
->expects($this->exactly(2))
|
|
->method('getAppValue')
|
|
->willReturnMap([
|
|
['core', 'lastupdatedat', '', '12345'],
|
|
['updatenotification', 'notify_groups', '["admin"]', '["admin"]'],
|
|
]);
|
|
$this->config
|
|
->expects($this->once())
|
|
->method('getSystemValue')
|
|
->with('updater.server.url', 'https://updates.nextcloud.com/server/')
|
|
->willReturn('https://updates.nextcloud.com/server/');
|
|
$this->dateTimeFormatter
|
|
->expects($this->once())
|
|
->method('formatDateTime')
|
|
->with('12345')
|
|
->willReturn('LastCheckedReturnValue');
|
|
$this->updateChecker
|
|
->expects($this->once())
|
|
->method('getUpdateState')
|
|
->willReturn([
|
|
'updateAvailable' => true,
|
|
'updateVersion' => '8.1.2',
|
|
'downloadLink' => 'https://downloads.nextcloud.org/server',
|
|
'updaterEnabled' => true,
|
|
]);
|
|
|
|
$params = [
|
|
'isNewVersionAvailable' => true,
|
|
'isUpdateChecked' => true,
|
|
'lastChecked' => 'LastCheckedReturnValue',
|
|
'currentChannel' => Util::getChannel(),
|
|
'channels' => $channels,
|
|
'newVersionString' => '8.1.2',
|
|
'downloadLink' => 'https://downloads.nextcloud.org/server',
|
|
'updaterEnabled' => true,
|
|
'isDefaultUpdateServerURL' => true,
|
|
'updateServerURL' => 'https://updates.nextcloud.com/server/',
|
|
'notify_groups' => 'admin',
|
|
];
|
|
|
|
$expected = new TemplateResponse('updatenotification', 'admin', $params, '');
|
|
$this->assertEquals($expected, $this->admin->getForm());
|
|
}
|
|
|
|
|
|
public function testGetSection() {
|
|
$this->assertSame('server', $this->admin->getSection());
|
|
}
|
|
|
|
public function testGetPriority() {
|
|
$this->assertSame(1, $this->admin->getPriority());
|
|
}
|
|
}
|