wix-style-react
Version:
wix-style-react
237 lines (185 loc) • 8.07 kB
JavaScript
;
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);
})));
});
});