summaryrefslogtreecommitdiffstats
path: root/apps/updatenotification/tests/UpdateCheckerTest.php
diff options
context:
space:
mode:
Diffstat (limited to 'apps/updatenotification/tests/UpdateCheckerTest.php')
-rw-r--r--apps/updatenotification/tests/UpdateCheckerTest.php38
1 files changed, 30 insertions, 8 deletions
diff --git a/apps/updatenotification/tests/UpdateCheckerTest.php b/apps/updatenotification/tests/UpdateCheckerTest.php
index 0a82f950b9a..16861eea54e 100644
--- a/apps/updatenotification/tests/UpdateCheckerTest.php
+++ b/apps/updatenotification/tests/UpdateCheckerTest.php
@@ -25,11 +25,14 @@ declare(strict_types=1);
namespace OCA\UpdateNotification\Tests;
+use OC\Updater\ChangesCheck;
use OC\Updater\VersionCheck;
use OCA\UpdateNotification\UpdateChecker;
use Test\TestCase;
class UpdateCheckerTest extends TestCase {
+ /** @var ChangesCheck|\PHPUnit_Framework_MockObject_MockObject */
+ protected $changesChecker;
/** @var VersionCheck|\PHPUnit_Framework_MockObject_MockObject */
private $updater;
/** @var UpdateChecker */
@@ -39,7 +42,8 @@ class UpdateCheckerTest extends TestCase {
parent::setUp();
$this->updater = $this->createMock(VersionCheck::class);
- $this->updateChecker = new UpdateChecker($this->updater);
+ $this->changesChecker = $this->createMock(ChangesCheck::class);
+ $this->updateChecker = new UpdateChecker($this->updater, $this->changesChecker);
}
public function testGetUpdateStateWithUpdateAndInvalidLink() {
@@ -51,8 +55,7 @@ class UpdateCheckerTest extends TestCase {
'versionstring' => 'Nextcloud 123',
'web'=> 'javascript:alert(1)',
'url'=> 'javascript:alert(2)',
- 'changelog' => 'javascript:alert(3)',
- 'whatsNew' => 'javascript:alert(4)',
+ 'changes' => 'javascript:alert(3)',
'autoupdater'=> '0',
'eol'=> '1',
]);
@@ -67,20 +70,40 @@ class UpdateCheckerTest extends TestCase {
}
public function testGetUpdateStateWithUpdateAndValidLink() {
+ $changes = [
+ 'changelog' => 'https://nextcloud.com/changelog/#123-0-0',
+ 'whatsNew' => [
+ 'en' => [
+ 'regular' => [
+ 'Yardarm heave to brig spyglass smartly pillage',
+ 'Bounty gangway bilge skysail rope\'s end',
+ 'Maroon cutlass spirits nipperkin Plate Fleet',
+ ],
+ 'admin' => [
+ 'Scourge of the seven seas coffer doubloon',
+ 'Brig me splice the main brace',
+ ]
+ ]
+ ]
+ ];
+
$this->updater
->expects($this->once())
->method('check')
->willReturn([
- 'version' => 123,
+ 'version' => '123',
'versionstring' => 'Nextcloud 123',
'web'=> 'https://docs.nextcloud.com/myUrl',
'url'=> 'https://downloads.nextcloud.org/server',
- 'changelog' => 'https://nextcloud.com/changelog/#123.0.0',
- 'whatsNew' => ['Brews coffee', 'Makes appointments', 'Orchestrates Terminators'],
+ 'changes' => 'https://updates.nextcloud.com/changelog_server/?version=123.0.0',
'autoupdater'=> '1',
'eol'=> '0',
]);
+ $this->changesChecker->expects($this->once())
+ ->method('check')
+ ->willReturn($changes);
+
$expected = [
'updateAvailable' => true,
'updateVersion' => 'Nextcloud 123',
@@ -88,8 +111,7 @@ class UpdateCheckerTest extends TestCase {
'versionIsEol' => false,
'updateLink' => 'https://docs.nextcloud.com/myUrl',
'downloadLink' => 'https://downloads.nextcloud.org/server',
- 'changelog' => 'https://nextcloud.com/changelog/#123.0.0',
- 'whatsNew' => ['Brews coffee', 'Makes appointments', 'Orchestrates Terminators'],
+ 'changes' => $changes,
];
$this->assertSame($expected, $this->updateChecker->getUpdateState());
}