Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add resource hints transformers #179

Merged
merged 37 commits into from
Jun 10, 2021
Merged
Changes from 1 commit
Commits
Show all changes
37 commits
Select commit Hold shift + click to select a range
6fa218e
Add initial scaffolding for link management
schlessera Nov 25, 2020
82eeaf4
Ignore HTML special char entity encoding mismatches in assertSimilarM…
schlessera Nov 29, 2020
b734f1e
Add tests for Google Fonts preconnect
schlessera Nov 29, 2020
b835bad
Add logic to detect usage of Google Fonts
schlessera Nov 29, 2020
4ef17b8
Change LinkManager link placement
schlessera Nov 29, 2020
3bfa743
Improve preconnect generation according to best practices
schlessera Nov 29, 2020
e4e611d
Use resource hint terminology
schlessera Nov 29, 2020
2152d8c
Add ResourceHintManager::addPreload() helper
schlessera Nov 30, 2020
6a4c48b
Add scaffolding for adding AMP runtime script and style preloads
schlessera Nov 30, 2020
51611f0
Rename ResourceHints into GooglePreconnects to split up transformers
schlessera Nov 30, 2020
5772a5c
Harden resource hint manager reference node logic
schlessera Nov 30, 2020
5280f04
Add AmpRuntimePreloads transformer
schlessera Nov 30, 2020
dda1127
Fix line length CS issue in Dom\Document
schlessera Nov 30, 2020
c6191d1
Rename GoogleFontsPreconnectTest
schlessera Dec 3, 2020
40a50c4
Add TODO for AMP runtime is needed condition
schlessera Dec 14, 2020
e3fc16c
Add tests for AMP runtime CSS preload
schlessera Dec 14, 2020
b0f6d93
Add GoogleFontsPreconnect spec tests
schlessera Dec 15, 2020
dfcbd14
Fix test failures
schlessera May 3, 2021
e1d4687
Rename property $linkManager -> $resourceHints
schlessera May 3, 2021
2c1588c
Add tests for resource hint manager
schlessera May 3, 2021
08285b0
Include AmpRuntimePreloads in list of default transformers
schlessera May 3, 2021
26cd737
Add covers annotations for AmpRuntimePreloadsTest
schlessera May 3, 2021
34b9189
Make URL check for Google API domain stricter
schlessera May 3, 2021
1cb6796
Rename ResourceHintManager back to LinkManager
schlessera May 11, 2021
5a5dd19
Rephrase crossorigin argument
schlessera May 11, 2021
6c9aae1
Improve docblocks
schlessera May 11, 2021
ddf7ee4
Add missing resource hints
schlessera May 11, 2021
50956fe
Adapt tests
schlessera May 11, 2021
657f2ab
Rename Google Fonts constants
schlessera May 11, 2021
0890944
Use renamed constants
schlessera May 11, 2021
300a078
Add modulepreload
schlessera May 11, 2021
f8170a3
Add replacement and removal to link manager
schlessera May 25, 2021
4cd2c0d
Make RewriteAmpUrls use link manager
schlessera May 25, 2021
3b6d5a9
Ensure that the host is only replaced once
schlessera May 25, 2021
52c903d
Fix PHPStan issue
schlessera May 25, 2021
5831c16
Fix missing import
schlessera Jun 7, 2021
c3a2159
Remove unused variables
schlessera Jun 7, 2021
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Add tests for Google Fonts preconnect
  • Loading branch information
schlessera committed Jun 7, 2021
commit b734f1ec43374a7c318d1582d44be67c5bb47a46
86 changes: 86 additions & 0 deletions tests/Optimizer/Transformer/BrowserHintsTest.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,86 @@
<?php

namespace AmpProject\Optimizer\Transformer;

use AmpProject\Dom\Document;
use AmpProject\Optimizer\Error;
use AmpProject\Optimizer\ErrorCollection;
use AmpProject\Tests\ErrorComparison;
use AmpProject\Tests\MarkupComparison;
use AmpProject\Tests\TestMarkup;
use PHPUnit\Framework\TestCase;

/**
* Test the BrowserHints transformer.
*
* @package ampproject/amp-toolbox
*/
final class BrowserHintsTest extends TestCase
{
use ErrorComparison;
use MarkupComparison;

/**
* Provide the data to test the transform() method.
*
* @return array[] Associative array of data arrays.
*/
public function dataTransform()
{
$input = static function ($head, $hints = '') {
return TestMarkup::DOCTYPE . '<html ⚡><head>'
. TestMarkup::META_CHARSET . TestMarkup::META_VIEWPORT . $hints . TestMarkup::SCRIPT_AMPRUNTIME
. TestMarkup::LINK_FAVICON . TestMarkup::LINK_CANONICAL . TestMarkup::STYLE_AMPBOILERPLATE . TestMarkup::NOSCRIPT_AMPBOILERPLATE
. $head
. '</head><body></body></html>';
};

$output = static function ($head, $hints = '') {
return TestMarkup::DOCTYPE . '<html ⚡><head>'
. TestMarkup::META_CHARSET . TestMarkup::META_VIEWPORT . $hints . TestMarkup::SCRIPT_AMPRUNTIME
. TestMarkup::LINK_FAVICON . TestMarkup::LINK_CANONICAL . TestMarkup::STYLE_AMPBOILERPLATE . TestMarkup::NOSCRIPT_AMPBOILERPLATE
. $head
. '</head><body></body></html>';
};

return [
'documents with google fonts do preconnect' => [
$input(
'<link href="https://fonts.googleapis.com/css?family=Karla&display=swap" rel="stylesheet">'
),
$output(
'<link href="https://fonts.googleapis.com/css?family=Karla&display=swap" rel="stylesheet">',
'<link crossorigin href="https://fonts.gstatic.com/" rel="dns-prefetch preconnect">'
),
],

'documents without google fonts do not preconnect' => [
$input(''),
$output(''),
],
];
}

/**
* Test the transform() method.
*
* @covers \AmpProject\Optimizer\Transformer\BrowserHints::transform()
* @dataProvider dataTransform()
*
* @param string $source String of source HTML.
* @param string $expectedHtml String of expected HTML output.
* @param ErrorCollection|Error[] $expectedErrors Set of expected errors.
* @param array $config Configuration data to use.
*/
public function testTransform($source, $expectedHtml, $expectedErrors = [], $config = [])
{
$document = Document::fromHtml($source);
$transformer = new BrowserHints();
$errors = new ErrorCollection();

$transformer->transform($document, $errors);

$this->assertSimilarMarkup($expectedHtml, $document->saveHTML());
$this->assertSameErrors($expectedErrors, $errors);
}
}