UNPKG

@roo-ui/components

Version:

193 lines (189 loc) 8.61 kB
function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } } function _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err); } _next(undefined); }); }; } /* eslint-env jest */ import React from 'react'; import { shallow } from 'enzyme'; import { axe } from 'jest-axe'; import StarRating from './StarRating'; var ratingType; var rating; describe('<StarRating />', function () { it('renders the icons', function () { rating = '1'; ratingType = 'SELF_RATED'; var wrapper = shallow(React.createElement(StarRating, { rating: rating, ratingType: ratingType, size: "16" })); var stars = wrapper.find('Icon'); expect(stars).toHaveLength(5); }); it('renders correctly', function () { var wrapper = shallow(React.createElement(StarRating, { rating: rating, ratingType: ratingType, size: "16" })); expect(wrapper).toMatchSnapshot(); }); it('has no accessibility errors', /*#__PURE__*/ _asyncToGenerator( /*#__PURE__*/ regeneratorRuntime.mark(function _callee() { var wrapper; return regeneratorRuntime.wrap(function _callee$(_context) { while (1) { switch (_context.prev = _context.next) { case 0: wrapper = shallow(React.createElement(StarRating, { rating: rating, ratingType: ratingType, size: "16" })); _context.t0 = expect; _context.next = 4; return axe(wrapper.html()); case 4: _context.t1 = _context.sent; (0, _context.t0)(_context.t1).toHaveNoViolations(); case 6: case "end": return _context.stop(); } } }, _callee); }))); ['AAA', 'SELF_RATED'].forEach(function (type) { describe("".concat(type, " Rated <StarRating />"), function () { var ratingTypeIcon = type === 'AAA' ? 'star' : 'circle'; it('renders the 5 star rating', function () { rating = '5'; var wrapper = shallow(React.createElement(StarRating, { rating: rating, ratingType: type, size: "16" })); var stars = wrapper.find('Icon'); expect(stars.at(0).prop('name')).toEqual("".concat(ratingTypeIcon)); expect(stars.at(1).prop('name')).toEqual("".concat(ratingTypeIcon)); expect(stars.at(2).prop('name')).toEqual("".concat(ratingTypeIcon)); expect(stars.at(3).prop('name')).toEqual("".concat(ratingTypeIcon)); expect(stars.at(4).prop('name')).toEqual("".concat(ratingTypeIcon)); }); it('renders the 4.5 star rating', function () { rating = '4.5'; var wrapper = shallow(React.createElement(StarRating, { rating: rating, ratingType: type, size: "16" })); var stars = wrapper.find('Icon'); expect(stars.at(0).prop('name')).toEqual("".concat(ratingTypeIcon)); expect(stars.at(1).prop('name')).toEqual("".concat(ratingTypeIcon)); expect(stars.at(2).prop('name')).toEqual("".concat(ratingTypeIcon)); expect(stars.at(3).prop('name')).toEqual("".concat(ratingTypeIcon)); expect(stars.at(4).prop('name')).toEqual("".concat(ratingTypeIcon, "Half")); }); it('renders the 4 star rating', function () { rating = '4'; var wrapper = shallow(React.createElement(StarRating, { rating: rating, ratingType: type, size: "16" })); var stars = wrapper.find('Icon'); expect(stars.at(0).prop('name')).toEqual("".concat(ratingTypeIcon)); expect(stars.at(1).prop('name')).toEqual("".concat(ratingTypeIcon)); expect(stars.at(2).prop('name')).toEqual("".concat(ratingTypeIcon)); expect(stars.at(3).prop('name')).toEqual("".concat(ratingTypeIcon)); expect(stars.at(4).prop('name')).toEqual("".concat(ratingTypeIcon, "Border")); }); it('renders the 3.5 star rating', function () { rating = '3.5'; var wrapper = shallow(React.createElement(StarRating, { rating: rating, ratingType: type, size: "16" })); var stars = wrapper.find('Icon'); expect(stars.at(0).prop('name')).toEqual("".concat(ratingTypeIcon)); expect(stars.at(1).prop('name')).toEqual("".concat(ratingTypeIcon)); expect(stars.at(2).prop('name')).toEqual("".concat(ratingTypeIcon)); expect(stars.at(3).prop('name')).toEqual("".concat(ratingTypeIcon, "Half")); expect(stars.at(4).prop('name')).toEqual("".concat(ratingTypeIcon, "Border")); }); it('renders the 3 star rating', function () { rating = '3'; var wrapper = shallow(React.createElement(StarRating, { rating: rating, ratingType: type, size: "16" })); var stars = wrapper.find('Icon'); expect(stars.at(0).prop('name')).toEqual("".concat(ratingTypeIcon)); expect(stars.at(1).prop('name')).toEqual("".concat(ratingTypeIcon)); expect(stars.at(2).prop('name')).toEqual("".concat(ratingTypeIcon)); expect(stars.at(3).prop('name')).toEqual("".concat(ratingTypeIcon, "Border")); expect(stars.at(4).prop('name')).toEqual("".concat(ratingTypeIcon, "Border")); }); it('renders the 2.5 star rating', function () { rating = '2.5'; var wrapper = shallow(React.createElement(StarRating, { rating: rating, ratingType: type, size: "16" })); var stars = wrapper.find('Icon'); expect(stars.at(0).prop('name')).toEqual("".concat(ratingTypeIcon)); expect(stars.at(1).prop('name')).toEqual("".concat(ratingTypeIcon)); expect(stars.at(2).prop('name')).toEqual("".concat(ratingTypeIcon, "Half")); expect(stars.at(3).prop('name')).toEqual("".concat(ratingTypeIcon, "Border")); expect(stars.at(4).prop('name')).toEqual("".concat(ratingTypeIcon, "Border")); }); it('renders the 2 star rating', function () { rating = '2'; var wrapper = shallow(React.createElement(StarRating, { rating: rating, ratingType: type, size: "16" })); var stars = wrapper.find('Icon'); expect(stars.at(0).prop('name')).toEqual("".concat(ratingTypeIcon)); expect(stars.at(1).prop('name')).toEqual("".concat(ratingTypeIcon)); expect(stars.at(2).prop('name')).toEqual("".concat(ratingTypeIcon, "Border")); expect(stars.at(3).prop('name')).toEqual("".concat(ratingTypeIcon, "Border")); expect(stars.at(4).prop('name')).toEqual("".concat(ratingTypeIcon, "Border")); }); it('renders the 1.5 star rating', function () { rating = '1.5'; var wrapper = shallow(React.createElement(StarRating, { rating: rating, ratingType: type, size: "16" })); var stars = wrapper.find('Icon'); expect(stars.at(0).prop('name')).toEqual("".concat(ratingTypeIcon)); expect(stars.at(1).prop('name')).toEqual("".concat(ratingTypeIcon, "Half")); expect(stars.at(2).prop('name')).toEqual("".concat(ratingTypeIcon, "Border")); expect(stars.at(3).prop('name')).toEqual("".concat(ratingTypeIcon, "Border")); expect(stars.at(4).prop('name')).toEqual("".concat(ratingTypeIcon, "Border")); }); it('renders the 1 star rating', function () { rating = '1'; var wrapper = shallow(React.createElement(StarRating, { rating: rating, ratingType: type, size: "16" })); var stars = wrapper.find('Icon'); expect(stars.at(0).prop('name')).toEqual("".concat(ratingTypeIcon)); expect(stars.at(1).prop('name')).toEqual("".concat(ratingTypeIcon, "Border")); expect(stars.at(2).prop('name')).toEqual("".concat(ratingTypeIcon, "Border")); expect(stars.at(3).prop('name')).toEqual("".concat(ratingTypeIcon, "Border")); expect(stars.at(4).prop('name')).toEqual("".concat(ratingTypeIcon, "Border")); }); }); }); });