diff --git a/.changeset/cuddly-rings-sing.md b/.changeset/cuddly-rings-sing.md new file mode 100644 index 0000000000..a5200c47ca --- /dev/null +++ b/.changeset/cuddly-rings-sing.md @@ -0,0 +1,5 @@ +--- +'astro': patch +--- + +Fixes the issue that audit incorrectly flag images as above the fold when the scrolling container is not body diff --git a/packages/astro/e2e/dev-toolbar-audits.test.js b/packages/astro/e2e/dev-toolbar-audits.test.js index ca74763142..50a4ab1751 100644 --- a/packages/astro/e2e/dev-toolbar-audits.test.js +++ b/packages/astro/e2e/dev-toolbar-audits.test.js @@ -44,6 +44,55 @@ test.describe('Dev Toolbar - Audits', () => { await appButton.click(); }); + test('does not warn about perf issue for below the fold image after mutation when body is unscrollable', async ({ page, astro }) => { + await page.goto(astro.resolveUrl('/audits-perf-body-unscrollable')); + + const toolbar = page.locator('astro-dev-toolbar'); + const appButton = toolbar.locator('button[data-app-id="astro:audit"]'); + await appButton.click(); + + const auditCanvas = toolbar.locator('astro-dev-toolbar-app-canvas[data-app-id="astro:audit"]'); + const auditHighlights = auditCanvas.locator('astro-dev-toolbar-highlight'); + + expect(auditHighlights).toHaveCount(1); + + await page.click('body'); + + let consolePromise = page.waitForEvent('console'); + await page.locator('#mutation-button').click(); + await consolePromise; + + await appButton.click(); + + expect(auditHighlights).toHaveCount(1); + }); + + test('does not warn about perf issue for below the fold image in relative container', async ({ page, astro }) => { + await page.goto(astro.resolveUrl('/audits-perf-relative')); + + const toolbar = page.locator('astro-dev-toolbar'); + const appButton = toolbar.locator('button[data-app-id="astro:audit"]'); + await appButton.click(); + + const auditCanvas = toolbar.locator('astro-dev-toolbar-app-canvas[data-app-id="astro:audit"]'); + const auditHighlights = auditCanvas.locator('astro-dev-toolbar-highlight'); + + expect(auditHighlights).toHaveCount(0); + }); + + test('can warn about perf issue for below the fold image in absolute container', async ({ page, astro }) => { + await page.goto(astro.resolveUrl('/audits-perf-absolute')); + + const toolbar = page.locator('astro-dev-toolbar'); + const appButton = toolbar.locator('button[data-app-id="astro:audit"]'); + await appButton.click(); + + const auditCanvas = toolbar.locator('astro-dev-toolbar-app-canvas[data-app-id="astro:audit"]'); + const auditHighlights = auditCanvas.locator('astro-dev-toolbar-highlight'); + + expect(auditHighlights).toHaveCount(1); + }); + test('can handle mutations', async ({ page, astro }) => { await page.goto(astro.resolveUrl('/audits-mutations')); diff --git a/packages/astro/e2e/fixtures/dev-toolbar/src/pages/audits-perf-absolute.astro b/packages/astro/e2e/fixtures/dev-toolbar/src/pages/audits-perf-absolute.astro new file mode 100644 index 0000000000..2ab42edde1 --- /dev/null +++ b/packages/astro/e2e/fixtures/dev-toolbar/src/pages/audits-perf-absolute.astro @@ -0,0 +1,9 @@ +--- +import { Image } from "astro:assets"; +import walrus from "../light_walrus.avif"; +--- +
+