mirror of
https://github.com/withastro/astro.git
synced 2025-01-06 22:10:10 -05:00
fix: throw a useful error if rendering undefined entry (#12113)
* fix: throw a useful error if rendering undefined entry * Update .changeset/wise-pumas-fry.md Co-authored-by: Sarah Rainsberger <sarah@rainsberger.ca> --------- Co-authored-by: Emanuele Stoppa <my.burning@gmail.com> Co-authored-by: Sarah Rainsberger <sarah@rainsberger.ca>
This commit is contained in:
parent
4dc00cc7c9
commit
a54e520d3c
5 changed files with 42 additions and 1 deletions
5
.changeset/wise-pumas-fry.md
Normal file
5
.changeset/wise-pumas-fry.md
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
---
|
||||||
|
'astro': patch
|
||||||
|
---
|
||||||
|
|
||||||
|
Adds a helpful error when attempting to render an undefined collection entry
|
|
@ -436,7 +436,11 @@ function updateImageReferencesInData<T extends Record<string, unknown>>(
|
||||||
export async function renderEntry(
|
export async function renderEntry(
|
||||||
entry: DataEntry | { render: () => Promise<{ Content: AstroComponentFactory }> },
|
entry: DataEntry | { render: () => Promise<{ Content: AstroComponentFactory }> },
|
||||||
) {
|
) {
|
||||||
if (entry && 'render' in entry) {
|
if (!entry) {
|
||||||
|
throw new AstroError(AstroErrorData.RenderUndefinedEntryError);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ('render' in entry) {
|
||||||
// This is an old content collection entry, so we use its render method
|
// This is an old content collection entry, so we use its render method
|
||||||
return entry.render();
|
return entry.render();
|
||||||
}
|
}
|
||||||
|
|
|
@ -1410,6 +1410,17 @@ export const UnknownContentCollectionError = {
|
||||||
title: 'Unknown Content Collection Error.',
|
title: 'Unknown Content Collection Error.',
|
||||||
} satisfies ErrorData;
|
} satisfies ErrorData;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @docs
|
||||||
|
* @description
|
||||||
|
* Astro tried to render a content collection entry that was undefined. This can happen if you try to render an entry that does not exist.
|
||||||
|
*/
|
||||||
|
export const RenderUndefinedEntryError = {
|
||||||
|
name: 'RenderUndefinedEntryError',
|
||||||
|
title: 'Attempted to render an undefined content collection entry.',
|
||||||
|
hint: 'Check if the entry is undefined before passing it to `render()`',
|
||||||
|
} satisfies ErrorData;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @docs
|
* @docs
|
||||||
* @description
|
* @description
|
||||||
|
|
|
@ -317,5 +317,12 @@ describe('Content Layer', () => {
|
||||||
assert.ok(updated.fileLoader[0].data.temperament.includes('Bouncy'));
|
assert.ok(updated.fileLoader[0].data.temperament.includes('Bouncy'));
|
||||||
await fixture.resetAllFiles();
|
await fixture.resetAllFiles();
|
||||||
});
|
});
|
||||||
|
|
||||||
|
it('returns an error if we render an undefined entry', async () => {
|
||||||
|
const res = await fixture.fetch('/missing');
|
||||||
|
const text = await res.text();
|
||||||
|
assert.equal(res.status, 500);
|
||||||
|
assert.ok(text.includes('RenderUndefinedEntryError'));
|
||||||
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
14
packages/astro/test/fixtures/content-layer/src/pages/missing.astro
vendored
Normal file
14
packages/astro/test/fixtures/content-layer/src/pages/missing.astro
vendored
Normal file
|
@ -0,0 +1,14 @@
|
||||||
|
---
|
||||||
|
import { getEntry, render } from "astro:content"
|
||||||
|
// Skipping the broken page in production so the build doesn't fail
|
||||||
|
if(import.meta.env.PROD) {
|
||||||
|
return new Response(null, { status: 404 })
|
||||||
|
}
|
||||||
|
|
||||||
|
const entry = await getEntry("spacecraft", "missing")
|
||||||
|
|
||||||
|
const { Content } = await render(entry)
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
<Content />
|
Loading…
Reference in a new issue