From 920f30ef7732e87045ae6652c464b58267991b8f Mon Sep 17 00:00:00 2001 From: Brian Vaughn Date: Wed, 18 Apr 2018 16:36:31 -0700 Subject: [PATCH] Add forwardRef DEV warning for prop-types on render function (#12644) --- .../src/__tests__/forwardRef-test.internal.js | 21 +++++++++++++++++++ packages/react/src/forwardRef.js | 8 +++++++ 2 files changed, 29 insertions(+) diff --git a/packages/react/src/__tests__/forwardRef-test.internal.js b/packages/react/src/__tests__/forwardRef-test.internal.js index 068448c437400..5780dbd054c6d 100644 --- a/packages/react/src/__tests__/forwardRef-test.internal.js +++ b/packages/react/src/__tests__/forwardRef-test.internal.js @@ -249,4 +249,25 @@ describe('forwardRef', () => { 'forwardRef requires a render function but was given undefined.', ); }); + + it('should warn if the render function provided has propTypes or defaultProps attributes', () => { + function renderWithPropTypes() { + return null; + } + renderWithPropTypes.propTypes = {}; + + function renderWithDefaultProps() { + return null; + } + renderWithDefaultProps.defaultProps = {}; + + expect(() => React.forwardRef(renderWithPropTypes)).toWarnDev( + 'forwardRef render functions do not support propTypes or defaultProps. ' + + 'Did you accidentally pass a React component?', + ); + expect(() => React.forwardRef(renderWithDefaultProps)).toWarnDev( + 'forwardRef render functions do not support propTypes or defaultProps. ' + + 'Did you accidentally pass a React component?', + ); + }); }); diff --git a/packages/react/src/forwardRef.js b/packages/react/src/forwardRef.js index 6a923be12795d..6c3c1a4343ba9 100644 --- a/packages/react/src/forwardRef.js +++ b/packages/react/src/forwardRef.js @@ -18,6 +18,14 @@ export default function forwardRef( 'forwardRef requires a render function but was given %s.', render === null ? 'null' : typeof render, ); + + if (render != null) { + warning( + render.defaultProps == null && render.propTypes == null, + 'forwardRef render functions do not support propTypes or defaultProps. ' + + 'Did you accidentally pass a React component?', + ); + } } return {