From 79b1a8d1bf41099e7537e07201961d926b8c0588 Mon Sep 17 00:00:00 2001 From: Mike Robinson Date: Wed, 23 Jan 2019 06:06:11 -0600 Subject: [PATCH] Add SVG push support and excluding favicons (#24) * Add SVG push support * Update AddHttp2ServerPush.php * Adding page with SVG object * Adding tests for SVG in and tags * Adding SVG * Update pageWithSVGObject.html * Excluding favicons When preloading favicon files (e.g. regular favicon or Apple touch icon), Chrome complains with the following message: > The resource https://example.net/favicon.png was preloaded using link preload but not used within a few seconds from the window's load event. Please make sure it has an appropriate `as` value and it is preloaded intentionally. The syntax for icon files is like: ``` ``` So excluding anything that contains `icon` somewhere in the `rel` attribute would exclude these from being preloaded. * Add files via upload * Adding test for favicons --- src/Middleware/AddHttp2ServerPush.php | 3 ++- tests/AddHttp2ServerPushTest.php | 26 +++++++++++++++++++++++--- tests/fixtures/pageWithFavicon.html | 12 ++++++++++++ tests/fixtures/pageWithImages.html | 1 + tests/fixtures/pageWithSVGObject.html | 11 +++++++++++ 5 files changed, 49 insertions(+), 4 deletions(-) create mode 100644 tests/fixtures/pageWithFavicon.html create mode 100644 tests/fixtures/pageWithSVGObject.html diff --git a/src/Middleware/AddHttp2ServerPush.php b/src/Middleware/AddHttp2ServerPush.php index 2a4cef2..70c5979 100644 --- a/src/Middleware/AddHttp2ServerPush.php +++ b/src/Middleware/AddHttp2ServerPush.php @@ -87,7 +87,7 @@ protected function fetchLinkableNodes($response) { $crawler = $this->getCrawler($response); - return collect($crawler->filter('link, script[src], img[src]')->extract(['src', 'href'])); + return collect($crawler->filter('link:not([rel*="icon"]), script[src], img[src], object[data]')->extract(['src', 'href', 'data'])); } /** @@ -107,6 +107,7 @@ private function buildLinkHeaderString($url) '.JPG' => 'image', '.JPEG' => 'image', '.PNG' => 'image', + '.SVG' => 'image', '.TIFF' => 'image', ]; diff --git a/tests/AddHttp2ServerPushTest.php b/tests/AddHttp2ServerPushTest.php index d0ec4b3..de33856 100644 --- a/tests/AddHttp2ServerPushTest.php +++ b/tests/AddHttp2ServerPushTest.php @@ -2,8 +2,6 @@ namespace JacobBennett\Http2ServerPush\Test; -// TODO: test for invalid file types like .svg - use Illuminate\Http\Request; use JacobBennett\Http2ServerPush\Middleware\AddHttp2ServerPush; use Symfony\Component\HttpFoundation\Response; @@ -57,7 +55,19 @@ public function it_will_return_an_image_link_header_for_images() $this->assertTrue($this->isServerPushResponse($response)); $this->assertStringEndsWith("as=image", $response->headers->get('link')); - $this->assertCount(6, explode(",", $response->headers->get('link'))); + $this->assertCount(7, explode(",", $response->headers->get('link'))); + } + + /** @test */ + public function it_will_return_an_image_link_header_for_svg_objects() + { + $request = new Request(); + + $response = $this->middleware->handle($request, $this->getNext('pageWithSVGObject')); + + $this->assertTrue($this->isServerPushResponse($response)); + $this->assertStringEndsWith("as=image", $response->headers->get('link')); + $this->assertCount(1, explode(",", $response->headers->get('link'))); } /** @test */ @@ -93,6 +103,16 @@ public function it_will_not_return_a_push_header_for_inline_js() $this->assertFalse($this->isServerPushResponse($response)); } + /** @test */ + public function it_will_not_return_a_push_header_for_icons() + { + $request = new Request(); + + $response = $this->middleware->handle($request, $this->getNext('pageWithFavicon')); + + $this->assertFalse($this->isServerPushResponse($response)); + } + /** @test */ public function it_will_return_limit_count_of_links() { diff --git a/tests/fixtures/pageWithFavicon.html b/tests/fixtures/pageWithFavicon.html new file mode 100644 index 0000000..7e75f3f --- /dev/null +++ b/tests/fixtures/pageWithFavicon.html @@ -0,0 +1,12 @@ + + + + Page title + + + + + + + + \ No newline at end of file diff --git a/tests/fixtures/pageWithImages.html b/tests/fixtures/pageWithImages.html index 99d0984..afcb5c4 100644 --- a/tests/fixtures/pageWithImages.html +++ b/tests/fixtures/pageWithImages.html @@ -11,6 +11,7 @@ + diff --git a/tests/fixtures/pageWithSVGObject.html b/tests/fixtures/pageWithSVGObject.html new file mode 100644 index 0000000..c4bab5a --- /dev/null +++ b/tests/fixtures/pageWithSVGObject.html @@ -0,0 +1,11 @@ + + + + Page title + + + + + + +