UNPKG

@roo-ui/components

Version:

83 lines (70 loc) 2.85 kB
"use strict"; var _react = _interopRequireDefault(require("react")); var _enzyme = require("enzyme"); var _themes = require("@roo-ui/themes"); var _jestAxe = require("jest-axe"); var _ = _interopRequireDefault(require(".")); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } } function _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err); } _next(undefined); }); }; } describe('<Icon />', function () { var wrapper; var props; var render = function render() { wrapper = (0, _enzyme.mount)(_react.default.createElement(_themes.ThemeProvider, { theme: _themes.qantas }, _react.default.createElement(_.default, props))).find(_.default); }; describe('when passed icon name in theme', function () { beforeEach(function () { props = { name: 'hotel' }; render(); }); it('renders correctly', function () { expect(wrapper).toMatchSnapshot(); }); it('has no accessibility errors', /*#__PURE__*/ _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)(wrapper.html()); case 3: _context.t1 = _context.sent; (0, _context.t0)(_context.t1).toHaveNoViolations(); case 5: case "end": return _context.stop(); } } }, _callee); }))); }); describe('when passed icon name not in theme', function () { var consoleSpy; beforeEach(function () { consoleSpy = jest.spyOn(console, 'error').mockImplementation(function () {}); props = { name: '_def_not_in_theme' }; render(); }); afterEach(function () { consoleSpy.mockRestore(); }); it('renders svg with null path', function () { expect(wrapper.find('svg path').prop('d')).toBe(null); }); it('logs error to console', function () { expect(consoleSpy).toHaveBeenCalledWith('Icon "_def_not_in_theme" not found in theme'); }); }); });