From fa78926a8f00cb901cb153b8ff1ac8b328e5fc77 Mon Sep 17 00:00:00 2001 From: bholmesdev Date: Wed, 15 Feb 2023 16:36:26 -0500 Subject: [PATCH 1/3] fix: avoid trying to SSR md?astroPropagatedAssets --- packages/astro/src/core/render/dev/vite.ts | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) diff --git a/packages/astro/src/core/render/dev/vite.ts b/packages/astro/src/core/render/dev/vite.ts index a3f0b6437821..724ad172f3ae 100644 --- a/packages/astro/src/core/render/dev/vite.ts +++ b/packages/astro/src/core/render/dev/vite.ts @@ -60,7 +60,16 @@ export async function* crawlGraph( if (entryIsStyle && !isCSSRequest(importedModulePathname)) { continue; } - if (fileExtensionsToSSR.has(npath.extname(importedModulePathname))) { + if ( + fileExtensionsToSSR.has( + npath.extname( + // Use `id` instead of `pathname` to preserve query params. + // Should not SSR a module with an unexpected query param, + // like "?astroPropagatedAssets" + importedModule.id + ) + ) + ) { const mod = loader.getModuleById(importedModule.id); if (!mod?.ssrModule) { try { From 4591988896d34e2c5a4e61cf499aa68635e43bcb Mon Sep 17 00:00:00 2001 From: bholmesdev Date: Wed, 15 Feb 2023 16:51:51 -0500 Subject: [PATCH 2/3] test: layout prop with recursive getCollection --- .../test/content-collections-render.test.js | 19 ++++++++++ .../content/src/components/LayoutProp.astro | 38 +++++++++++++++++++ .../src/content/blog/with-layout-prop.md | 9 +++++ .../content/src/pages/with-layout-prop.astro | 7 ++++ 4 files changed, 73 insertions(+) create mode 100644 packages/astro/test/fixtures/content/src/components/LayoutProp.astro create mode 100644 packages/astro/test/fixtures/content/src/content/blog/with-layout-prop.md create mode 100644 packages/astro/test/fixtures/content/src/pages/with-layout-prop.astro diff --git a/packages/astro/test/content-collections-render.test.js b/packages/astro/test/content-collections-render.test.js index 8410487c62a4..2aea21a74711 100644 --- a/packages/astro/test/content-collections-render.test.js +++ b/packages/astro/test/content-collections-render.test.js @@ -191,5 +191,24 @@ describe('Content Collections - render()', () => { expect(h2).to.have.a.lengthOf(1); expect(h2.attr('data-components-export-applied')).to.equal('true'); }); + + it('Supports layout prop with recursive getCollection() call', async () => { + const response = await fixture.fetch('/with-layout-prop', { method: 'GET' }); + expect(response.status).to.equal(200); + + const html = await response.text(); + const $ = cheerio.load(html); + + const body = $('body'); + expect(body.attr('data-layout-prop')).to.equal('true'); + + const h1 = $('h1'); + expect(h1).to.have.a.lengthOf(1); + expect(h1.text()).to.equal('With Layout Prop'); + + const h2 = $('h2'); + expect(h2).to.have.a.lengthOf(1); + expect(h2.text()).to.equal('Content with a layout prop'); + }); }); }); diff --git a/packages/astro/test/fixtures/content/src/components/LayoutProp.astro b/packages/astro/test/fixtures/content/src/components/LayoutProp.astro new file mode 100644 index 000000000000..df7493c3e05c --- /dev/null +++ b/packages/astro/test/fixtures/content/src/components/LayoutProp.astro @@ -0,0 +1,38 @@ +--- +import { CollectionEntry, getCollection } from 'astro:content'; + +// Test for recursive `getCollection()` calls +const blog = await getCollection('blog'); + +type Props = { + content: CollectionEntry<'blog'>['data']; +}; + +const { + content: { title }, +} = Astro.props; +--- + + + + + + + + With Layout Prop + + +

{title}

+ + + + + diff --git a/packages/astro/test/fixtures/content/src/content/blog/with-layout-prop.md b/packages/astro/test/fixtures/content/src/content/blog/with-layout-prop.md new file mode 100644 index 000000000000..ce8a866cb9c0 --- /dev/null +++ b/packages/astro/test/fixtures/content/src/content/blog/with-layout-prop.md @@ -0,0 +1,9 @@ +--- +title: With Layout Prop +description: Use a layout prop in a content collection +layout: "../../components/LayoutProp.astro" +--- + +## Content with a layout prop + +Sure, why not? diff --git a/packages/astro/test/fixtures/content/src/pages/with-layout-prop.astro b/packages/astro/test/fixtures/content/src/pages/with-layout-prop.astro new file mode 100644 index 000000000000..672430ab5452 --- /dev/null +++ b/packages/astro/test/fixtures/content/src/pages/with-layout-prop.astro @@ -0,0 +1,7 @@ +--- +import { getEntryBySlug } from 'astro:content'; + +const entry = await getEntryBySlug('blog', 'with-layout-prop'); +const { Content } = await entry.render(); +--- + From c3bd14e508710fb268e679953f92735aa61ca906 Mon Sep 17 00:00:00 2001 From: bholmesdev Date: Thu, 16 Feb 2023 12:06:26 -0500 Subject: [PATCH 3/3] chore: changeset --- .changeset/metal-ducks-invite.md | 5 +++++ 1 file changed, 5 insertions(+) create mode 100644 .changeset/metal-ducks-invite.md diff --git a/.changeset/metal-ducks-invite.md b/.changeset/metal-ducks-invite.md new file mode 100644 index 000000000000..9ee7653e0a6f --- /dev/null +++ b/.changeset/metal-ducks-invite.md @@ -0,0 +1,5 @@ +--- +'astro': patch +--- + +Fix: prevent dev server hanging for `getCollection()` calls within a layout when using the `layout` prop