diff options
author | Julius Härtl <jus@bitgrid.net> | 2018-03-05 12:19:20 +0100 |
---|---|---|
committer | Julius Härtl <jus@bitgrid.net> | 2018-03-05 12:19:20 +0100 |
commit | 723b8764d111fd414cf2e37ae06e0b9a29c9dff7 (patch) | |
tree | 56d532655a7fe1785cec336c81eed03b41256848 /tests/Core/Controller | |
parent | 3ced2c7ab25ae6c7f64d96a4b16754f902a9689f (diff) | |
download | nextcloud-server-723b8764d111fd414cf2e37ae06e0b9a29c9dff7.tar.gz nextcloud-server-723b8764d111fd414cf2e37ae06e0b9a29c9dff7.zip |
Add ETag to NavigationController
Signed-off-by: Julius Härtl <jus@bitgrid.net>
Diffstat (limited to 'tests/Core/Controller')
-rw-r--r-- | tests/Core/Controller/NavigationControllerTest.php | 31 |
1 files changed, 31 insertions, 0 deletions
diff --git a/tests/Core/Controller/NavigationControllerTest.php b/tests/Core/Controller/NavigationControllerTest.php index 1143ed003f0..ef4720604fb 100644 --- a/tests/Core/Controller/NavigationControllerTest.php +++ b/tests/Core/Controller/NavigationControllerTest.php @@ -23,6 +23,7 @@ namespace Tests\Core\Controller; use OC\Core\Controller\NavigationController; +use OCP\AppFramework\Http; use OCP\AppFramework\Http\DataResponse; use OCP\INavigationManager; use OCP\IRequest; @@ -126,4 +127,34 @@ class NavigationControllerTest extends TestCase { } } + public function testGetAppNavigationEtagMatch() { + $navigation = [ ['id' => 'files', 'href' => '/index.php/apps/files', 'icon' => 'icon' ] ]; + $this->request->expects($this->once()) + ->method('getHeader') + ->with('If-None-Match') + ->willReturn(md5(json_encode($navigation))); + $this->navigationManager->expects($this->once()) + ->method('getAll') + ->with('link') + ->willReturn($navigation); + $actual = $this->controller->getAppsNavigation(); + $this->assertInstanceOf(DataResponse::class, $actual); + $this->assertEquals(Http::STATUS_NOT_MODIFIED, $actual->getStatus()); + } + + public function testGetSettingsNavigationEtagMatch() { + $navigation = [ ['id' => 'files', 'href' => '/index.php/apps/files', 'icon' => 'icon' ] ]; + $this->request->expects($this->once()) + ->method('getHeader') + ->with('If-None-Match') + ->willReturn(md5(json_encode($navigation))); + $this->navigationManager->expects($this->once()) + ->method('getAll') + ->with('settings') + ->willReturn($navigation); + $actual = $this->controller->getSettingsNavigation(); + $this->assertInstanceOf(DataResponse::class, $actual); + $this->assertEquals(Http::STATUS_NOT_MODIFIED, $actual->getStatus()); + } + } |