- 
          
- 
                Notifications
    You must be signed in to change notification settings 
- Fork 1.7k
          new: Document failOnPrerenderConflict experimental flag
          #12237
        
          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
Conversation
| ✅ Deploy Preview for astro-docs-2 ready!
 To edit notification comments on pull requests, go to your Netlify project configuration. | 
| Lunaria Status Overview🌕 This pull request will trigger status changes. Learn moreBy default, every PR changing files present in the Lunaria configuration's  You can change this by adding one of the keywords present in the  Tracked Files
 Warnings reference
 | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Looks great, see my BIG comment for my BIG suggestion below! 😂
| Multiple dynamic routes can result in the same output path, for example `/blog/[slug]` and `/blog/[...all]` both could try to prerender the `/blog/post-1` path. In such cases, Astro will warn you about the conflict during build and render only the [highest priority route](/en/guides/routing/#route-priority-order) for the conflicting path. With this flag set, the build will instead fail immediately with an error. | ||
|  | ||
| This will be the default behavior in Astro 6. | ||
|  | ||
| Enable it in your `astro.config.mjs`: | ||
|  | ||
| ```js | ||
| // astro.config.mjs | ||
| defineConfig({ | ||
| experimental: { | ||
| failOnPrerenderConflict: true, | ||
| }, | ||
| }); | ||
| ``` | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
| Multiple dynamic routes can result in the same output path, for example `/blog/[slug]` and `/blog/[...all]` both could try to prerender the `/blog/post-1` path. In such cases, Astro will warn you about the conflict during build and render only the [highest priority route](/en/guides/routing/#route-priority-order) for the conflicting path. With this flag set, the build will instead fail immediately with an error. | |
| This will be the default behavior in Astro 6. | |
| Enable it in your `astro.config.mjs`: | |
| ```js | |
| // astro.config.mjs | |
| defineConfig({ | |
| experimental: { | |
| failOnPrerenderConflict: true, | |
| }, | |
| }); | |
| ``` | |
| Astro currently warns you during the build about any conflicts between multiple dynamic routes that can result in the same output path. For example `/blog/[slug]` and `/blog/[...all]` both could try to prerender the `/blog/post-1` path. In such cases, Astro renders only the [highest priority route](/en/guides/routing/#route-priority-order) for the conflicting path. This allows your site to build successfully, although you may discover that some pages are rendered by unexpected routes. | |
| With this experimental flag set, the build will instead fail immediately with an error. This will require you to resolve any routing conflicts immediately, and will ensure that Astro is building your routes as you intend. | |
| To enable this behavior, add the `experimental.failOnPrerenderConflict` feature flag to your Astro config: | |
| ```js title="astro.config.mjs" ins={4-6} | |
| import { defineConfig } from "astro/config" | |
| defineConfig({ | |
| experimental: { | |
| failOnPrerenderConflict: true, | |
| }, | |
| }); | |
| ``` | |
| ## Usage | |
| After enabling this flag, you may encounter errors about conflicting prerendered routes when you attempt to build your project. If this happens, you will need to update one or more of your [dynamic routes](/en/guides/routing/#dynamic-routes) to avoid ambiguous routing. | 
This looks great!!
This is one big suggestion because I wanted to do some rearranging (more than actually editing). BUT, I did try to add some context as an example of "level of detail" I think might be useful.
Also, after this, I would consider showing a simple example of resolving a conflict. It's one thing to tell people "both of these routes are trying to render this page", but even better to show a typical conflict and how someone will need to change their project to be able to build!
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Should we add that here or should we add a "troubleshooting" section on the routing page explaining the warning and how to fix it?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@Fryuni For now, while this is experimental, (and people flipping this on are the only people who are going to need it, and might very well need it!) it should go here!
All experimental documentation is contained to its one page. When this is no longer experimental and is the default, we can redistribute whatever content needed is on this page. (e.g. we might update the routing priority page with a one-liner, as you say, this could go in troubleshooting...)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Just to be clear. The experimental flag is to turn the warning into an error. The warning is for everyone.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Right, everyone gets the warning right now, but the flag means people's builds will fail.
Oh, I get you know -- you mean something in troubleshooting so people can fix the warning that they are currently getting! Actually, now maybe that does seem helpful. And we can link to it from the existing warning maybe? There's nothing someone would do to fix the existing warning that they wouldn't do to fix a broken build in this case, right? The advice is exactly the same?
I see what you were thinking. I also think that people who might have ignored the warning (maybe it didn't really matter to them or affect their project in a way they cared about) will now have failing builds, and these people need to realize this maybe even before deciding to enable the flag. So this still feels like important information about this feature in particular. So I might still include the "how to solve this" in the PR changeset for the minor release maybe, even if we put this in troubleshooting in the docs?
I could go either way on this PR, but now I think troubleshooting is not a bad idea, and might help more people sooner, so not opposed to adding it there! Great idea!
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There's nothing someone would do to fix the existing warning that they wouldn't do to fix a broken build in this case, right? The advice is exactly the same?
Correct. We had a discussion about this and decided to not make it the default in the future. It will be experimental to set it as an error and once stabilized it will be a normal flag, but the default will remain as a warning.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
OK, updated my previous suggestion @Fryuni to:
- remove the comment about it becoming the default in Astro 6
- Write around Yan's earlier grammar/punctuation fix. Yan was, of course, grammatically correct; however, semi-colons are rarely our style in favour of multiple shorter sentences or moving clauses around to "write ourselves out" of the problem! 😄
How close are we with this now?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Going to commit here so we have something updated to work off of! Can always reedit!
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Sorry for the lack of replies Sarah, going through some things. Feel free to commit any changes needed I'll try to get back to this as soon as I can.
        
          
                src/content/docs/en/reference/experimental-flags/fail-on-prerender-conflict.mdx
              
                Outdated
          
            Show resolved
            Hide resolved
        
      …nder-conflict.mdx Co-authored-by: Yan <[email protected]>
Description
Document new experimental flag to fail on multiple routes prerendering the same page instead of showing a warning.
For Astro version:
5.14. See astro PR #14206.