UNPKG

wix-style-react

Version:
173 lines (138 loc) • 6.08 kB
'use strict'; var _protractor = require('wix-ui-test-utils/protractor'); var _AutoExampleDriver = require('wix-storybook-utils/AutoExampleDriver'); var _AutoExampleDriver2 = _interopRequireDefault(_AutoExampleDriver); var _eyesIt = require('../../test/utils/eyes-it'); var _ProportionDriver = require('./Proportion.driver.private'); var _storySettings = require('../../stories/Proportion/storySettings'); var _ratios = require('./ratios'); 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 eyes = (0, _eyesIt.eyesItInstance)({ enableSnapshotAtBrowserGet: false }); describe('Proportion', function () { var storyUrl = (0, _protractor.createStoryUrl)({ kind: _storySettings.storySettings.category, story: _storySettings.storySettings.storyName }); var createDriver = function () { var _ref = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee() { var dataHook = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : _storySettings.storySettings.dataHook; var driver; return regeneratorRuntime.wrap(function _callee$(_context) { while (1) { switch (_context.prev = _context.next) { case 0: driver = (0, _protractor.protractorUniTestkitFactoryCreator)(_ProportionDriver.proportionPrivateDriverFactory)({ dataHook: dataHook }); _context.t0 = _protractor.waitForVisibilityOf; _context.next = 4; return driver.element(); case 4: _context.t1 = _context.sent; _context.t2 = 'Cannot find <Proportion/> component with dataHook of ' + dataHook; _context.next = 8; return (0, _context.t0)(_context.t1, _context.t2); case 8: return _context.abrupt('return', driver); case 9: case 'end': return _context.stop(); } } }, _callee, undefined); })); return function createDriver() { return _ref.apply(this, arguments); }; }(); beforeEach(_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 _AutoExampleDriver2.default.reset(); case 2: case 'end': return _context2.stop(); } } }, _callee2, undefined); }))); beforeAll(_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); case 2: case 'end': return _context3.stop(); } } }, _callee3, undefined); }))); describe('predefined ratios', function () { var _loop = function _loop(predefinedRatio) { if (_ratios.PREDEFINED_RATIOS.hasOwnProperty(predefinedRatio)) { eyes.it('should maintain proportion with predefined ' + predefinedRatio, _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee4() { var expectedRatio, driver, aspectRatioResult; return regeneratorRuntime.wrap(function _callee4$(_context4) { while (1) { switch (_context4.prev = _context4.next) { case 0: expectedRatio = _ratios.PREDEFINED_RATIOS[predefinedRatio]; _context4.next = 3; return _AutoExampleDriver2.default.setProps({ aspectRatio: expectedRatio }); case 3: _context4.next = 5; return createDriver(); case 5: driver = _context4.sent; _context4.next = 8; return driver.getAspectRatio(); case 8: aspectRatioResult = _context4.sent; expect(aspectRatioResult.toFixed(2)).toBe(expectedRatio.toFixed(2)); case 10: case 'end': return _context4.stop(); } } }, _callee4, undefined); }))); } }; for (var predefinedRatio in _ratios.PREDEFINED_RATIOS) { _loop(predefinedRatio); } }); describe('custom ratio', function () { eyes.it('should maintain proportion with custom ratio', _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee5() { var expectedRatio, driver, aspectRatioResult; return regeneratorRuntime.wrap(function _callee5$(_context5) { while (1) { switch (_context5.prev = _context5.next) { case 0: expectedRatio = 9.5 / 3; _context5.next = 3; return _AutoExampleDriver2.default.setProps({ aspectRatio: expectedRatio }); case 3: _context5.next = 5; return createDriver(); case 5: driver = _context5.sent; _context5.next = 8; return driver.getAspectRatio(); case 8: aspectRatioResult = _context5.sent; expect(aspectRatioResult.toFixed(2)).toBe(expectedRatio.toFixed(2)); case 10: case 'end': return _context5.stop(); } } }, _callee5, undefined); }))); }); });