mirror of
https://github.com/facebook/react.git
synced 2026-02-23 20:23:02 +00:00
Add new error message for awaiting the client export (#29853)
<!-- Thanks for submitting a pull request! We appreciate you spending the time to work on these changes. Please provide enough information so that others can review your pull request. The three fields below are mandatory. Before submitting a pull request, please make sure the following is done: 1. Fork [the repository](https://github.com/facebook/react) and create your branch from `main`. 2. Run `yarn` in the repository root. 3. If you've fixed a bug or added code that should be tested, add tests! 4. Ensure the test suite passes (`yarn test`). Tip: `yarn test --watch TestName` is helpful in development. 5. Run `yarn test --prod` to test in the production environment. It supports the same options as `yarn test`. 6. If you need a debugger, run `yarn test --debug --watch TestName`, open `chrome://inspect`, and press "Inspect". 7. Format your code with [prettier](https://github.com/prettier/prettier) (`yarn prettier`). 8. Make sure your code lints (`yarn lint`). Tip: `yarn linc` to only check changed files. 9. Run the [Flow](https://flowtype.org/) type checks (`yarn flow`). 10. If you haven't already, complete the CLA. Learn more about contributing: https://reactjs.org/docs/how-to-contribute.html --> ## Summary `Cannot access .then on server` is not an ideal message when you try to await or do promise chain to the properties of client reference. The below example will let `.then` get accessed by native code while handling the promise chain but the access is not clearly visible in user code. ``` import('./client-module').then((mod) => mod.Component) ``` This PR chnage the error message of module reference proxy '.then' property to show more kinds of usage, then it can be pretty clearly for helping users to avoid the bad usage <!-- Explain the **motivation** for making this change. What existing problem does the pull request solve? --> ## How did you test this change? Unit test <!-- Demonstrate the code is solid. Example: The exact commands you ran and their output, screenshots / videos if the pull request changes the user interface. How exactly did you verify that your PR solves the issue you wanted to solve? If you leave this empty, your PR will very likely be closed. -->
This commit is contained in:
@@ -133,6 +133,11 @@ const deepProxyHandlers = {
|
||||
`Instead, you can export a Client Component wrapper ` +
|
||||
`that itself renders a Client Context Provider.`,
|
||||
);
|
||||
case 'then':
|
||||
throw new Error(
|
||||
`Cannot await or return from a thenable. ` +
|
||||
`You cannot await a client module from a server component.`,
|
||||
);
|
||||
}
|
||||
// eslint-disable-next-line react-internal/safe-string-coercion
|
||||
const expression = String(target.name) + '.' + String(name);
|
||||
|
||||
@@ -141,6 +141,11 @@ const deepProxyHandlers = {
|
||||
`Instead, you can export a Client Component wrapper ` +
|
||||
`that itself renders a Client Context Provider.`,
|
||||
);
|
||||
case 'then':
|
||||
throw new Error(
|
||||
`Cannot await or return from a thenable. ` +
|
||||
`You cannot await a client module from a server component.`,
|
||||
);
|
||||
}
|
||||
// eslint-disable-next-line react-internal/safe-string-coercion
|
||||
const expression = String(target.name) + '.' + String(name);
|
||||
|
||||
@@ -623,6 +623,20 @@ describe('ReactFlightDOM', () => {
|
||||
);
|
||||
});
|
||||
|
||||
it('throws when await a client module prop of client exports', async () => {
|
||||
const ClientModule = clientExports({
|
||||
Component: {deep: 'thing'},
|
||||
});
|
||||
async function awaitExport() {
|
||||
const mod = await ClientModule;
|
||||
return await Promise.resolve(mod.Component);
|
||||
}
|
||||
await expect(awaitExport()).rejects.toThrowError(
|
||||
`Cannot await or return from a thenable. ` +
|
||||
`You cannot await a client module from a server component.`,
|
||||
);
|
||||
});
|
||||
|
||||
it('throws when accessing a symbol prop from client exports', () => {
|
||||
const symbol = Symbol('test');
|
||||
const ClientModule = clientExports({
|
||||
|
||||
Reference in New Issue
Block a user