wix-style-react
Version:
wix-style-react
114 lines (94 loc) • 4.64 kB
JavaScript
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 eyes from 'eyes.it';
import { tooltipTestkitFactory } from '../../testkit/protractor';
import { waitForVisibilityOf } from 'wix-ui-test-utils/protractor';
import { getStoryUrl } from '../../test/utils/storybook-helpers';
import { SHORT_CONTENT, LONG_CONTENT } from '../../stories/Tooltip/content';
describe('Tooltip', function () {
var tooltipStoryUrl = getStoryUrl('7. Tooltips', '7.1. Tooltip');
var popoverStoryUrl = 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);
});
eyes.it('should see tooltip centered above element', function () {
var driver = tooltipTestkitFactory({ dataHook: dataHook });
waitForVisibilityOf(driver.getTooltipContentElement(tooltipDataHook), 'Cannot find Tooltip content').then(function () {
expect(driver.getTooltipTextContent(tooltipDataHook)).toBe(SHORT_CONTENT);
});
});
eyes.it('should see tooltip centered above element with longer content', function () {
var driver = tooltipTestkitFactory({ dataHook: dataHook });
waitForVisibilityOf(driver.getTooltipContentElement(tooltipDataHook), 'Cannot find Tooltip content').then(function () {
driver.clickButton();
waitForVisibilityOf(driver.getTooltipContentElement(tooltipDataHook), 'Cannot find Tooltip content').then(function () {
expect(driver.getTooltipTextContent(tooltipDataHook)).toBe(LONG_CONTENT);
});
});
});
eyes.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 = tooltipTestkitFactory({ dataHook: dataHook });
_context.next = 4;
return driver.element().$('[data-hook="popover-button"]').click();
case 4:
eyes.checkWindow('Check tooltip with popover styles');
_context.next = 7;
return 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:
eyes.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 waitForVisibilityOf(driver.getTooltipContentElement(tooltipDataHook), 'Cannot find Tooltip content');
case 16:
case 'end':
return _context.stop();
}
}
}, _callee, _this);
})));
});
describe('Popover story', function () {
beforeEach(function () {
browser.get(popoverStoryUrl);
});
describe('Popover with EmptyState', function () {
eyes.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 = tooltipTestkitFactory({
dataHook: 'popover-empty-state'
});
_context2.next = 3;
return waitForVisibilityOf(driver.element());
case 3:
driver.clickButton();
case 4:
case 'end':
return _context2.stop();
}
}
}, _callee2, _this);
})));
});
});
});