diff --git a/.changeset/stupid-steaks-hang.md b/.changeset/stupid-steaks-hang.md new file mode 100644 index 0000000000..157e89480b --- /dev/null +++ b/.changeset/stupid-steaks-hang.md @@ -0,0 +1,5 @@ +--- +'astro': patch +--- + +Make Astro.redirect use a 302 status code diff --git a/packages/astro/src/core/render/result.ts b/packages/astro/src/core/render/result.ts index 154fb797be..cfbc485213 100644 --- a/packages/astro/src/core/render/result.ts +++ b/packages/astro/src/core/render/result.ts @@ -152,7 +152,7 @@ export function createResult(args: CreateResultArgs): SSRResult { redirect: args.ssr ? (path: string) => { return new Response(null, { - status: 301, + status: 302, headers: { Location: path, }, diff --git a/packages/astro/test/fixtures/ssr-redirect/package.json b/packages/astro/test/fixtures/ssr-redirect/package.json new file mode 100644 index 0000000000..9017715ce7 --- /dev/null +++ b/packages/astro/test/fixtures/ssr-redirect/package.json @@ -0,0 +1,8 @@ +{ + "name": "@test/ssr-redirect", + "version": "0.0.0", + "private": true, + "dependencies": { + "astro": "workspace:*" + } +} diff --git a/packages/astro/test/fixtures/ssr-redirect/src/pages/secret.astro b/packages/astro/test/fixtures/ssr-redirect/src/pages/secret.astro new file mode 100644 index 0000000000..f8fc808e7a --- /dev/null +++ b/packages/astro/test/fixtures/ssr-redirect/src/pages/secret.astro @@ -0,0 +1,3 @@ +--- +return Astro.redirect('/login'); +--- diff --git a/packages/astro/test/ssr-redirect.test.js b/packages/astro/test/ssr-redirect.test.js new file mode 100644 index 0000000000..29fe701f7a --- /dev/null +++ b/packages/astro/test/ssr-redirect.test.js @@ -0,0 +1,27 @@ +import { expect } from 'chai'; +import { loadFixture } from './test-utils.js'; +import testAdapter from './test-adapter.js'; + +describe('Astro.redirect', () => { + /** @type {import('./test-utils').Fixture} */ + let fixture; + + before(async () => { + fixture = await loadFixture({ + root: './fixtures/ssr-redirect/', + experimental: { + ssr: true, + }, + adapter: testAdapter(), + }); + await fixture.build(); + }); + + it('Returns a 302 status', async () => { + const app = await fixture.loadTestAdapterApp(); + const request = new Request('http://example.com/secret'); + const response = await app.render(request); + expect(response.status).to.equal(302); + expect(response.headers.get('location')).to.equal('/login'); + }); +}); diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index b42e76d32e..666af67896 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -1636,6 +1636,12 @@ importers: '@astrojs/partytown': link:../../../../integrations/partytown astro: link:../../.. + packages/astro/test/fixtures/ssr-redirect: + specifiers: + astro: workspace:* + dependencies: + astro: link:../../.. + packages/astro/test/fixtures/ssr-scripts: specifiers: '@astrojs/preact': 'workspace:'