@roo-ui/components
Version:
91 lines (74 loc) • 2.64 kB
JavaScript
var _react = require('react');
var _react2 = _interopRequireDefault(_react);
var _themes = require('@roo-ui/themes');
var _testUtils = require('@roo-ui/test-utils');
var _jestAxe = require('jest-axe');
var _ = require('.');
var _2 = _interopRequireDefault(_);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _asyncToGenerator(fn) { return function () { var gen = fn.apply(this, arguments); return new Promise(function (resolve, reject) { function step(key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { return Promise.resolve(value).then(function (value) { step("next", value); }, function (err) { step("throw", err); }); } } return step("next"); }); }; }
describe('<Dropdown />', function () {
var props = {
isOpen: false
};
var render = function render() {
return (0, _testUtils.shallowWithTheme)(_react2.default.createElement(
_2.default,
props,
'Options',
_react2.default.createElement(
_2.default.item,
{ id: 'foo', foo: 'bar' },
'Edit'
),
_react2.default.createElement(
_2.default.item,
null,
'Delete'
),
_react2.default.createElement(
_2.default.item,
null,
'Unpublish'
),
_react2.default.createElement(
_2.default.item,
null,
'Duplicate'
)
), _themes.qantas).dive();
};
it('renders correctly when closed', function () {
expect(render()).toMatchSnapshot();
});
it('renders correctly when open', function () {
props.isOpen = true;
expect(render()).toMatchSnapshot();
});
it('has no accessibility errors', _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee() {
return regeneratorRuntime.wrap(function _callee$(_context) {
while (1) {
switch (_context.prev = _context.next) {
case 0:
_context.t0 = expect;
_context.next = 3;
return (0, _jestAxe.axe)(render().html());
case 3:
_context.t1 = _context.sent;
(0, _context.t0)(_context.t1).toHaveNoViolations();
case 5:
case 'end':
return _context.stop();
}
}
}, _callee, undefined);
})));
it('adds props passed in to the <Dropdown.item />', function () {
props.isOpen = true;
expect(render().find(_2.default.item).first().props()).toEqual(expect.objectContaining({
id: 'foo',
foo: 'bar'
}));
});
});
;