Skip to content

Commit

Permalink
fix(@angular-devkit/build-angular): fix issue were @media all causi…
Browse files Browse the repository at this point in the history
…ng critical CSS inling to fail

Workaround for Critters as it doesn't work when `@media all {}` is minified to `@media {}`.

Closes #20804
  • Loading branch information
alan-agius4 authored and filipesilva committed Jul 9, 2021
1 parent 5203415 commit 3d71c63
Show file tree
Hide file tree
Showing 3 changed files with 166 additions and 66 deletions.

This file was deleted.

Original file line number Diff line number Diff line change
@@ -0,0 +1,163 @@
/**
* @license
* Copyright Google LLC All Rights Reserved.
*
* Use of this source code is governed by an MIT-style license that can be
* found in the LICENSE file at https://angular.io/license
*/

import { buildWebpackBrowser } from '../../index';
import { BASE_OPTIONS, BROWSER_BUILDER_INFO, describeBuilder } from '../setup';

describeBuilder(buildWebpackBrowser, BROWSER_BUILDER_INFO, (harness) => {
describe('Option: "inlineCritical"', () => {
beforeEach(async () => {
await harness.writeFile('src/styles.css', 'body { color: #000 }');
});

it(`should extract critical css when 'inlineCritical' is true`, async () => {
harness.useTarget('build', {
...BASE_OPTIONS,
optimization: {
scripts: false,
styles: {
minify: true,
inlineCritical: true,
},
fonts: false,
},
styles: ['src/styles.css'],
});

const { result } = await harness.executeOnce();

expect(result?.success).toBe(true);
harness
.expectFile('dist/index.html')
.content.toContain(
`<link rel="stylesheet" href="styles.css" media="print" onload="this.media='all'">`,
);
harness.expectFile('dist/index.html').content.toContain(`body{color:#000;}`);
});

it(`should extract critical css when 'optimization' is unset`, async () => {
harness.useTarget('build', {
...BASE_OPTIONS,
styles: ['src/styles.css'],
optimization: undefined,
});

const { result } = await harness.executeOnce();

expect(result?.success).toBe(true);
harness
.expectFile('dist/index.html')
.content.toContain(
`<link rel="stylesheet" href="styles.css" media="print" onload="this.media='all'">`,
);
harness.expectFile('dist/index.html').content.toContain(`body{color:#000;}`);
});

it(`should extract critical css when 'optimization' is true`, async () => {
harness.useTarget('build', {
...BASE_OPTIONS,
styles: ['src/styles.css'],
optimization: true,
});

const { result } = await harness.executeOnce();

expect(result?.success).toBe(true);
harness
.expectFile('dist/index.html')
.content.toContain(
`<link rel="stylesheet" href="styles.css" media="print" onload="this.media='all'">`,
);
harness.expectFile('dist/index.html').content.toContain(`body{color:#000;}`);
});

it(`should not extract critical css when 'optimization' is false`, async () => {
harness.useTarget('build', {
...BASE_OPTIONS,
styles: ['src/styles.css'],
optimization: false,
});

const { result } = await harness.executeOnce();

expect(result?.success).toBe(true);
harness.expectFile('dist/index.html').content.not.toContain(`<style`);
});

it(`should not extract critical css when 'inlineCritical' is false`, async () => {
harness.useTarget('build', {
...BASE_OPTIONS,
styles: ['src/styles.css'],
optimization: {
scripts: false,
styles: {
minify: false,
inlineCritical: false,
},
fonts: false,
},
});

const { result } = await harness.executeOnce();

expect(result?.success).toBe(true);
harness.expectFile('dist/index.html').content.not.toContain(`<style`);
});

it(`should extract critical css when 'inlineCritical' when using 'deployUrl'`, async () => {
harness.useTarget('build', {
...BASE_OPTIONS,
deployUrl: 'http://cdn.com/',
optimization: {
scripts: false,
styles: {
minify: true,
inlineCritical: true,
},
fonts: false,
},
styles: ['src/styles.css'],
});

const { result } = await harness.executeOnce();
expect(result?.success).toBe(true);
harness
.expectFile('dist/index.html')
.content.toContain(
`<link rel="stylesheet" href="http://cdn.com/styles.css" media="print" onload="this.media='all'">`,
);
harness.expectFile('dist/index.html').content.toContain(`body{color:#000;}`);
});

it(`should extract critical css when using '@media all {}' and 'minify' is set to true`, async () => {
harness.useTarget('build', {
...BASE_OPTIONS,
styles: ['src/styles.css'],
optimization: {
scripts: false,
styles: {
minify: true,
inlineCritical: true,
},
fonts: false,
},
});

await harness.writeFile('src/styles.css', '@media all { body { color: #000 } }');

const { result } = await harness.executeOnce();
expect(result?.success).toBe(true);
harness
.expectFile('dist/index.html')
.content.toContain(
`<link rel="stylesheet" href="styles.css" media="print" onload="this.media='all'">`,
);
harness.expectFile('dist/index.html').content.toContain(`body{color:#000;}`);
});
});
});
Original file line number Diff line number Diff line change
Expand Up @@ -287,6 +287,9 @@ export function getStylesConfig(wco: WebpackConfigOptions): webpack.Configuratio
calc: false,
// Disable CSS rules sorted due to several issues #20693, https://github.com/ionic-team/ionic-framework/issues/23266 and https://github.com/cssnano/cssnano/issues/1054
cssDeclarationSorter: false,
// Workaround for Critters as it doesn't work when `@media all {}` is minified to `@media {}`.
// TODO: Remove once they move to postcss.
minifyParams: !buildOptions.optimization.styles.inlineCritical,
},
],
};
Expand Down

0 comments on commit 3d71c63

Please sign in to comment.