diff options
author | Roeland Jago Douma <rullzer@users.noreply.github.com> | 2020-05-13 09:04:56 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-05-13 09:04:56 +0200 |
commit | 7c15c63b05eb4a3e4ff8b8871480707f3b97bc65 (patch) | |
tree | 8afcc2bf5f830dcf77a114056cd4346ee111408b /tests | |
parent | 4fbea316a7eab0104f088a53edd61a70615e355e (diff) | |
parent | 12fa748c49773d57f03052ef3cee4c72a2d3cdcc (diff) | |
download | nextcloud-server-7c15c63b05eb4a3e4ff8b8871480707f3b97bc65.tar.gz nextcloud-server-7c15c63b05eb4a3e4ff8b8871480707f3b97bc65.zip |
Merge pull request #20939 from nextcloud/enh/middleware/not_modified
Move not modified check to the middleware
Diffstat (limited to 'tests')
-rw-r--r-- | tests/lib/AppFramework/Http/DispatcherTest.php | 10 | ||||
-rw-r--r-- | tests/lib/AppFramework/Http/HttpTest.php | 32 | ||||
-rw-r--r-- | tests/lib/AppFramework/Middleware/NotModifiedMiddlewareTest.php | 106 |
3 files changed, 107 insertions, 41 deletions
diff --git a/tests/lib/AppFramework/Http/DispatcherTest.php b/tests/lib/AppFramework/Http/DispatcherTest.php index 74dbf68c28a..c4c973aec90 100644 --- a/tests/lib/AppFramework/Http/DispatcherTest.php +++ b/tests/lib/AppFramework/Http/DispatcherTest.php @@ -181,19 +181,11 @@ class DispatcherTest extends \Test\TestCase { ->method('getStatus') ->willReturn(Http::STATUS_OK); $this->response->expects($this->once()) - ->method('getLastModified') - ->willReturn($this->lastModified); - $this->response->expects($this->once()) - ->method('getETag') - ->willReturn($this->etag); - $this->response->expects($this->once()) ->method('getHeaders') ->willReturn($responseHeaders); $this->http->expects($this->once()) ->method('getStatusHeader') - ->with($this->equalTo(Http::STATUS_OK), - $this->equalTo($this->lastModified), - $this->equalTo($this->etag)) + ->with($this->equalTo(Http::STATUS_OK)) ->willReturn($httpHeaders); $this->middlewareDispatcher->expects($this->once()) diff --git a/tests/lib/AppFramework/Http/HttpTest.php b/tests/lib/AppFramework/Http/HttpTest.php index 009bb39260d..d3d23425f7c 100644 --- a/tests/lib/AppFramework/Http/HttpTest.php +++ b/tests/lib/AppFramework/Http/HttpTest.php @@ -53,38 +53,6 @@ class HttpTest extends \Test\TestCase { $this->assertEquals('HTTP/1.0 200 OK', $header); } - - public function testEtagMatchReturnsNotModified() { - $http = new Http(['HTTP_IF_NONE_MATCH' => 'hi']); - - $header = $http->getStatusHeader(Http::STATUS_OK, null, 'hi'); - $this->assertEquals('HTTP/1.1 304 Not Modified', $header); - } - - - public function testQuotedEtagMatchReturnsNotModified() { - $http = new Http(['HTTP_IF_NONE_MATCH' => '"hi"']); - - $header = $http->getStatusHeader(Http::STATUS_OK, null, 'hi'); - $this->assertEquals('HTTP/1.1 304 Not Modified', $header); - } - - - public function testLastModifiedMatchReturnsNotModified() { - $dateTime = new \DateTime(null, new \DateTimeZone('GMT')); - $dateTime->setTimestamp('12'); - - $http = new Http( - [ - 'HTTP_IF_MODIFIED_SINCE' => 'Thu, 01 Jan 1970 00:00:12 +0000'] - ); - - $header = $http->getStatusHeader(Http::STATUS_OK, $dateTime); - $this->assertEquals('HTTP/1.1 304 Not Modified', $header); - } - - - public function testTempRedirectBecomesFoundInHttp10() { $http = new Http([], 'HTTP/1.0'); diff --git a/tests/lib/AppFramework/Middleware/NotModifiedMiddlewareTest.php b/tests/lib/AppFramework/Middleware/NotModifiedMiddlewareTest.php new file mode 100644 index 00000000000..89ae75bcac2 --- /dev/null +++ b/tests/lib/AppFramework/Middleware/NotModifiedMiddlewareTest.php @@ -0,0 +1,106 @@ +<?php + +declare(strict_types=1); +/** + * @copyright Copyright (c) 2020, Roeland Jago Douma <roeland@famdouma.nl> + * + * @author Roeland Jago Douma <roeland@famdouma.nl> + * + * @license GNU AGPL version 3 or any later version + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU Affero General Public License as + * published by the Free Software Foundation, either version 3 of the + * License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU Affero General Public License for more details. + * + * You should have received a copy of the GNU Affero General Public License + * along with this program. If not, see <http://www.gnu.org/licenses/>. + * + */ + +namespace Test\AppFramework\Middleware; + +use OC\AppFramework\Middleware\NotModifiedMiddleware; +use OCP\AppFramework\Controller; +use OCP\AppFramework\Http; +use OCP\IRequest; + +class NotModifiedMiddlewareTest extends \Test\TestCase { + + /** @var IRequest */ + private $request; + /** @var Controller */ + private $controller; + /** @var NotModifiedMiddleware */ + private $middleWare; + + protected function setUp(): void { + parent::setUp(); + + $this->request = $this->createMock(IRequest::class); + $this->middleWare = new NotModifiedMiddleware( + $this->request + ); + + $this->controller = $this->createMock(Controller::class); + } + + public function dataModified(): array { + $now = new \DateTime(); + + return [ + [null, '', null, '', false], + ['etag', 'etag', null, '', false], + ['etag', '"wrongetag"', null, '', false], + ['etag', '', null, '', false], + [null, '"etag"', null, '', false], + ['etag', '"etag"', null, '', true], + + [null, '', $now, $now->format(\DateTime::RFC2822), true], + [null, '', $now, $now->format(\DateTime::ATOM), false], + [null, '', null, $now->format(\DateTime::RFC2822), false], + [null, '', $now, '', false], + + ['etag', '"etag"', $now, $now->format(\DateTime::ATOM), true], + ['etag', '"etag"', $now, $now->format(\DateTime::RFC2822), true], + ]; + } + + /** + * @dataProvider dataModified + */ + public function testMiddleware(?string $etag, string $etagHeader, ?\DateTime $lastModified, string $lastModifiedHeader, bool $notModifiedSet) { + $this->request->method('getHeader') + ->willReturnCallback(function (string $name) use ($etagHeader, $lastModifiedHeader) { + if ($name === 'IF_NONE_MATCH') { + return $etagHeader; + } + if ($name === 'IF_MODIFIED_SINCE') { + return $lastModifiedHeader; + } + return ''; + }); + + $response = new Http\Response(); + if ($etag !== null) { + $response->setETag($etag); + } + if ($lastModified !== null) { + $response->setLastModified($lastModified); + } + $response->setStatus(Http::STATUS_OK); + + $result = $this->middleWare->afterController($this->controller, 'myfunction', $response); + + if ($notModifiedSet) { + $this->assertSame(Http::STATUS_NOT_MODIFIED, $result->getStatus()); + } else { + $this->assertSame(Http::STATUS_OK, $result->getStatus()); + } + } +} |