wix-style-react
Version:
wix-style-react
122 lines (96 loc) • 5.06 kB
JavaScript
;
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 _content = require('../../stories/Tooltip/content');
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"); }); }; }
describe('Tooltip', function () {
var tooltipStoryUrl = (0, _storybookHelpers.getStoryUrl)('7. Tooltips', '7.1. Tooltip');
var popoverStoryUrl = (0, _storybookHelpers.getStoryUrl)('7. Tooltips', '7.2. Popover');
var dataHook = 'tooltip-e2e-wrapper';
var tooltipDataHook = 'tooltip-e2e-tooltip';
describe('Tooltip story', function () {
beforeEach(function () {
browser.get(tooltipStoryUrl);
});
_eyes2.default.it('should see tooltip centered above element', function () {
var driver = (0, _protractor.tooltipTestkitFactory)({ dataHook: dataHook });
(0, _protractor2.waitForVisibilityOf)(driver.getTooltipContentElement(tooltipDataHook), 'Cannot find Tooltip content').then(function () {
expect(driver.getTooltipTextContent(tooltipDataHook)).toBe(_content.SHORT_CONTENT);
});
});
_eyes2.default.it('should see tooltip centered above element with longer content', function () {
var driver = (0, _protractor.tooltipTestkitFactory)({ dataHook: dataHook });
(0, _protractor2.waitForVisibilityOf)(driver.getTooltipContentElement(tooltipDataHook), 'Cannot find Tooltip content').then(function () {
driver.clickButton();
(0, _protractor2.waitForVisibilityOf)(driver.getTooltipContentElement(tooltipDataHook), 'Cannot find Tooltip content').then(function () {
expect(driver.getTooltipTextContent(tooltipDataHook)).toBe(_content.LONG_CONTENT);
});
});
});
_eyes2.default.it('should show tooltip in popover mode', _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee() {
var EC, driver;
return regeneratorRuntime.wrap(function _callee$(_context) {
while (1) {
switch (_context.prev = _context.next) {
case 0:
EC = protractor.ExpectedConditions;
driver = (0, _protractor.tooltipTestkitFactory)({ dataHook: dataHook });
_context.next = 4;
return driver.element().$('[data-hook="popover-button"]').click();
case 4:
_eyes2.default.checkWindow('Check tooltip with popover styles');
_context.next = 7;
return (0, _protractor2.waitForVisibilityOf)(driver.getTooltipContentElement(tooltipDataHook), 'Cannot find Tooltip content');
case 7:
_context.next = 9;
return driver.element().$('[data-hook="tooltip-anchor"]').click();
case 9:
_context.next = 11;
return browser.wait(EC.not(EC.presenceOf(driver.getTooltipContentElement(tooltipDataHook))));
case 11:
_eyes2.default.checkWindow('Check that we do not have tooltip content');
_context.next = 14;
return driver.element().$('[data-hook="tooltip-anchor"]').click();
case 14:
_context.next = 16;
return (0, _protractor2.waitForVisibilityOf)(driver.getTooltipContentElement(tooltipDataHook), 'Cannot find Tooltip content');
case 16:
case 'end':
return _context.stop();
}
}
}, _callee, undefined);
})));
});
describe('Popover story', function () {
beforeEach(function () {
browser.get(popoverStoryUrl);
});
describe('Popover with EmptyState', function () {
_eyes2.default.it('should not break design', _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee2() {
var driver;
return regeneratorRuntime.wrap(function _callee2$(_context2) {
while (1) {
switch (_context2.prev = _context2.next) {
case 0:
driver = (0, _protractor.tooltipTestkitFactory)({
dataHook: 'popover-empty-state'
});
_context2.next = 3;
return (0, _protractor2.waitForVisibilityOf)(driver.element());
case 3:
driver.clickButton();
case 4:
case 'end':
return _context2.stop();
}
}
}, _callee2, undefined);
})));
});
});
});