/* eslint-env jest */
/**
* @fileoverview Enforce that elements with ARIA roles must
* have all required attributes for that role.
* @author Ethan Cohen
*/
// -----------------------------------------------------------------------------
// Requirements
// -----------------------------------------------------------------------------
import { roles } from 'aria-query';
import { RuleTester } from 'eslint';
import parserOptionsMapper from '../../__util__/parserOptionsMapper';
import rule from '../../../src/rules/role-has-required-aria-props';
// -----------------------------------------------------------------------------
// Tests
// -----------------------------------------------------------------------------
const ruleTester = new RuleTester();
const errorMessage = (role) => {
const requiredProps = Object.keys(roles.get(role).requiredProps);
return {
message: `Elements with the ARIA role "${role}" must have the following ` +
`attributes defined: ${requiredProps}`,
type: 'JSXAttribute',
};
};
// Create basic test cases using all valid role types.
const basicValidityTests = [...roles.keys()].map((role) => {
const {
requiredProps: requiredPropKeyValues,
} = roles.get(role);
const requiredProps = Object.keys(requiredPropKeyValues);
const propChain = requiredProps.join(' ');
return {
code: `
`,
};
});
ruleTester.run('role-has-required-aria-props', rule, {
valid: [
{ code: '' },
// Variables should pass, as we are only testing literals.
{ code: '' },
{ code: '' },
{ code: '' },
{ code: '' },
{ code: '' },
{ code: '' },
{ code: '' },
].concat(basicValidityTests).map(parserOptionsMapper),
invalid: [
// SLIDER
{ code: '', errors: [errorMessage('slider')] },
{
code: '',
errors: [errorMessage('slider')],
},
{
code: '',
errors: [errorMessage('slider')],
},
{
code: '',
errors: [errorMessage('slider')],
},
{
code: '',
errors: [errorMessage('slider')],
},
// SPINBUTTON
{ code: '', errors: [errorMessage('spinbutton')] },
{
code: '',
errors: [errorMessage('spinbutton')],
},
{
code: '',
errors: [errorMessage('spinbutton')],
},
{
code: '',
errors: [errorMessage('spinbutton')],
},
{
code: '',
errors: [errorMessage('spinbutton')],
},
// CHECKBOX
{ code: '', errors: [errorMessage('checkbox')] },
{ code: '', errors: [errorMessage('checkbox')] },
{
code: '',
errors: [errorMessage('checkbox')],
},
{
code: '',
errors: [errorMessage('checkbox')],
},
// COMBOBOX
{ code: '', errors: [errorMessage('combobox')] },
{ code: '', errors: [errorMessage('combobox')] },
{
code: '',
errors: [errorMessage('combobox')],
},
// SCROLLBAR
{ code: '', errors: [errorMessage('scrollbar')] },
{
code: '',
errors: [errorMessage('scrollbar')],
},
{
code: '',
errors: [errorMessage('scrollbar')],
},
{
code: '',
errors: [errorMessage('scrollbar')],
},
{
code: '',
errors: [errorMessage('scrollbar')],
},
].map(parserOptionsMapper),
});