|
| 1 | +/** |
| 2 | + * @fileoverview Report missing `key` props in iterators/collection literals. |
| 3 | + * @author Ben Mosher |
| 4 | + */ |
| 5 | +'use strict'; |
| 6 | + |
| 7 | +// ------------------------------------------------------------------------------ |
| 8 | +// Requirements |
| 9 | +// ------------------------------------------------------------------------------ |
| 10 | + |
| 11 | +var rule = require('../../../lib/rules/jsx-key'); |
| 12 | +var RuleTester = require('eslint').RuleTester; |
| 13 | + |
| 14 | +// ------------------------------------------------------------------------------ |
| 15 | +// Tests |
| 16 | +// ------------------------------------------------------------------------------ |
| 17 | + |
| 18 | +var ruleTester = new RuleTester(); |
| 19 | +ruleTester.run('jsx-key', rule, { |
| 20 | + valid: [ |
| 21 | + {code: '<App />;', ecmaFeatures: {jsx: true}}, |
| 22 | + {code: '[<App key={0} />, <App key={1} />];', ecmaFeatures: {jsx: true}}, |
| 23 | + {code: '[1, 2, 3].map(x => <App key={x} />);', ecmaFeatures: {jsx: true, arrowFunctions: true}} |
| 24 | + ], |
| 25 | + invalid: [ |
| 26 | + {code: '[<App />];', |
| 27 | + errors: [{message: 'Missing "key" prop for element in array'}], |
| 28 | + ecmaFeatures: {jsx: true}}, |
| 29 | + |
| 30 | + {code: '[<App {...key} />];', |
| 31 | + errors: [{message: 'Missing "key" prop for element in array'}], |
| 32 | + ecmaFeatures: {jsx: true}}, |
| 33 | + |
| 34 | + {code: '[<App key={0}/>, <App />];', |
| 35 | + errors: [{message: 'Missing "key" prop for element in array'}], |
| 36 | + ecmaFeatures: {jsx: true}}, |
| 37 | + |
| 38 | + {code: '[1, 2 ,3].map(x => <App />);', |
| 39 | + errors: [{message: 'Missing "key" prop for element in iterator'}], |
| 40 | + ecmaFeatures: {jsx: true, arrowFunctions: true}} |
| 41 | + ] |
| 42 | +}); |
0 commit comments