diff --git a/packages/react-router/__tests__/descendant-routes-warning-test.tsx b/packages/react-router/__tests__/descendant-routes-warning-test.tsx index e7cacaed84..52588870a2 100644 --- a/packages/react-router/__tests__/descendant-routes-warning-test.tsx +++ b/packages/react-router/__tests__/descendant-routes-warning-test.tsx @@ -52,9 +52,47 @@ describe("Descendant ", () => { }); expect(consoleWarn).toHaveBeenCalledTimes(1); - expect(consoleWarn).toHaveBeenCalledWith( - expect.stringContaining("child routes will never render") - ); + + expect(consoleWarn.mock.calls[0][0]) + .toMatch(`You rendered descendant (or called \`useRoutes()\`) at "/courses/react" (under ) but the parent route path has no trailing "*". This means if you navigate deeper, the parent won't match anymore and therefore the child routes will never render. + +Please change the parent to .`); + }); + }); + + describe("when the parent route path does not have a trailing * and is the root", () => { + it("warns once when you visit the parent route and only shows a hint like *", () => { + function ReactCourses() { + return ( +
+

React

+ + + React Fundamentals} + /> + +
+ ); + } + + TestRenderer.act(() => { + TestRenderer.create( + + + } /> + + + ); + }); + + expect(consoleWarn).toHaveBeenCalledTimes(1); + + expect(consoleWarn.mock.calls[0][0]) + .toMatch(`You rendered descendant (or called \`useRoutes()\`) at "/" (under ) but the parent route path has no trailing "*". This means if you navigate deeper, the parent won't match anymore and therefore the child routes will never render. + +Please change the parent to .`); }); }); diff --git a/packages/react-router/index.tsx b/packages/react-router/index.tsx index 054547f25c..34de7a6738 100644 --- a/packages/react-router/index.tsx +++ b/packages/react-router/index.tsx @@ -663,7 +663,7 @@ export function useRoutes( `deeper, the parent won't match anymore and therefore the child ` + `routes will never render.\n\n` + `Please change the parent to .` + `path="${parentPath === "/" ? "*" : `${parentPath}/*`}">.` ); }