Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[@astrojs/cloudflare] Prerendering 404 page causes Server Islands to break #12771

Open
1 task
austin-raey opened this issue Dec 18, 2024 · 2 comments
Open
1 task
Labels
needs response Issue needs response from OP

Comments

@austin-raey
Copy link

Astro Info

Astro                    v5.0.9
Node                     v22.11.0
System                   macOS (arm64)
Package Manager          pnpm
Output                   server
Adapter                  @astrojs/cloudflare
Integrations             none

If this issue only occurs in one browser, which browser is a problem?

Chrome, Safari, etc.

Describe the Bug

Consider the below minimal stackblitz template using the @astrojs/cloudflare adapter. (I tried the @astrojs/node adapter and could not reproduce this).

Note that I cannot get the npm run preview command to run on Stackblitz, I recommend you download and run locally if you must.

When adding export const prerender = true to the src/pages/404.astro, and emulating a production deployment via npm run preview (i.e., astro build && wrangler pages dev ./dist), the Server Island components with server:defer no longer render. The _server-islands/ network call shows a 404.

Upon removing the export const prerender = true or setting = false, the Islands render as expected.

What's the expected result?

I would expect statically generating a 404 page does not cause Server Islands server:defer on components to break.

I'm not sure what could cause this behavior, or if it's as simple as something weird with the src/pages/404.astro file being "special".

Link to Minimal Reproducible Example

https://stackblitz.com/edit/github-fapec6as?file=src%2Fpages%2Findex.astro

Participation

  • I am willing to submit a pull request for this issue.
@github-actions github-actions bot added the needs triage Issue needs to be triaged label Dec 18, 2024
@anonyoroshi
Copy link

anonyoroshi commented Dec 19, 2024

I am experiencing a similar issue with the server:defer directive on Vercel.

Environment

  • Astro version: 5.0.9
  • Node version: 20.x
  • Package Manager: pnpm
  • Output: server
  • Adapter: @astrojs/vercel

Description

When using the server:defer directive, the components fail to load on Vercel with a 404 error. This issue does not occur locally, only on Vercel deployment.

xxx.vercel.app/_server-islands/DelayedMessage?sample・・・
Failed to load resource: the server responded with a status of 404 ()

Steps to Reproduce

  1. Create a component with server:defer directive.
  2. Deploy the project to Vercel.
  3. Access the deployed site and observe the 404 error in the browser console.
  4. The UI remains with the fallback content (e.g., "読み込み中...").

Expected Behavior

The component should load correctly without a 404 error.

Actual Behavior

The component fails to load with a 404 error on Vercel, and the UI remains with the fallback content (e.g., "読み込み中...").

@gtom84
Copy link

gtom84 commented Jan 14, 2025

Please retest on 5.1.6. I've had the same issue on Vercel with ISR on and it's gone since update to 5.1.6.

@ascorbic ascorbic added needs response Issue needs response from OP and removed needs triage Issue needs to be triaged labels Jan 21, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
needs response Issue needs response from OP
Projects
None yet
Development

No branches or pull requests

4 participants