From cd2dbfedb15969274df40b1c41b6680ea8885e8d Mon Sep 17 00:00:00 2001 From: Matthew Phillips Date: Wed, 13 Jul 2022 16:37:17 -0400 Subject: [PATCH] Provide a better error message for when RSS is missing `link` field (#3913) * Provide a better error message for when RSS is missing `link` field * Adds a changeset --- .changeset/weak-mangos-double.md | 5 +++++ packages/astro-rss/src/index.ts | 12 ++++++++++++ packages/astro-rss/test/rss.test.js | 20 ++++++++++++++++++++ 3 files changed, 37 insertions(+) create mode 100644 .changeset/weak-mangos-double.md diff --git a/.changeset/weak-mangos-double.md b/.changeset/weak-mangos-double.md new file mode 100644 index 000000000..d5cbfd741 --- /dev/null +++ b/.changeset/weak-mangos-double.md @@ -0,0 +1,5 @@ +--- +'@astrojs/rss': patch +--- + +Adds error messages for missing required fields diff --git a/packages/astro-rss/src/index.ts b/packages/astro-rss/src/index.ts index 5f7e63b89..2ff803d8b 100644 --- a/packages/astro-rss/src/index.ts +++ b/packages/astro-rss/src/index.ts @@ -113,6 +113,7 @@ export async function generateRSS({ rssOptions, items }: GenerateRSSArgs): Promi if (typeof rssOptions.customData === 'string') xml += rssOptions.customData; // items for (const result of items) { + validate(result); xml += ``; xml += `<![CDATA[${result.title}]]>`; // If the item's link is already a valid URL, don't mess with it. @@ -146,3 +147,14 @@ export async function generateRSS({ rssOptions, items }: GenerateRSSArgs): Promi return xml; } + +const requiredFields = Object.freeze(['link', 'title']); + +// Perform validation to make sure all required fields are passed. +function validate(item: RSSFeedItem) { + for(const field of requiredFields) { + if(!(field in item)) { + throw new Error(`@astrojs/rss: Required field [${field}] is missing. RSS cannot be generated without it.`); + } + } +} diff --git a/packages/astro-rss/test/rss.test.js b/packages/astro-rss/test/rss.test.js index 9962e83f9..bc5816142 100644 --- a/packages/astro-rss/test/rss.test.js +++ b/packages/astro-rss/test/rss.test.js @@ -123,4 +123,24 @@ describe('rss', () => { ).to.be.rejected; }); }); + + describe('errors', () => { + it('should provide a good error message when a link is not provided', async () => { + try { + await rss({ + title: 'Your Website Title', + description: 'Your Website Description', + site: 'https://astro-demo', + items: [{ + pubDate: new Date(), + title: 'Some title', + slug: 'foo' + }] + }); + chai.expect(false).to.equal(true, 'Should have errored'); + } catch(err) { + chai.expect(err.message).to.contain('Required field [link] is missing'); + } + }); + }) });