UNPKG

wix-style-react

Version:
226 lines (182 loc) • 7.51 kB
var _this = this; 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"); }); }; } import browserLogs from 'protractor-browser-logs'; import { eyesItInstance } from '../../test/utils/eyes-it'; import autoExampleDriver from 'wix-storybook-utils/AutoExampleDriver'; import { storySettings } from '../../stories/PopoverMenu/storySettings'; var EC = protractor.ExpectedConditions; import { popoverMenuTestkitFactory } from '../../testkit/protractor'; import { waitForVisibilityOf } from 'wix-ui-test-utils/protractor'; import { createStoryUrl } from '../../test/utils/storybook-helpers'; 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 = 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 = popoverMenuTestkitFactory({ dataHook: storySettings.dataHook }).init.menuItemDataHook(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 = eyesItInstance(); var driver = void 0; var logs = browserLogs(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 waitForVisibilityOf(driver.element(), 'Can not find PopoverMenu trigger element'); case 4: _context2.next = 6; return driver.click(); case 6: waitForVisibilityOf(driver.menu.element(), 'Can not find PopoverMenu menu'); case 7: case 'end': return _context2.stop(); } } }, _callee2, _this); }))); describe('RTL', function () { afterEach(function () { return autoExampleDriver.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 autoExampleDriver.setProps({ placement: 'left' }); case 4: _context3.next = 6; return waitForVisibilityOf(driver.element(), 'Can not find PopoverMenu trigger element'); case 6: _context3.next = 8; return driver.click(); case 8: _context3.next = 10; return waitForVisibilityOf(driver.menu.element(), 'Can not find PopoverMenu menu'); case 10: case 'end': return _context3.stop(); } } }, _callee3, _this); }))); }); 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 waitForVisibilityOf(driver.element()); case 4: _context4.next = 6; return driver.click(); case 6: _context4.next = 8; return 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, _this); }))); 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 = createStoryUrl({ kind: 'Tests/7. Tooltip', story: '7.3. Popover Menu' }); _context5.next = 3; return browser.get(storyUrl); case 3: driver = popoverMenuTestkitFactory({ dataHook: 'popover-0' }).init.menuItemDataHook('popover-item-0'); _context5.next = 6; return waitForVisibilityOf(driver.element()); case 6: _context5.next = 8; return driver.click(); case 8: _context5.next = 10; return 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, _this); }))); }); });