Skip to content

Commit

Permalink
fix(react-router-dom): fix detectErrorBoundary function (#10190)
Browse files Browse the repository at this point in the history
  • Loading branch information
vonagam authored Mar 13, 2023
1 parent 28bdebf commit 0f561ee
Show file tree
Hide file tree
Showing 4 changed files with 123 additions and 5 deletions.
5 changes: 5 additions & 0 deletions .changeset/tricky-walls-eat.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
---
"react-router-dom": patch
---

Check for ErrorBoundary property (not only errorElement) in detectErrorBoundary
1 change: 1 addition & 0 deletions contributors.yml
Original file line number Diff line number Diff line change
Expand Up @@ -191,6 +191,7 @@
- vijaypushkin
- vikingviolinist
- vishwast03
- vonagam
- WalkAlone0325
- willemarcel
- williamsdyyz
Expand Down
120 changes: 116 additions & 4 deletions packages/react-router-dom/__tests__/data-static-router-test.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -831,11 +831,11 @@ describe("A <StaticRouterProvider>", () => {
let frameworkAgnosticRoutes = [
{
path: "the",
hasErrorElement: true,
hasErrorBoundary: true,
children: [
{
path: "path",
hasErrorElement: true,
hasErrorBoundary: true,
},
],
},
Expand Down Expand Up @@ -949,6 +949,118 @@ describe("A <StaticRouterProvider>", () => {
`);
});

it("handles framework agnostic static handler routes (using ErrorBoundary)", async () => {
let frameworkAgnosticRoutes = [
{
path: "the",
hasErrorBoundary: true,
children: [
{
path: "path",
hasErrorBoundary: true,
},
],
},
];
let { query } = createStaticHandler(frameworkAgnosticRoutes);

let context = (await query(
new Request("http://localhost/the/path", {
signal: new AbortController().signal,
})
)) as StaticHandlerContext;

let frameworkAwareRoutes = [
{
path: "the",
element: <h1>Hi!</h1>,
ErrorBoundary: () => <h1>Error!</h1>,
children: [
{
path: "path",
element: <h2>Hi again!</h2>,
ErrorBoundary: () => <h2>Error again!</h2>,
},
],
},
];

// This should add route ids + hasErrorBoundary, and also update the
// context.matches to include the full framework-aware routes
let router = createStaticRouter(frameworkAwareRoutes, context);

expect(router.routes).toMatchInlineSnapshot(`
[
{
"ErrorBoundary": [Function],
"children": [
{
"ErrorBoundary": [Function],
"children": undefined,
"element": <h2>
Hi again!
</h2>,
"hasErrorBoundary": true,
"id": "0-0",
"path": "path",
},
],
"element": <h1>
Hi!
</h1>,
"hasErrorBoundary": true,
"id": "0",
"path": "the",
},
]
`);
expect(router.state.matches).toMatchInlineSnapshot(`
[
{
"params": {},
"pathname": "/the",
"pathnameBase": "/the",
"route": {
"ErrorBoundary": [Function],
"children": [
{
"ErrorBoundary": [Function],
"children": undefined,
"element": <h2>
Hi again!
</h2>,
"hasErrorBoundary": true,
"id": "0-0",
"path": "path",
},
],
"element": <h1>
Hi!
</h1>,
"hasErrorBoundary": true,
"id": "0",
"path": "the",
},
},
{
"params": {},
"pathname": "/the/path",
"pathnameBase": "/the/path",
"route": {
"ErrorBoundary": [Function],
"children": undefined,
"element": <h2>
Hi again!
</h2>,
"hasErrorBoundary": true,
"id": "0-0",
"path": "path",
},
},
]
`);
});

it("renders absolute links correctly", async () => {
let routes = [
{
Expand Down Expand Up @@ -993,7 +1105,7 @@ describe("A <StaticRouterProvider>", () => {
{
path: "/",
element: <Outlet />,
errorElement: <p>Error</p>,
ErrorBoundary: () => <p>Error</p>,
children: [
{
index: true,
Expand Down Expand Up @@ -1036,7 +1148,7 @@ describe("A <StaticRouterProvider>", () => {
index: true,
lazy: async () => ({
element: <h1>👋</h1>,
errorElement: <p>Error</p>,
ErrorBoundary: () => <p>Error</p>,
}),
},
],
Expand Down
2 changes: 1 addition & 1 deletion packages/react-router-dom/server.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -206,7 +206,7 @@ function getStatelessNavigator() {
};
}

let detectErrorBoundary = (route: RouteObject) => Boolean(route.errorElement);
let detectErrorBoundary = (route: RouteObject) => Boolean(route.ErrorBoundary) || Boolean(route.errorElement);

type CreateStaticHandlerOptions = Omit<
RouterCreateStaticHandlerOptions,
Expand Down

0 comments on commit 0f561ee

Please sign in to comment.