wix-style-react
Version:
wix-style-react
173 lines (138 loc) • 6.08 kB
JavaScript
;
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);
})));
});
});