From e231f44c38d28878039edeb43e009b153614ca0a Mon Sep 17 00:00:00 2001 From: Chiawen Chen Date: Sun, 1 Mar 2020 22:33:45 +0800 Subject: [PATCH] [tests] `no-unescaped-entities`: skip test cases that are now parsing errors in acorn-jsx@5.2.0 Co-authored-by: Chiawen Chen Co-authored-by: Jordan Harband --- package.json | 8 +++++++- tests/lib/rules/no-unescaped-entities.js | 24 ++++++++++++++++-------- 2 files changed, 23 insertions(+), 9 deletions(-) diff --git a/package.json b/package.json index 2ca60bd394..947afc596b 100644 --- a/package.json +++ b/package.json @@ -37,6 +37,7 @@ "object.values": "^1.1.1", "prop-types": "^15.7.2", "resolve": "^1.15.1", + "semver": "^6.3.0", "string.prototype.matchall": "^4.0.2", "xregexp": "^4.3.0" }, @@ -69,5 +70,10 @@ "eslintplugin", "react" ], - "license": "MIT" + "license": "MIT", + "greenkeeper": { + "ignore": [ + "semver" + ] + } } diff --git a/tests/lib/rules/no-unescaped-entities.js b/tests/lib/rules/no-unescaped-entities.js index b10f5555e0..1b47aa2b63 100644 --- a/tests/lib/rules/no-unescaped-entities.js +++ b/tests/lib/rules/no-unescaped-entities.js @@ -9,6 +9,14 @@ // Requirements // ------------------------------------------------------------------------------ +const semver = require('semver'); + +let allowsInvalidJSX = false; +try { + // eslint-disable-next-line import/no-extraneous-dependencies, global-require + allowsInvalidJSX = semver.satisfies(require('acorn-jsx/package.json').version, '< 5.2'); +} catch (e) { /**/ } + const RuleTester = require('eslint').RuleTester; const rule = require('../../../lib/rules/no-unescaped-entities'); @@ -107,7 +115,7 @@ ruleTester.run('no-unescaped-entities', rule, { ], invalid: [ - { + (allowsInvalidJSX && { code: ` var Hello = createReactClass({ render: function() { @@ -116,7 +124,7 @@ ruleTester.run('no-unescaped-entities', rule, { }); `, errors: [{message: '`>` can be escaped with `>`.'}] - }, { + }), { code: ` var Hello = createReactClass({ render: function() { @@ -126,7 +134,7 @@ ruleTester.run('no-unescaped-entities', rule, { `, parser: parsers.BABEL_ESLINT, errors: [{message: '`>` can be escaped with `>`.'}] - }, { + }, (allowsInvalidJSX && { code: ` var Hello = createReactClass({ render: function() { @@ -137,7 +145,7 @@ ruleTester.run('no-unescaped-entities', rule, { }); `, errors: [{message: '`>` can be escaped with `>`.'}] - }, { + }), { code: ` var Hello = createReactClass({ render: function() { @@ -158,7 +166,7 @@ ruleTester.run('no-unescaped-entities', rule, { }); `, errors: [{message: '`\'` can be escaped with `'`, `‘`, `'`, `’`.'}] - }, { + }, (allowsInvalidJSX && { code: ` var Hello = createReactClass({ render: function() { @@ -171,7 +179,7 @@ ruleTester.run('no-unescaped-entities', rule, { {message: '`>` can be escaped with `>`.'}, {message: '`>` can be escaped with `>`.'} ] - }, { + }), (allowsInvalidJSX && { code: ` var Hello = createReactClass({ render: function() { @@ -180,7 +188,7 @@ ruleTester.run('no-unescaped-entities', rule, { }); `, errors: [{message: '`}` can be escaped with `}`.'}] - }, { + }), { code: ` var Hello = createReactClass({ render: function() { @@ -231,5 +239,5 @@ ruleTester.run('no-unescaped-entities', rule, { }] }] } - ] + ].filter(Boolean) });