From 4c7ba4da084d7508df91cbac03c2b099a8301e2b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Andr=C3=A9=20Alves?= <71379045+andremralves@users.noreply.github.com> Date: Mon, 17 Apr 2023 11:44:48 -0300 Subject: [PATCH] Fix Astro.params does not contain path parameter from URL with non-English characters (#6859) --- .changeset/few-cats-beam.md | 5 +++++ packages/astro/src/core/render/core.ts | 4 +++- .../pages/\346\235\261\350\245\277/[category].astro" | 12 ++++++++++++ packages/astro/test/ssr-params.test.js | 12 ++++++++++++ 4 files changed, 32 insertions(+), 1 deletion(-) create mode 100644 .changeset/few-cats-beam.md create mode 100644 "packages/astro/test/fixtures/ssr-params/src/pages/\346\235\261\350\245\277/[category].astro" diff --git a/.changeset/few-cats-beam.md b/.changeset/few-cats-beam.md new file mode 100644 index 000000000000..7585992ceb6d --- /dev/null +++ b/.changeset/few-cats-beam.md @@ -0,0 +1,5 @@ +--- +'astro': patch +--- + +Fix Astro.params does not contain path parameter from URL with non-English characters. diff --git a/packages/astro/src/core/render/core.ts b/packages/astro/src/core/render/core.ts index d072c85b4586..8687e90068bc 100644 --- a/packages/astro/src/core/render/core.ts +++ b/packages/astro/src/core/render/core.ts @@ -32,7 +32,9 @@ export async function getParamsAndProps( let pageProps: Props; if (route && !route.pathname) { if (route.params.length) { - const paramsMatch = route.pattern.exec(pathname); + // The RegExp pattern expects a decoded string, but the pathname is encoded + // when the URL contains non-English characters. + const paramsMatch = route.pattern.exec(decodeURIComponent(pathname)); if (paramsMatch) { params = getParams(route.params)(paramsMatch); diff --git "a/packages/astro/test/fixtures/ssr-params/src/pages/\346\235\261\350\245\277/[category].astro" "b/packages/astro/test/fixtures/ssr-params/src/pages/\346\235\261\350\245\277/[category].astro" new file mode 100644 index 000000000000..bdaa1f965d22 --- /dev/null +++ "b/packages/astro/test/fixtures/ssr-params/src/pages/\346\235\261\350\245\277/[category].astro" @@ -0,0 +1,12 @@ +--- +const { category } = Astro.params +--- + + + Testing + + +

Testing

+

{ category }

+ + diff --git a/packages/astro/test/ssr-params.test.js b/packages/astro/test/ssr-params.test.js index 37155425ebc5..343e47cf8705 100644 --- a/packages/astro/test/ssr-params.test.js +++ b/packages/astro/test/ssr-params.test.js @@ -26,4 +26,16 @@ describe('Astro.params in SSR', () => { const $ = cheerio.load(html); expect($('.category').text()).to.equal('food'); }); + + describe('Non-english characters in the URL', () => { + it('Params are passed to component', async () => { + const app = await fixture.loadTestAdapterApp(); + const request = new Request('http://example.com/users/houston/東西/food'); + const response = await app.render(request); + expect(response.status).to.equal(200); + const html = await response.text(); + const $ = cheerio.load(html); + expect($('.category').text()).to.equal('food'); + }); + }); });