diff --git a/CHANGELOG.md b/CHANGELOG.md index dde43a8d6d..6c27654dbf 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -16,9 +16,11 @@ This change log adheres to standards from [Keep a CHANGELOG](https://keepachange * [`sort-prop-types`]: restore autofixing ([#3452][] @ROSSROSALES) * [`no-unknown-property`]: do not check `fbs` elements ([#3494][] @brianogilvie) * [`jsx-newline`]: No newline between comments and jsx elements ([#3493][] @justmejulian) +* [`jsx-no-leaked-render`]: Don't report errors on empty strings if React >= v18 ([#3488][] @himanshu007-creator) [#3494]: https://github.com/jsx-eslint/eslint-plugin-react/pull/3494 [#3493]: https://github.com/jsx-eslint/eslint-plugin-react/pull/3493 +[#3488]: https://github.com/jsx-eslint/eslint-plugin-react/pull/3488 [#3461]: https://github.com/jsx-eslint/eslint-plugin-react/issues/3461 [#3452]: https://github.com/jsx-eslint/eslint-plugin-react/pull/3452 [#3449]: https://github.com/jsx-eslint/eslint-plugin-react/pull/3449 diff --git a/lib/rules/jsx-no-leaked-render.js b/lib/rules/jsx-no-leaked-render.js index efea6a63c4..c1003644b1 100644 --- a/lib/rules/jsx-no-leaked-render.js +++ b/lib/rules/jsx-no-leaked-render.js @@ -7,6 +7,7 @@ const docsUrl = require('../util/docsUrl'); const report = require('../util/report'); +const testReactVersion = require('../util/version').testReactVersion; const isParenthesized = require('../util/ast').isParenthesized; //------------------------------------------------------------------------------ @@ -130,6 +131,9 @@ module.exports = { } } + if (testReactVersion(context, '>= 18.0.0') && node.left.value === '') { + return; + } report(context, messages.noPotentialLeakedRender, 'noPotentialLeakedRender', { node, fix(fixer) { diff --git a/tests/lib/rules/jsx-no-leaked-render.js b/tests/lib/rules/jsx-no-leaked-render.js index 032d8eadfb..6e1378e3ad 100644 --- a/tests/lib/rules/jsx-no-leaked-render.js +++ b/tests/lib/rules/jsx-no-leaked-render.js @@ -218,7 +218,41 @@ ruleTester.run('jsx-no-leaked-render', rule, { }, { message: 'Potential leaked value that might cause unintentionally rendered values or rendering crashes', - line: 6, + line: 7, + column: 14, + }, + ], + output: ` + const Example = () => { + return ( + <> + {0 ? : null} + {'' ? : null} + {NaN ? : null} + + ) + } + `, + settings: { react: { version: '17.999.999' } }, + }, + + { + code: ` + const Example = () => { + return ( + <> + {0 && } + {'' && } + {NaN && } + + ) + } + `, + features: ['fragment'], + errors: [ + { + message: 'Potential leaked value that might cause unintentionally rendered values or rendering crashes', + line: 5, column: 14, }, { @@ -232,12 +266,13 @@ ruleTester.run('jsx-no-leaked-render', rule, { return ( <> {0 ? : null} - {'' ? : null} + {'' && } {NaN ? : null} ) } `, + settings: { react: { version: '18.0.0' } }, }, // Invalid tests with both strategies enabled (default)