]> source.dussan.org Git - nextcloud-server.git/commitdiff
Add tests for update notification controller for non-default updater server URL 20704/head
authorMorris Jobke <hey@morrisjobke.de>
Fri, 24 Apr 2020 16:00:49 +0000 (18:00 +0200)
committerbackportbot[bot] <backportbot[bot]@users.noreply.github.com>
Tue, 28 Apr 2020 14:21:05 +0000 (14:21 +0000)
Signed-off-by: Morris Jobke <hey@morrisjobke.de>
apps/updatenotification/lib/Settings/Admin.php
apps/updatenotification/tests/Settings/AdminTest.php

index e7a8f07a1832dd125f760fb206449d6b304efb4b..46206136f7d086d3751d246c9de9d8623c81925b 100644 (file)
@@ -94,7 +94,7 @@ class Admin implements ISettings {
                $defaultCustomerUpdateServerURLPrefix = 'https://updates.nextcloud.com/customers/';
 
                $isDefaultUpdateServerURL = $updateServerURL === $defaultUpdateServerURL
-                       || $updateServerURL === substr($updateServerURL, 0, strlen($defaultCustomerUpdateServerURLPrefix));
+                       || strpos($updateServerURL, $defaultCustomerUpdateServerURLPrefix) === 0;
 
                $hasValidSubscription = $this->subscriptionRegistry->delegateHasValidSubscription();
 
index d2d4b503bad2f4301db3670781151ebe1daccba9..97563496c32d2cc9b6a4ce40f74c6acd305f941f 100644 (file)
@@ -155,6 +155,176 @@ class AdminTest extends TestCase {
                $this->assertEquals($expected, $this->admin->getForm());
        }
 
+       public function testGetFormWithUpdateAndChangedUpdateServer() {
+               $channels = [
+                       'daily',
+                       'beta',
+                       'stable',
+                       'production',
+               ];
+               $currentChannel = Util::getChannel();
+               if ($currentChannel === 'git') {
+                       $channels[] = 'git';
+               }
+
+               $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/updater_server/')
+                       ->willReturn('https://updates.nextcloud.com/updater_server_changed/');
+               $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',
+                               'updateVersionString' => 'Nextcloud 8.1.2',
+                               'downloadLink' => 'https://downloads.nextcloud.org/server',
+                               'changes' => [],
+                               'updaterEnabled' => true,
+                               'versionIsEol' => false,
+                       ]);
+
+               $group = $this->createMock(IGroup::class);
+               $group->expects($this->any())
+                       ->method('getDisplayName')
+                       ->willReturn('Administrators');
+               $group->expects($this->any())
+                       ->method('getGID')
+                       ->willReturn('admin');
+               $this->groupManager->expects($this->once())
+                       ->method('get')
+                       ->with('admin')
+                       ->willReturn($group);
+
+               $this->subscriptionRegistry
+                       ->expects($this->once())
+                       ->method('delegateHasValidSubscription')
+                       ->willReturn(true);
+
+               $params = [
+                       'json' => json_encode([
+                               'isNewVersionAvailable' => true,
+                               'isUpdateChecked' => true,
+                               'lastChecked' => 'LastCheckedReturnValue',
+                               'currentChannel' => Util::getChannel(),
+                               'channels' => $channels,
+                               'newVersion' => '8.1.2',
+                               'newVersionString' => 'Nextcloud 8.1.2',
+                               'downloadLink' => 'https://downloads.nextcloud.org/server',
+                               'changes' => [],
+                               'updaterEnabled' => true,
+                               'versionIsEol' => false,
+                               'isDefaultUpdateServerURL' => false,
+                               'updateServerURL' => 'https://updates.nextcloud.com/updater_server_changed/',
+                               'notifyGroups' => [
+                                       ['value' => 'admin', 'label' => 'Administrators'],
+                               ],
+                               'hasValidSubscription' => true,
+                       ]),
+               ];
+
+               $expected = new TemplateResponse('updatenotification', 'admin', $params, '');
+               $this->assertEquals($expected, $this->admin->getForm());
+       }
+
+       public function testGetFormWithUpdateAndCustomersUpdateServer() {
+               $channels = [
+                       'daily',
+                       'beta',
+                       'stable',
+                       'production',
+               ];
+               $currentChannel = Util::getChannel();
+               if ($currentChannel === 'git') {
+                       $channels[] = 'git';
+               }
+
+               $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/updater_server/')
+                       ->willReturn('https://updates.nextcloud.com/customers/ABC-DEF/');
+               $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',
+                               'updateVersionString' => 'Nextcloud 8.1.2',
+                               'downloadLink' => 'https://downloads.nextcloud.org/server',
+                               'changes' => [],
+                               'updaterEnabled' => true,
+                               'versionIsEol' => false,
+                       ]);
+
+               $group = $this->createMock(IGroup::class);
+               $group->expects($this->any())
+                       ->method('getDisplayName')
+                       ->willReturn('Administrators');
+               $group->expects($this->any())
+                       ->method('getGID')
+                       ->willReturn('admin');
+               $this->groupManager->expects($this->once())
+                       ->method('get')
+                       ->with('admin')
+                       ->willReturn($group);
+
+               $this->subscriptionRegistry
+                       ->expects($this->once())
+                       ->method('delegateHasValidSubscription')
+                       ->willReturn(true);
+
+               $params = [
+                       'json' => json_encode([
+                               'isNewVersionAvailable' => true,
+                               'isUpdateChecked' => true,
+                               'lastChecked' => 'LastCheckedReturnValue',
+                               'currentChannel' => Util::getChannel(),
+                               'channels' => $channels,
+                               'newVersion' => '8.1.2',
+                               'newVersionString' => 'Nextcloud 8.1.2',
+                               'downloadLink' => 'https://downloads.nextcloud.org/server',
+                               'changes' => [],
+                               'updaterEnabled' => true,
+                               'versionIsEol' => false,
+                               'isDefaultUpdateServerURL' => true,
+                               'updateServerURL' => 'https://updates.nextcloud.com/customers/ABC-DEF/',
+                               'notifyGroups' => [
+                                       ['value' => 'admin', 'label' => 'Administrators'],
+                               ],
+                               'hasValidSubscription' => true,
+                       ]),
+               ];
+
+               $expected = new TemplateResponse('updatenotification', 'admin', $params, '');
+               $this->assertEquals($expected, $this->admin->getForm());
+       }
+
 
        public function testGetSection() {
                $this->assertSame('overview', $this->admin->getSection());