UNPKG

airbnb-prop-types

Version:

Custom React PropType validators that we use at Airbnb.

207 lines (196 loc) 11.1 kB
"use strict"; var _chai = require("chai"); var _propTypes = require("prop-types"); var _react = _interopRequireDefault(require("react")); var _ = require(".."); var _callValidator = _interopRequireDefault(require("./_callValidator")); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); } describe('or', function () { it('returns a function', function () { (0, _chai.expect)(_typeof((0, _.or)([_propTypes.string, _propTypes.bool]))).to.equal('function'); }); it('throws if given a non-array', function () { (0, _chai.expect)(function () { return (0, _.or)(); }).to["throw"](TypeError); (0, _chai.expect)(function () { return (0, _.or)(null); }).to["throw"](TypeError); (0, _chai.expect)(function () { return (0, _.or)(undefined); }).to["throw"](TypeError); (0, _chai.expect)(function () { return (0, _.or)({}); }).to["throw"](TypeError); }); it('throws if given an array of zero or one items', function () { (0, _chai.expect)(function () { return (0, _.or)([]); }).to["throw"](RangeError); (0, _chai.expect)(function () { return (0, _.or)([_propTypes.string]); }).to["throw"](RangeError); }); function assertPasses(validator, element, propName) { (0, _chai.expect)((0, _callValidator["default"])(validator, element, propName, '"or" test')).to.equal(null); } function assertFails(validator, element, propName) { (0, _chai.expect)((0, _callValidator["default"])(validator, element, propName, '"or" test')).to.be.instanceOf(Error); } it('allows composing propTypes', function () { var validator = (0, _.or)([_propTypes.bool, _propTypes.number, (0, _propTypes.arrayOf)(_propTypes.string)]); assertPasses(validator, /*#__PURE__*/_react["default"].createElement("div", { a: true }), 'a'); assertPasses(validator, /*#__PURE__*/_react["default"].createElement("div", { a: 1 }), 'a'); assertPasses(validator, /*#__PURE__*/_react["default"].createElement("div", { a: [] }), 'a'); assertPasses(validator, /*#__PURE__*/_react["default"].createElement("div", { a: ['b', 'c'] }), 'a'); assertFails(validator, /*#__PURE__*/_react["default"].createElement("div", { a: ['b', 1] }), 'a'); assertFails(validator, /*#__PURE__*/_react["default"].createElement("div", { a: "b" }), 'a'); assertPasses(validator.isRequired, /*#__PURE__*/_react["default"].createElement("div", { a: true }), 'a'); assertPasses(validator.isRequired, /*#__PURE__*/_react["default"].createElement("div", { a: 1 }), 'a'); assertPasses(validator.isRequired, /*#__PURE__*/_react["default"].createElement("div", { a: [] }), 'a'); assertPasses(validator.isRequired, /*#__PURE__*/_react["default"].createElement("div", { a: ['b', 'c'] }), 'a'); assertFails(validator.isRequired, /*#__PURE__*/_react["default"].createElement("div", { a: ['b', 1] }), 'a'); assertFails(validator.isRequired, /*#__PURE__*/_react["default"].createElement("div", { a: "b" }), 'a'); assertFails(validator.isRequired, /*#__PURE__*/_react["default"].createElement("div", null), 'a'); }); describe('works with explicitNull', function () { it('works when outer and inner are optional', function () { assertPasses((0, _.or)([_propTypes.bool.isRequired, (0, _.explicitNull)()]), /*#__PURE__*/_react["default"].createElement("div", { a: true }), 'a'); assertPasses((0, _.or)([(0, _.explicitNull)(), _propTypes.bool.isRequired]), /*#__PURE__*/_react["default"].createElement("div", { a: true }), 'a'); assertPasses((0, _.or)([_propTypes.bool.isRequired, (0, _.explicitNull)()]), /*#__PURE__*/_react["default"].createElement("div", { a: false }), 'a'); assertPasses((0, _.or)([(0, _.explicitNull)(), _propTypes.bool.isRequired]), /*#__PURE__*/_react["default"].createElement("div", { a: false }), 'a'); assertPasses((0, _.or)([_propTypes.bool.isRequired, (0, _.explicitNull)()]), /*#__PURE__*/_react["default"].createElement("div", { a: null }), 'a'); assertPasses((0, _.or)([(0, _.explicitNull)(), _propTypes.bool.isRequired]), /*#__PURE__*/_react["default"].createElement("div", { a: null }), 'a'); assertPasses((0, _.or)([_propTypes.bool.isRequired, (0, _.explicitNull)()]), /*#__PURE__*/_react["default"].createElement("div", null), 'a'); assertPasses((0, _.or)([(0, _.explicitNull)(), _propTypes.bool.isRequired]), /*#__PURE__*/_react["default"].createElement("div", null), 'a'); assertPasses((0, _.or)([_propTypes.bool.isRequired, (0, _.explicitNull)()]), /*#__PURE__*/_react["default"].createElement("div", { a: undefined }), 'a'); assertPasses((0, _.or)([(0, _.explicitNull)(), _propTypes.bool.isRequired]), /*#__PURE__*/_react["default"].createElement("div", { a: undefined }), 'a'); }); it('works when outer is optional, inner is required', function () { assertPasses((0, _.or)([_propTypes.bool.isRequired, (0, _.explicitNull)().isRequired]), /*#__PURE__*/_react["default"].createElement("div", { a: true }), 'a'); assertPasses((0, _.or)([(0, _.explicitNull)().isRequired, _propTypes.bool.isRequired]), /*#__PURE__*/_react["default"].createElement("div", { a: true }), 'a'); assertPasses((0, _.or)([_propTypes.bool.isRequired, (0, _.explicitNull)().isRequired]), /*#__PURE__*/_react["default"].createElement("div", { a: false }), 'a'); assertPasses((0, _.or)([(0, _.explicitNull)().isRequired, _propTypes.bool.isRequired]), /*#__PURE__*/_react["default"].createElement("div", { a: false }), 'a'); assertPasses((0, _.or)([_propTypes.bool.isRequired, (0, _.explicitNull)().isRequired]), /*#__PURE__*/_react["default"].createElement("div", { a: null }), 'a'); assertPasses((0, _.or)([(0, _.explicitNull)().isRequired, _propTypes.bool.isRequired]), /*#__PURE__*/_react["default"].createElement("div", { a: null }), 'a'); assertPasses((0, _.or)([_propTypes.bool.isRequired, (0, _.explicitNull)().isRequired]), /*#__PURE__*/_react["default"].createElement("div", null), 'a'); assertPasses((0, _.or)([(0, _.explicitNull)().isRequired, _propTypes.bool.isRequired]), /*#__PURE__*/_react["default"].createElement("div", null), 'a'); assertPasses((0, _.or)([_propTypes.bool.isRequired, (0, _.explicitNull)().isRequired]), /*#__PURE__*/_react["default"].createElement("div", { a: undefined }), 'a'); assertPasses((0, _.or)([(0, _.explicitNull)().isRequired, _propTypes.bool.isRequired]), /*#__PURE__*/_react["default"].createElement("div", { a: undefined }), 'a'); }); it('works when outer is required, inner is optional', function () { assertPasses((0, _.or)([_propTypes.bool.isRequired, (0, _.explicitNull)()]).isRequired, /*#__PURE__*/_react["default"].createElement("div", { a: true }), 'a'); assertPasses((0, _.or)([(0, _.explicitNull)(), _propTypes.bool.isRequired]).isRequired, /*#__PURE__*/_react["default"].createElement("div", { a: true }), 'a'); assertPasses((0, _.or)([_propTypes.bool.isRequired, (0, _.explicitNull)()]).isRequired, /*#__PURE__*/_react["default"].createElement("div", { a: false }), 'a'); assertPasses((0, _.or)([(0, _.explicitNull)(), _propTypes.bool.isRequired]).isRequired, /*#__PURE__*/_react["default"].createElement("div", { a: false }), 'a'); assertPasses((0, _.or)([_propTypes.bool.isRequired, (0, _.explicitNull)()]).isRequired, /*#__PURE__*/_react["default"].createElement("div", { a: null }), 'a'); assertPasses((0, _.or)([(0, _.explicitNull)(), _propTypes.bool.isRequired]).isRequired, /*#__PURE__*/_react["default"].createElement("div", { a: null }), 'a'); assertFails((0, _.or)([_propTypes.bool.isRequired, (0, _.explicitNull)()]).isRequired, /*#__PURE__*/_react["default"].createElement("div", null), 'a'); assertFails((0, _.or)([(0, _.explicitNull)(), _propTypes.bool.isRequired]).isRequired, /*#__PURE__*/_react["default"].createElement("div", null), 'a'); assertFails((0, _.or)([_propTypes.bool.isRequired, (0, _.explicitNull)()]).isRequired, /*#__PURE__*/_react["default"].createElement("div", { a: undefined }), 'a'); assertFails((0, _.or)([(0, _.explicitNull)(), _propTypes.bool.isRequired]).isRequired, /*#__PURE__*/_react["default"].createElement("div", { a: undefined }), 'a'); }); it('works when outer is required, inner is required', function () { assertPasses((0, _.or)([_propTypes.bool.isRequired, (0, _.explicitNull)().isRequired]).isRequired, /*#__PURE__*/_react["default"].createElement("div", { a: true }), 'a'); assertPasses((0, _.or)([(0, _.explicitNull)().isRequired, _propTypes.bool.isRequired]).isRequired, /*#__PURE__*/_react["default"].createElement("div", { a: true }), 'a'); assertPasses((0, _.or)([_propTypes.bool.isRequired, (0, _.explicitNull)().isRequired]).isRequired, /*#__PURE__*/_react["default"].createElement("div", { a: false }), 'a'); assertPasses((0, _.or)([(0, _.explicitNull)().isRequired, _propTypes.bool.isRequired]).isRequired, /*#__PURE__*/_react["default"].createElement("div", { a: false }), 'a'); assertPasses((0, _.or)([_propTypes.bool.isRequired, (0, _.explicitNull)().isRequired]).isRequired, /*#__PURE__*/_react["default"].createElement("div", { a: null }), 'a'); assertPasses((0, _.or)([(0, _.explicitNull)().isRequired, _propTypes.bool.isRequired]).isRequired, /*#__PURE__*/_react["default"].createElement("div", { a: null }), 'a'); assertFails((0, _.or)([_propTypes.bool.isRequired, (0, _.explicitNull)().isRequired]).isRequired, /*#__PURE__*/_react["default"].createElement("div", null), 'a'); assertFails((0, _.or)([(0, _.explicitNull)().isRequired, _propTypes.bool.isRequired]).isRequired, /*#__PURE__*/_react["default"].createElement("div", null), 'a'); assertFails((0, _.or)([_propTypes.bool.isRequired, (0, _.explicitNull)().isRequired]).isRequired, /*#__PURE__*/_react["default"].createElement("div", { a: undefined }), 'a'); assertFails((0, _.or)([(0, _.explicitNull)().isRequired, _propTypes.bool.isRequired]).isRequired, /*#__PURE__*/_react["default"].createElement("div", { a: undefined }), 'a'); }); }); }); //# sourceMappingURL=or.js.map