UNPKG

wix-style-react

Version:
237 lines (185 loc) • 8.07 kB
'use strict'; var _protractorBrowserLogs = require('protractor-browser-logs'); var _protractorBrowserLogs2 = _interopRequireDefault(_protractorBrowserLogs); var _eyesIt = require('../../test/utils/eyes-it'); var _AutoExampleDriver = require('wix-storybook-utils/AutoExampleDriver'); var _AutoExampleDriver2 = _interopRequireDefault(_AutoExampleDriver); var _storySettings = require('../../stories/PopoverMenu/storySettings'); var _protractor = require('../../testkit/protractor'); var _protractor2 = require('wix-ui-test-utils/protractor'); var _storybookHelpers = require('../../test/utils/storybook-helpers'); 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 EC = protractor.ExpectedConditions; describe('PopoverMenu', function () { var getPage = function () { var _ref = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee() { var _ref2 = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}, rtl = _ref2.rtl; var storyUrl; return regeneratorRuntime.wrap(function _callee$(_context) { while (1) { switch (_context.prev = _context.next) { case 0: storyUrl = (0, _storybookHelpers.createStoryUrl)({ kind: '7. Tooltips', story: '7.3 Popover Menu', withExamples: false, rtl: rtl }); logs.reset(); logs.ignore(function (message) { return message.message.indexOf('Uncaught') === -1; }); driver = (0, _protractor.popoverMenuTestkitFactory)({ dataHook: _storySettings.storySettings.dataHook }).init.menuItemDataHook(_storySettings.storySettings.itemDataHook); _context.next = 6; return browser.get(storyUrl); case 6: case 'end': return _context.stop(); } } }, _callee, this); })); return function getPage() { return _ref.apply(this, arguments); }; }(); var eyes = (0, _eyesIt.eyesItInstance)(); var driver = void 0; var logs = (0, _protractorBrowserLogs2.default)(browser); eyes.it('should show popover menu', _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 getPage(); case 2: _context2.next = 4; return (0, _protractor2.waitForVisibilityOf)(driver.element(), 'Can not find PopoverMenu trigger element'); case 4: _context2.next = 6; return driver.click(); case 6: (0, _protractor2.waitForVisibilityOf)(driver.menu.element(), 'Can not find PopoverMenu menu'); case 7: case 'end': return _context2.stop(); } } }, _callee2, undefined); }))); describe('RTL', function () { afterEach(function () { return _AutoExampleDriver2.default.remount(); }); eyes.it('should show popover menu', _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 getPage({ rtl: true }); case 2: _context3.next = 4; return _AutoExampleDriver2.default.setProps({ placement: 'left' }); case 4: _context3.next = 6; return (0, _protractor2.waitForVisibilityOf)(driver.element(), 'Can not find PopoverMenu trigger element'); case 6: _context3.next = 8; return driver.click(); case 8: _context3.next = 10; return (0, _protractor2.waitForVisibilityOf)(driver.menu.element(), 'Can not find PopoverMenu menu'); case 10: case 'end': return _context3.stop(); } } }, _callee3, undefined); }))); }); it('should hide popover menu on item click', _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee4() { return regeneratorRuntime.wrap(function _callee4$(_context4) { while (1) { switch (_context4.prev = _context4.next) { case 0: _context4.next = 2; return getPage(); case 2: _context4.next = 4; return (0, _protractor2.waitForVisibilityOf)(driver.element()); case 4: _context4.next = 6; return driver.click(); case 6: _context4.next = 8; return (0, _protractor2.waitForVisibilityOf)(driver.menu.element()); case 8: _context4.next = 10; return driver.menu.clickItemAt(0); case 10: _context4.next = 12; return browser.wait(EC.stalenessOf(driver.menu.element()), 5000, 'PopoverMenu has not been hidden after menu item click'); case 12: case 'end': return _context4.stop(); } } }, _callee4, undefined); }))); describe('regression tests', function () { it('Uncaught TypeError: https://github.com/wix/wix-style-react/issues/2113', _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee5() { var storyUrl; return regeneratorRuntime.wrap(function _callee5$(_context5) { while (1) { switch (_context5.prev = _context5.next) { case 0: storyUrl = (0, _storybookHelpers.createStoryUrl)({ kind: 'Tests/7. Tooltip', story: '7.3. Popover Menu' }); _context5.next = 3; return browser.get(storyUrl); case 3: driver = (0, _protractor.popoverMenuTestkitFactory)({ dataHook: 'popover-0' }).init.menuItemDataHook('popover-item-0'); _context5.next = 6; return (0, _protractor2.waitForVisibilityOf)(driver.element()); case 6: _context5.next = 8; return driver.click(); case 8: _context5.next = 10; return (0, _protractor2.waitForVisibilityOf)(driver.menu.element()); case 10: _context5.next = 12; return driver.menu.clickItemAt(0); case 12: _context5.next = 14; return browser.wait(EC.stalenessOf(driver.menu.element()), 5000, 'PopoverMenu has not been hidden after menu item click'); case 14: _context5.next = 16; return browser.wait(EC.stalenessOf(driver.element()), 5000, 'PopoverMenu has not been removed after menu item click'); case 16: logs.expect(/Uncaught TypeError: Cannot read property 'parentElement' of null/); _context5.next = 19; return logs.verify().then(function () { fail('Expected error occurred'); }).catch(function (e) { expect(e.message).toContain('NO MESSAGE TO EXPECT'); }); case 19: case 'end': return _context5.stop(); } } }, _callee5, undefined); }))); }); });