wix-style-react
Version:
wix-style-react
244 lines (207 loc) • 8.65 kB
JavaScript
;
var _eyesIt = require('../../test/utils/eyes-it');
var _protractor = require('../../testkit/protractor');
var _storybookHelpers = require('../../test/utils/storybook-helpers');
var _storiesHierarchy = require('../../stories/storiesHierarchy');
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('Calendar', function () {
var eyes = (0, _eyesIt.eyesItInstance)();
var storyUrl = function storyUrl(_ref) {
var selectedDays = _ref.selectedDays,
numOfMonths = _ref.numOfMonths;
var baseUrl = (0, _storybookHelpers.createStoryUrl)({
kind: _storiesHierarchy.TESTS_PREFIX + '/3. Inputs/3.13 Calendar',
story: '1. selectedDays'
});
return baseUrl + '&selectedDays=' + global.encodeURIComponent(JSON.stringify(selectedDays)) + '&numOfMonths=' + (numOfMonths || 1);
};
var dataHook = 'calendar';
var driver = (0, _protractor.calendarTestkitFactory)({ dataHook: dataHook });
eyes.it('should correctly render when selectedDays is a single date', _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee() {
return regeneratorRuntime.wrap(function _callee$(_context) {
while (1) {
switch (_context.prev = _context.next) {
case 0:
_context.next = 2;
return browser.get(storyUrl({ selectedDays: new Date('2017/05/01') }));
case 2:
_context.next = 4;
return (0, _protractor.waitForVisibilityOf)(driver.getElement(), 'Cannot find Calendar');
case 4:
case 'end':
return _context.stop();
}
}
}, _callee, undefined);
})), { enableSnapshotAtBrowserGet: false });
eyes.it('should correctly render when selectedDays is a date range', _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 browser.get(storyUrl({
selectedDays: {
from: new Date('2017/05/02'),
to: new Date('2017/05/06')
}
}));
case 2:
_context2.next = 4;
return (0, _protractor.waitForVisibilityOf)(driver.getElement(), 'Cannot find Calendar');
case 4:
case 'end':
return _context2.stop();
}
}
}, _callee2, undefined);
})), { enableSnapshotAtBrowserGet: false });
eyes.it('should correctly render two months', _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 browser.get(storyUrl({
selectedDays: {
from: new Date('2017/05/02'),
to: new Date('2017/06/06')
},
numOfMonths: 2
}));
case 2:
_context3.next = 4;
return (0, _protractor.waitForVisibilityOf)(driver.getElement(), 'Cannot find Calendar');
case 4:
case 'end':
return _context3.stop();
}
}
}, _callee3, undefined);
})), { enableSnapshotAtBrowserGet: false });
eyes.it('should correctly render when selectedDays is a date range with boundaries outside the current month', _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 browser.get(storyUrl({
selectedDays: {
from: new Date('2017/04/01'),
to: new Date('2017/07/01')
}
}));
case 2:
_context4.next = 4;
return (0, _protractor.waitForVisibilityOf)(driver.getElement(), 'Cannot find Calendar');
case 4:
_context4.next = 6;
return driver.nextMonth();
case 6:
_context4.t0 = expect;
_context4.next = 9;
return driver.getMonthCaption();
case 9:
_context4.t1 = _context4.sent;
(0, _context4.t0)(_context4.t1).toBe('May');
case 11:
case 'end':
return _context4.stop();
}
}
}, _callee4, undefined);
})), { enableSnapshotAtBrowserGet: false });
it('should navigate to previous month', _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee5() {
return regeneratorRuntime.wrap(function _callee5$(_context5) {
while (1) {
switch (_context5.prev = _context5.next) {
case 0:
_context5.next = 2;
return browser.get(storyUrl({
selectedDays: new Date('2017/06/01')
}));
case 2:
_context5.next = 4;
return (0, _protractor.waitForVisibilityOf)(driver.getElement(), 'Cannot find Calendar');
case 4:
_context5.next = 6;
return driver.prevMonth();
case 6:
_context5.t0 = expect;
_context5.next = 9;
return driver.getMonthCaption();
case 9:
_context5.t1 = _context5.sent;
(0, _context5.t0)(_context5.t1).toBe('May');
case 11:
case 'end':
return _context5.stop();
}
}
}, _callee5, undefined);
})));
eyes.it('should correctly render when selectedDays is an infinite date range starting in the current month', _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee6() {
return regeneratorRuntime.wrap(function _callee6$(_context6) {
while (1) {
switch (_context6.prev = _context6.next) {
case 0:
_context6.next = 2;
return browser.get(storyUrl({
selectedDays: {
from: new Date('2017/05/02')
}
}));
case 2:
_context6.next = 4;
return (0, _protractor.waitForVisibilityOf)(driver.getElement(), 'Cannot find Calendar');
case 4:
case 'end':
return _context6.stop();
}
}
}, _callee6, undefined);
})), { enableSnapshotAtBrowserGet: false });
eyes.it('should correctly render when selectedDays is an infinite date range ending in the current month', _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee7() {
return regeneratorRuntime.wrap(function _callee7$(_context7) {
while (1) {
switch (_context7.prev = _context7.next) {
case 0:
_context7.next = 2;
return browser.get(storyUrl({
selectedDays: {
to: new Date('2017/06/29')
}
}));
case 2:
_context7.next = 4;
return (0, _protractor.waitForVisibilityOf)(driver.getElement(), 'Cannot find Calendar');
case 4:
case 'end':
return _context7.stop();
}
}
}, _callee7, undefined);
})), { enableSnapshotAtBrowserGet: false });
eyes.it('should correctly render when selectedDays is a range of one day', _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee8() {
return regeneratorRuntime.wrap(function _callee8$(_context8) {
while (1) {
switch (_context8.prev = _context8.next) {
case 0:
_context8.next = 2;
return browser.get(storyUrl({
selectedDays: {
from: new Date('2017/05/02'),
to: new Date('2017/05/02')
}
}));
case 2:
_context8.next = 4;
return (0, _protractor.waitForVisibilityOf)(driver.getElement(), 'Cannot find Calendar');
case 4:
case 'end':
return _context8.stop();
}
}
}, _callee8, undefined);
})), { enableSnapshotAtBrowserGet: false });
});