UNPKG

wix-style-react

Version:
428 lines (353 loc) • 15 kB
'use strict'; var _eyes = require('eyes.it'); var _eyes2 = _interopRequireDefault(_eyes); var _protractor = require('../../testkit/protractor'); var _protractor2 = require('wix-ui-test-utils/protractor'); var _storybookHelpers = require('../../test/utils/storybook-helpers'); var _AutoExampleDriver = require('wix-storybook-utils/AutoExampleDriver'); var _AutoExampleDriver2 = _interopRequireDefault(_AutoExampleDriver); var _privateDrivers = require('../../test/utils/private-drivers'); 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"); }); }; } var NUM_OF_BUTTONS_IN_EXAMPLE = 4; var kind = '4. Selection'; var story = '4.3 Radio Button Group'; describe('RadioGroup', function () { var dataHook = 'storybook-radiogroup'; var radioGroupDriver = (0, _protractor.radioGroupTestkitFactory)({ dataHook: dataHook }); beforeAll(function () { return browser.get((0, _storybookHelpers.createStoryUrl)({ kind: kind, story: story })); }); afterEach(_asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee() { return regeneratorRuntime.wrap(function _callee$(_context) { while (1) { switch (_context.prev = _context.next) { case 0: _context.next = 2; return _AutoExampleDriver2.default.reset(); case 2: case 'end': return _context.stop(); } } }, _callee, undefined); }))); _eyes2.default.it('should select the second option in a group', _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee2() { return regeneratorRuntime.wrap(function _callee2$(_context2) { while (1) { switch (_context2.prev = _context2.next) { case 0: _context2.next = 2; return (0, _protractor2.waitForVisibilityOf)(radioGroupDriver.element(), 'Cannot find RadioGroup'); case 2: radioGroupDriver.selectByIndex(1).click(); expect(radioGroupDriver.isRadioChecked(1)).toBe(true); case 4: case 'end': return _context2.stop(); } } }, _callee2, undefined); }))); _eyes2.default.it('should not select disabled option', _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee3() { return regeneratorRuntime.wrap(function _callee3$(_context3) { while (1) { switch (_context3.prev = _context3.next) { case 0: _context3.next = 2; return _AutoExampleDriver2.default.setProps({ disabledRadios: [4] }); case 2: _context3.next = 4; return (0, _protractor2.waitForVisibilityOf)(radioGroupDriver.element(), 'Cannot find RadioGroup'); case 4: expect(radioGroupDriver.isRadioDisabled(3)).toBe(true); browser.actions().mouseMove(radioGroupDriver.getRadioAtIndex(3)).click(); expect(radioGroupDriver.isRadioChecked(3)).toBe(false); case 7: case 'end': return _context3.stop(); } } }, _callee3, undefined); }))); describe('Focus tests', function () { var pressTab = function pressTab() { return browser.actions().sendKeys(protractor.Key.TAB).perform(); }; var groupDriver = radioGroupDriver; var expectNotFocused = function () { var _ref4 = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee4(msg, driver) { var prefix; return regeneratorRuntime.wrap(function _callee4$(_context4) { while (1) { switch (_context4.prev = _context4.next) { case 0: prefix = msg ? msg + ' - ' : ''; _context4.t0 = expect; _context4.next = 4; return driver.isFocused(); case 4: _context4.t1 = _context4.sent; _context4.t2 = prefix + 'focused'; (0, _context4.t0)(_context4.t1).toBe(false, _context4.t2); _context4.t3 = expect; _context4.next = 10; return driver.hasFocusState(); case 10: _context4.t4 = _context4.sent; _context4.t5 = prefix + 'hasFocusState'; (0, _context4.t3)(_context4.t4).toBe(false, _context4.t5); _context4.t6 = expect; _context4.next = 16; return driver.hasFocusVisibleState(); case 16: _context4.t7 = _context4.sent; _context4.t8 = prefix + 'hasFocusVisibleState'; (0, _context4.t6)(_context4.t7).toBe(false, _context4.t8); case 19: case 'end': return _context4.stop(); } } }, _callee4, undefined); })); return function expectNotFocused(_x, _x2) { return _ref4.apply(this, arguments); }; }(); var expectFocusedByKeyboard = function () { var _ref5 = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee5(msg, driver) { var prefix; return regeneratorRuntime.wrap(function _callee5$(_context5) { while (1) { switch (_context5.prev = _context5.next) { case 0: prefix = msg ? msg + ' - ' : ''; _context5.t0 = expect; _context5.next = 4; return driver.isFocused(); case 4: _context5.t1 = _context5.sent; _context5.t2 = prefix + 'focused'; (0, _context5.t0)(_context5.t1).toBe(true, _context5.t2); _context5.t3 = expect; _context5.next = 10; return driver.hasFocusState(); case 10: _context5.t4 = _context5.sent; _context5.t5 = prefix + 'hasFocusState'; (0, _context5.t3)(_context5.t4).toBe(true, _context5.t5); _context5.t6 = expect; _context5.next = 16; return driver.hasFocusVisibleState(); case 16: _context5.t7 = _context5.sent; _context5.t8 = prefix + 'hasFocusVisibleState'; (0, _context5.t6)(_context5.t7).toBe(true, _context5.t8); case 19: case 'end': return _context5.stop(); } } }, _callee5, undefined); })); return function expectFocusedByKeyboard(_x3, _x4) { return _ref5.apply(this, arguments); }; }(); var expectFocusedByMouse = function () { var _ref6 = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee6(msg, driver) { var prefix; return regeneratorRuntime.wrap(function _callee6$(_context6) { while (1) { switch (_context6.prev = _context6.next) { case 0: prefix = msg ? msg + ' - ' : ''; _context6.t0 = expect; _context6.next = 4; return driver.isFocused(); case 4: _context6.t1 = _context6.sent; _context6.t2 = prefix + 'focused'; (0, _context6.t0)(_context6.t1).toBe(true, _context6.t2); _context6.t3 = expect; _context6.next = 10; return driver.hasFocusState(); case 10: _context6.t4 = _context6.sent; _context6.t5 = prefix + 'hasFocusState'; (0, _context6.t3)(_context6.t4).toBe(true, _context6.t5); _context6.t6 = expect; _context6.next = 16; return driver.hasFocusVisibleState(); case 16: _context6.t7 = _context6.sent; _context6.t8 = prefix + 'hasFocusVisibleState'; (0, _context6.t6)(_context6.t7).toBe(false, _context6.t8); case 19: case 'end': return _context6.stop(); } } }, _callee6, undefined); })); return function expectFocusedByMouse(_x5, _x6) { return _ref6.apply(this, arguments); }; }(); _eyes2.default.it('should show focus styles when navigated by keyboard', _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee7() { var index, driver; return regeneratorRuntime.wrap(function _callee7$(_context7) { while (1) { switch (_context7.prev = _context7.next) { case 0: _context7.next = 2; return (0, _protractor2.waitForVisibilityOf)(radioGroupDriver.element(), 'Cannot find RadioGroup'); case 2: index = 0; case 3: if (!(index < NUM_OF_BUTTONS_IN_EXAMPLE)) { _context7.next = 18; break; } driver = (0, _privateDrivers.flattenInternalDriver)(groupDriver.getButtonDriver(index)); _context7.next = 7; return expectNotFocused('button ' + index + ' - before', driver); case 7: _context7.next = 9; return pressTab(); case 9: _context7.next = 11; return expectFocusedByKeyboard('button ' + index + ' - after', driver); case 11: _context7.t0 = index === 0; if (!_context7.t0) { _context7.next = 15; break; } _context7.next = 15; return _eyes2.default.checkWindow('button ' + index + ' with focus-visible'); case 15: index++; _context7.next = 3; break; case 18: case 'end': return _context7.stop(); } } }, _callee7, undefined); }))); beforeEach(_asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee8() { return regeneratorRuntime.wrap(function _callee8$(_context8) { while (1) { switch (_context8.prev = _context8.next) { case 0: _context8.next = 2; return browser.get((0, _storybookHelpers.createStoryUrl)({ kind: kind, story: story })); case 2: case 'end': return _context8.stop(); } } }, _callee8, undefined); }))); it('should to be selected but NOT to show focus styles when clicked by mouse', _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee9() { var index, driver; return regeneratorRuntime.wrap(function _callee9$(_context9) { while (1) { switch (_context9.prev = _context9.next) { case 0: _context9.next = 2; return (0, _protractor2.waitForVisibilityOf)(radioGroupDriver.element(), 'Cannot find RadioGroup'); case 2: index = 0; case 3: if (!(index < NUM_OF_BUTTONS_IN_EXAMPLE)) { _context9.next = 19; break; } driver = (0, _privateDrivers.flattenInternalDriver)(groupDriver.getButtonDriver(index)); _context9.next = 7; return expectNotFocused('button ' + index + ' - before', driver); case 7: _context9.next = 9; return driver.clickRoot(); case 9: _context9.t0 = expect; _context9.next = 12; return radioGroupDriver.isRadioChecked(index); case 12: _context9.t1 = _context9.sent; (0, _context9.t0)(_context9.t1).toBe(true); _context9.next = 16; return expectFocusedByMouse('button ' + index + ' - after', driver); case 16: index++; _context9.next = 3; break; case 19: case 'end': return _context9.stop(); } } }, _callee9, undefined); }))); _eyes2.default.it('should show focus styles on first item (selected)', _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee10() { var driver; return regeneratorRuntime.wrap(function _callee10$(_context10) { while (1) { switch (_context10.prev = _context10.next) { case 0: _context10.next = 2; return _AutoExampleDriver2.default.setProps({ value: 1 }); case 2: _context10.next = 4; return (0, _protractor2.waitForVisibilityOf)(radioGroupDriver.element(), 'Cannot find RadioGroup'); case 4: driver = (0, _privateDrivers.flattenInternalDriver)(groupDriver.getButtonDriver(0)); _context10.t0 = expect; _context10.next = 8; return radioGroupDriver.isRadioChecked(0); case 8: _context10.t1 = _context10.sent; (0, _context10.t0)(_context10.t1).toBe(true); _context10.next = 12; return expectNotFocused('button 0 - before', driver); case 12: _context10.next = 14; return pressTab(); case 14: _context10.next = 16; return expectFocusedByKeyboard('button 0 - after', driver); case 16: case 'end': return _context10.stop(); } } }, _callee10, undefined); }))); }); describe('RTL', function () { beforeAll(function () { return browser.get((0, _storybookHelpers.createStoryUrl)({ kind: kind, story: story, rtl: true })); }); _eyes2.default.it('should select the second option in a group', _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee11() { return regeneratorRuntime.wrap(function _callee11$(_context11) { while (1) { switch (_context11.prev = _context11.next) { case 0: _context11.next = 2; return (0, _protractor2.waitForVisibilityOf)(radioGroupDriver.element(), 'Cannot find RadioGroup'); case 2: radioGroupDriver.selectByIndex(1).click(); expect(radioGroupDriver.isRadioChecked(1)).toBe(true); case 4: case 'end': return _context11.stop(); } } }, _callee11, undefined); }))); }); });