summaryrefslogtreecommitdiffstats
path: root/tests/Core/Controller
diff options
context:
space:
mode:
authorJulius Härtl <jus@bitgrid.net>2018-01-29 12:52:40 +0100
committerJulius Härtl <jus@bitgrid.net>2018-02-12 17:22:32 +0100
commit8ecac5654323e5d335386874f01b15d680d0febb (patch)
treeca25c200b0e5eb42cc9de1a00e10b3bb55817a27 /tests/Core/Controller
parent6211d18dc103dac3bea6e7cf1c05dca6a8ccf774 (diff)
downloadnextcloud-server-8ecac5654323e5d335386874f01b15d680d0febb.tar.gz
nextcloud-server-8ecac5654323e5d335386874f01b15d680d0febb.zip
Allow requesting absolute URLs
They might be useful when requesting the navigation from the clients Signed-off-by: Julius Härtl <jus@bitgrid.net>
Diffstat (limited to 'tests/Core/Controller')
-rw-r--r--tests/Core/Controller/NavigationControllerTest.php49
1 files changed, 43 insertions, 6 deletions
diff --git a/tests/Core/Controller/NavigationControllerTest.php b/tests/Core/Controller/NavigationControllerTest.php
index 1e9acccb615..3a745b48678 100644
--- a/tests/Core/Controller/NavigationControllerTest.php
+++ b/tests/Core/Controller/NavigationControllerTest.php
@@ -26,6 +26,7 @@ use OC\Core\Controller\NavigationController;
use OCP\AppFramework\Http\JSONResponse;
use OCP\INavigationManager;
use OCP\IRequest;
+use OCP\IURLGenerator;
use Test\TestCase;
class NavigationControllerTest extends TestCase {
@@ -36,20 +37,24 @@ class NavigationControllerTest extends TestCase {
/** @var INavigationManager|\PHPUnit_Framework_MockObject_MockObject */
private $navigationManager;
+ /** @var IURLGenerator|\PHPUnit_Framework_MockObject_MockObject */
+ private $urlGenerator;
+
/** @var NavigationController */
private $controller;
public function setUp() {
parent::setUp();
-
$this->request = $this->createMock(IRequest::class);
$this->navigationManager = $this->createMock(INavigationManager::class);
+ $this->urlGenerator = $this->createMock(IURLGenerator::class);
$this->controller = new NavigationController(
'core',
$this->request,
- $this->navigationManager
+ $this->navigationManager,
+ $this->urlGenerator
);
}
@@ -62,16 +67,48 @@ class NavigationControllerTest extends TestCase {
public function testGetAppNavigation($absolute) {
$this->navigationManager->expects($this->once())
->method('getAll')
- ->with('link', $absolute);
- $this->assertInstanceOf(JSONResponse::class, $this->controller->getAppsNavigation($absolute));
+ ->with('link')
+ ->willReturn([ ['id' => 'files', 'href' => '/index.php/apps/files'] ]);
+ if ($absolute) {
+ $this->urlGenerator->expects($this->any())
+ ->method('getBaseURL')
+ ->willReturn('http://localhost/');
+ $this->urlGenerator->expects($this->once())
+ ->method('getAbsoluteURL')
+ ->with('/index.php/apps/files')
+ ->willReturn('http://localhost/index.php/apps/files');
+ $actual = $this->controller->getAppsNavigation($absolute);
+ $this->assertInstanceOf(JSONResponse::class, $actual);
+ $this->assertEquals('http://localhost/index.php/apps/files', $actual->getData()[0]['href']);
+ } else {
+ $actual = $this->controller->getAppsNavigation($absolute);
+ $this->assertInstanceOf(JSONResponse::class, $actual);
+ $this->assertEquals('/index.php/apps/files', $actual->getData()[0]['href']);
+ }
}
/** @dataProvider dataGetNavigation */
public function testGetSettingsNavigation($absolute) {
$this->navigationManager->expects($this->once())
->method('getAll')
- ->with('settings', $absolute);
- $this->assertInstanceOf(JSONResponse::class, $this->controller->getSettingsNavigation($absolute));
+ ->with('settings')
+ ->willReturn([ ['id' => 'settings', 'href' => '/index.php/settings/user'] ]);
+ if ($absolute) {
+ $this->urlGenerator->expects($this->any())
+ ->method('getBaseURL')
+ ->willReturn('http://localhost/');
+ $this->urlGenerator->expects($this->once())
+ ->method('getAbsoluteURL')
+ ->with('/index.php/settings/user')
+ ->willReturn('http://localhost/index.php/settings/user');
+ $actual = $this->controller->getSettingsNavigation($absolute);
+ $this->assertInstanceOf(JSONResponse::class, $actual);
+ $this->assertEquals('http://localhost/index.php/settings/user', $actual->getData()[0]['href']);
+ } else {
+ $actual = $this->controller->getSettingsNavigation($absolute);
+ $this->assertInstanceOf(JSONResponse::class, $actual);
+ $this->assertEquals('/index.php/settings/user', $actual->getData()[0]['href']);
+ }
}
}