UNPKG

wix-style-react

Version:
369 lines (322 loc) • 13.3 kB
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 React from 'react'; import { createUniDriverFactory } from 'wix-ui-test-utils/uni-driver-factory'; import Thumbnail from './Thumbnail'; import { thumbnailPrivateDriverFactory } from './Thumbnail.driver.private'; var createDriver = createUniDriverFactory(thumbnailPrivateDriverFactory); describe('Thumbnail', function () { it('should allow adding title', _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee() { var title, driver; return regeneratorRuntime.wrap(function _callee$(_context) { while (1) { switch (_context.prev = _context.next) { case 0: title = 'I am a title'; driver = createDriver(React.createElement(Thumbnail, { title: title })); _context.t0 = expect; _context.next = 5; return driver.getTitle(); case 5: _context.t1 = _context.sent; _context.t2 = title; (0, _context.t0)(_context.t1).toEqual(_context.t2); case 8: case 'end': return _context.stop(); } } }, _callee, _this); }))); it('should allow adding description', _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee2() { var description, driver; return regeneratorRuntime.wrap(function _callee2$(_context2) { while (1) { switch (_context2.prev = _context2.next) { case 0: description = 'I am a description'; driver = createDriver(React.createElement(Thumbnail, { description: description })); _context2.t0 = expect; _context2.next = 5; return driver.getDescription(); case 5: _context2.t1 = _context2.sent; _context2.t2 = description; (0, _context2.t0)(_context2.t1).toEqual(_context2.t2); case 8: case 'end': return _context2.stop(); } } }, _callee2, _this); }))); it('should be clickable', _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee3() { var onClick, driver; return regeneratorRuntime.wrap(function _callee3$(_context3) { while (1) { switch (_context3.prev = _context3.next) { case 0: onClick = jest.fn(); driver = createDriver(React.createElement(Thumbnail, { onClick: onClick })); _context3.next = 4; return driver.click(); case 4: expect(onClick).toHaveBeenCalled(); case 5: case 'end': return _context3.stop(); } } }, _callee3, _this); }))); describe('`image` prop', function () { describe('as string', function () { it('should use string as <img/> src', _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee4() { var src, driver; return regeneratorRuntime.wrap(function _callee4$(_context4) { while (1) { switch (_context4.prev = _context4.next) { case 0: src = 'john.jpg'; driver = createDriver(React.createElement(Thumbnail, { image: src, title: 'shit' })); _context4.t0 = expect; _context4.next = 5; return driver.getImage().$('img').attr('src'); case 5: _context4.t1 = _context4.sent; _context4.t2 = src; (0, _context4.t0)(_context4.t1).toEqual(_context4.t2); case 8: case 'end': return _context4.stop(); } } }, _callee4, _this); }))); }); describe('as node', function () { it('should render that node as is', _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee5() { var image, driver; return regeneratorRuntime.wrap(function _callee5$(_context5) { while (1) { switch (_context5.prev = _context5.next) { case 0: image = React.createElement( 'div', { 'data-hook': 'image-node' }, 'catch me' ); driver = createDriver(React.createElement(Thumbnail, { image: image })); _context5.t0 = expect; _context5.next = 5; return driver.getImage().$('[data-hook="image-node"]').text(); case 5: _context5.t1 = _context5.sent; (0, _context5.t0)(_context5.t1).toEqual('catch me'); case 7: case 'end': return _context5.stop(); } } }, _callee5, _this); }))); }); }); describe('`backgroundImage` prop', _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee8() { return regeneratorRuntime.wrap(function _callee8$(_context8) { while (1) { switch (_context8.prev = _context8.next) { case 0: it('should allow adding backgroundImage as URL', _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee6() { var driver; return regeneratorRuntime.wrap(function _callee6$(_context6) { while (1) { switch (_context6.prev = _context6.next) { case 0: _context6.next = 2; return createDriver(React.createElement(Thumbnail, { title: 'title', description: 'description', image: 'image.jpg', backgroundImage: 'john.jpg' })); case 2: driver = _context6.sent; _context6.t0 = expect; _context6.next = 6; return driver.getBackgroundImage().attr('style'); case 6: _context6.t1 = _context6.sent; (0, _context6.t0)(_context6.t1).toEqual('background-image: url(john.jpg);'); case 8: case 'end': return _context6.stop(); } } }, _callee6, _this); }))); it('should disable title, description and image', _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee7() { var driver; return regeneratorRuntime.wrap(function _callee7$(_context7) { while (1) { switch (_context7.prev = _context7.next) { case 0: _context7.next = 2; return createDriver(React.createElement(Thumbnail, { title: 'title', description: 'description', image: 'image.jpg', backgroundImage: 'john.jpg' })); case 2: driver = _context7.sent; _context7.t0 = expect; _context7.next = 6; return driver.titleExists(); case 6: _context7.t1 = _context7.sent; (0, _context7.t0)(_context7.t1).toEqual(false); _context7.t2 = expect; _context7.next = 11; return driver.descriptionExists(); case 11: _context7.t3 = _context7.sent; (0, _context7.t2)(_context7.t3).toEqual(false); _context7.t4 = expect; _context7.next = 16; return driver.imageExists(); case 16: _context7.t5 = _context7.sent; (0, _context7.t4)(_context7.t5).toEqual(false); case 18: case 'end': return _context7.stop(); } } }, _callee7, _this); }))); case 2: case 'end': return _context8.stop(); } } }, _callee8, _this); }))); describe('`selected` prop', function () { it('should render icon when true', _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee9() { var driver; return regeneratorRuntime.wrap(function _callee9$(_context9) { while (1) { switch (_context9.prev = _context9.next) { case 0: driver = createDriver(React.createElement(Thumbnail, { selected: true })); _context9.t0 = expect; _context9.next = 4; return driver.selectedIconExists(); case 4: _context9.t1 = _context9.sent; (0, _context9.t0)(_context9.t1).toEqual(true); _context9.t2 = expect; _context9.next = 9; return driver.isSelected(); case 9: _context9.t3 = _context9.sent; (0, _context9.t2)(_context9.t3).toEqual(true); case 11: case 'end': return _context9.stop(); } } }, _callee9, _this); }))); it('should not render icon when false', _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee10() { var driver; return regeneratorRuntime.wrap(function _callee10$(_context10) { while (1) { switch (_context10.prev = _context10.next) { case 0: driver = createDriver(React.createElement(Thumbnail, { selected: true, hideSelectedIcon: true })); _context10.t0 = expect; _context10.next = 4; return driver.getSelectedIcon().exists(); case 4: _context10.t1 = _context10.sent; (0, _context10.t0)(_context10.t1).toEqual(false); case 6: case 'end': return _context10.stop(); } } }, _callee10, _this); }))); }); describe('`disabled` prop', function () { it('should have disabled state', _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee11() { var driver; return regeneratorRuntime.wrap(function _callee11$(_context11) { while (1) { switch (_context11.prev = _context11.next) { case 0: driver = createDriver(React.createElement(Thumbnail, { disabled: true })); _context11.t0 = expect; _context11.next = 4; return driver.isDisabled(); case 4: _context11.t1 = _context11.sent; (0, _context11.t0)(_context11.t1).toEqual(true); case 6: case 'end': return _context11.stop(); } } }, _callee11, _this); }))); it('should not trigger onClick', _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee12() { var onClick, driver; return regeneratorRuntime.wrap(function _callee12$(_context12) { while (1) { switch (_context12.prev = _context12.next) { case 0: onClick = jest.fn(); driver = createDriver(React.createElement(Thumbnail, { disabled: true, onClick: onClick })); _context12.next = 4; return driver.click(); case 4: expect(onClick).not.toHaveBeenCalled(); case 5: case 'end': return _context12.stop(); } } }, _callee12, _this); }))); }); describe('`width` & `height` props', function () { it('should set width & height', _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee13() { var driver; return regeneratorRuntime.wrap(function _callee13$(_context13) { while (1) { switch (_context13.prev = _context13.next) { case 0: driver = createDriver(React.createElement(Thumbnail, { width: 100, height: 100 })); _context13.t0 = expect; _context13.next = 4; return driver.getWidth(); case 4: _context13.t1 = _context13.sent; (0, _context13.t0)(_context13.t1).toEqual('100px'); _context13.t2 = expect; _context13.next = 9; return driver.getHeight(); case 9: _context13.t3 = _context13.sent; (0, _context13.t2)(_context13.t3).toEqual('100px'); case 11: case 'end': return _context13.stop(); } } }, _callee13, _this); }))); }); });