aboutsummaryrefslogtreecommitdiffstats
path: root/apps/updatenotification/tests
diff options
context:
space:
mode:
authorszaimen <szaimen@e.mail.de>2022-03-11 12:23:15 +0100
committernextcloud-command <nextcloud-command@users.noreply.github.com>2022-03-24 23:04:33 +0000
commite8122f21c5bdba3e284931b3b076f5b127c062e0 (patch)
tree238149d7d486c5d1b9583809ed6be5e90ca807d4 /apps/updatenotification/tests
parent47c9cd97b937fed2d54fe096512c0efc78f45b94 (diff)
downloadnextcloud-server-e8122f21c5bdba3e284931b3b076f5b127c062e0.tar.gz
nextcloud-server-e8122f21c5bdba3e284931b3b076f5b127c062e0.zip
show warning in update admin overview
Signed-off-by: szaimen <szaimen@e.mail.de> Signed-off-by: nextcloud-command <nextcloud-command@users.noreply.github.com>
Diffstat (limited to 'apps/updatenotification/tests')
-rw-r--r--apps/updatenotification/tests/Settings/AdminTest.php128
1 files changed, 127 insertions, 1 deletions
diff --git a/apps/updatenotification/tests/Settings/AdminTest.php b/apps/updatenotification/tests/Settings/AdminTest.php
index 186c5a09070..852504fb45a 100644
--- a/apps/updatenotification/tests/Settings/AdminTest.php
+++ b/apps/updatenotification/tests/Settings/AdminTest.php
@@ -41,6 +41,8 @@ use OCP\L10N\ILanguageIterator;
use OCP\Support\Subscription\IRegistry;
use OCP\Util;
use Test\TestCase;
+use OCP\IUserManager;
+use Psr\Log\LoggerInterface;
class AdminTest extends TestCase {
/** @var IFactory|\PHPUnit\Framework\MockObject\MockObject */
@@ -57,6 +59,10 @@ class AdminTest extends TestCase {
private $dateTimeFormatter;
/** @var IRegistry|\PHPUnit\Framework\MockObject\MockObject */
private $subscriptionRegistry;
+ /** @var IUserManager|\PHPUnit\Framework\MockObject\MockObject */
+ private $userManager;
+ /** @var LoggerInterface|\PHPUnit\Framework\MockObject\MockObject */
+ private $logger;
protected function setUp(): void {
parent::setUp();
@@ -67,13 +73,58 @@ class AdminTest extends TestCase {
$this->dateTimeFormatter = $this->createMock(IDateTimeFormatter::class);
$this->l10nFactory = $this->createMock(IFactory::class);
$this->subscriptionRegistry = $this->createMock(IRegistry::class);
+ $this->userManager = $this->createMock(IUserManager::class);
+ $this->logger = $this->createMock(LoggerInterface::class);
$this->admin = new Admin(
- $this->config, $this->updateChecker, $this->groupManager, $this->dateTimeFormatter, $this->l10nFactory, $this->subscriptionRegistry
+ $this->config,
+ $this->updateChecker,
+ $this->groupManager,
+ $this->dateTimeFormatter,
+ $this->l10nFactory,
+ $this->subscriptionRegistry,
+ $this->userManager,
+ $this->logger
);
}
public function testGetFormWithUpdate() {
+ $backend1 = $this->createMock(UserInterface::class);
+ $backend2 = $this->createMock(UserInterface::class);
+ $backend3 = $this->createMock(UserInterface::class);
+ $backend1
+ ->expects($this->once())
+ ->method('implementsActions')
+ ->with(Backend::COUNT_USERS)
+ ->willReturn(false);
+ $backend2
+ ->expects($this->once())
+ ->method('implementsActions')
+ ->with(Backend::COUNT_USERS)
+ ->willReturn(true);
+ $backend3
+ ->expects($this->once())
+ ->method('implementsActions')
+ ->with(Backend::COUNT_USERS)
+ ->willReturn(true);
+ $backend1
+ ->expects($this->never())
+ ->method('countUsers');
+ $backend2
+ ->expects($this->once())
+ ->method('countUsers')
+ ->with()
+ ->willReturn(false);
+ $backend3
+ ->expects($this->once())
+ ->method('countUsers')
+ ->with()
+ ->willReturn(5);
+ $this->userManager
+ ->expects($this->once())
+ ->method('getBackends')
+ ->with()
+ ->willReturn([$backend1, $backend2, $backend3]);
$channels = [
'daily',
'beta',
@@ -145,6 +196,7 @@ class AdminTest extends TestCase {
'downloadLink' => 'https://downloads.nextcloud.org/server',
'changes' => [],
'webUpdaterEnabled' => true,
+ 'isWebUpdaterRecommended' => true,
'updaterEnabled' => true,
'versionIsEol' => false,
'isDefaultUpdateServerURL' => true,
@@ -161,6 +213,42 @@ class AdminTest extends TestCase {
}
public function testGetFormWithUpdateAndChangedUpdateServer() {
+ $backend1 = $this->createMock(UserInterface::class);
+ $backend2 = $this->createMock(UserInterface::class);
+ $backend3 = $this->createMock(UserInterface::class);
+ $backend1
+ ->expects($this->once())
+ ->method('implementsActions')
+ ->with(Backend::COUNT_USERS)
+ ->willReturn(false);
+ $backend2
+ ->expects($this->once())
+ ->method('implementsActions')
+ ->with(Backend::COUNT_USERS)
+ ->willReturn(true);
+ $backend3
+ ->expects($this->once())
+ ->method('implementsActions')
+ ->with(Backend::COUNT_USERS)
+ ->willReturn(true);
+ $backend1
+ ->expects($this->never())
+ ->method('countUsers');
+ $backend2
+ ->expects($this->once())
+ ->method('countUsers')
+ ->with()
+ ->willReturn(false);
+ $backend3
+ ->expects($this->once())
+ ->method('countUsers')
+ ->with()
+ ->willReturn(5);
+ $this->userManager
+ ->expects($this->once())
+ ->method('getBackends')
+ ->with()
+ ->willReturn([$backend1, $backend2, $backend3]);
$channels = [
'daily',
'beta',
@@ -232,6 +320,7 @@ class AdminTest extends TestCase {
'downloadLink' => 'https://downloads.nextcloud.org/server',
'changes' => [],
'webUpdaterEnabled' => false,
+ 'isWebUpdaterRecommended' => true,
'updaterEnabled' => true,
'versionIsEol' => false,
'isDefaultUpdateServerURL' => false,
@@ -248,6 +337,42 @@ class AdminTest extends TestCase {
}
public function testGetFormWithUpdateAndCustomersUpdateServer() {
+ $backend1 = $this->createMock(UserInterface::class);
+ $backend2 = $this->createMock(UserInterface::class);
+ $backend3 = $this->createMock(UserInterface::class);
+ $backend1
+ ->expects($this->once())
+ ->method('implementsActions')
+ ->with(Backend::COUNT_USERS)
+ ->willReturn(false);
+ $backend2
+ ->expects($this->once())
+ ->method('implementsActions')
+ ->with(Backend::COUNT_USERS)
+ ->willReturn(true);
+ $backend3
+ ->expects($this->once())
+ ->method('implementsActions')
+ ->with(Backend::COUNT_USERS)
+ ->willReturn(true);
+ $backend1
+ ->expects($this->never())
+ ->method('countUsers');
+ $backend2
+ ->expects($this->once())
+ ->method('countUsers')
+ ->with()
+ ->willReturn(false);
+ $backend3
+ ->expects($this->once())
+ ->method('countUsers')
+ ->with()
+ ->willReturn(5);
+ $this->userManager
+ ->expects($this->once())
+ ->method('getBackends')
+ ->with()
+ ->willReturn([$backend1, $backend2, $backend3]);
$channels = [
'daily',
'beta',
@@ -319,6 +444,7 @@ class AdminTest extends TestCase {
'downloadLink' => 'https://downloads.nextcloud.org/server',
'changes' => [],
'webUpdaterEnabled' => true,
+ 'isWebUpdaterRecommended' => true,
'updaterEnabled' => true,
'versionIsEol' => false,
'isDefaultUpdateServerURL' => true,