react-palm
Version:
Elm-like architecture for React apps
1,106 lines (906 loc) • 37.2 kB
JavaScript
"use strict";
var _react = _interopRequireDefault(require("react"));
var _reactDom = _interopRequireDefault(require("../react-dom"));
var _server = _interopRequireDefault(require("../react-dom/server"));
var _shallow = _interopRequireDefault(require("react-test-renderer/shallow"));
var _package = require("react-test-renderer/package.json");
var _testUtils = _interopRequireDefault(require("../react-dom/test-utils"));
var _semver = _interopRequireDefault(require("semver"));
var _checkPropTypes2 = _interopRequireDefault(require("prop-types/checkPropTypes"));
var _has = _interopRequireDefault(require("has"));
var _reactIs = require("react-is");
var _enzyme = require("enzyme");
var _Utils = require("enzyme/build/Utils");
var _enzymeShallowEqual = _interopRequireDefault(require("enzyme-shallow-equal"));
var _enzymeAdapterUtils = require("enzyme-adapter-utils");
var _findCurrentFiberUsingSlowPath = _interopRequireDefault(require("./findCurrentFiberUsingSlowPath"));
var _detectFiberTags = _interopRequireDefault(require("./detectFiberTags"));
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _typeof(obj) { 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); }
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); }
function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }
function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; var ownKeys = Object.keys(source); if (typeof Object.getOwnPropertySymbols === 'function') { ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function (sym) { return Object.getOwnPropertyDescriptor(source, sym).enumerable; })); } ownKeys.forEach(function (key) { _defineProperty(target, key, source[key]); }); } return target; }
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
var is164 = !!_testUtils.default.Simulate.touchStart; // 16.4+
var is165 = !!_testUtils.default.Simulate.auxClick; // 16.5+
var is166 = is165 && !_react.default.unstable_AsyncMode; // 16.6+
var is168 = is166 && typeof _testUtils.default.act === 'function';
var hasShouldComponentUpdateBug = _semver.default.satisfies(_package.version, '< 16.8'); // Lazily populated if DOM is available.
var FiberTags = null;
function nodeAndSiblingsArray(nodeWithSibling) {
var array = [];
var node = nodeWithSibling;
while (node != null) {
array.push(node);
node = node.sibling;
}
return array;
}
function flatten(arr) {
var result = [];
var stack = [{
i: 0,
array: arr
}];
while (stack.length) {
var n = stack.pop();
while (n.i < n.array.length) {
var el = n.array[n.i];
n.i += 1;
if (Array.isArray(el)) {
stack.push(n);
stack.push({
i: 0,
array: el
});
break;
}
result.push(el);
}
}
return result;
}
function nodeTypeFromType(type) {
if (type === _reactIs.Portal) {
return 'portal';
}
return (0, _enzymeAdapterUtils.nodeTypeFromType)(type);
}
function isMemo(type) {
return (0, _enzymeAdapterUtils.compareNodeTypeOf)(type, _reactIs.Memo);
}
function isLazy(type) {
return (0, _enzymeAdapterUtils.compareNodeTypeOf)(type, _reactIs.Lazy);
}
function unmemoType(type) {
return isMemo(type) ? type.type : type;
}
function elementToTree(el) {
if (!(0, _reactIs.isPortal)(el)) {
return (0, _enzymeAdapterUtils.elementToTree)(el, elementToTree);
}
var children = el.children,
containerInfo = el.containerInfo;
var props = {
children: children,
containerInfo: containerInfo
};
return {
nodeType: 'portal',
type: _reactIs.Portal,
props: props,
key: (0, _enzymeAdapterUtils.ensureKeyOrUndefined)(el.key),
ref: el.ref || null,
instance: null,
rendered: elementToTree(el.children)
};
}
function _toTree(vnode) {
if (vnode == null) {
return null;
} // TODO(lmr): I'm not really sure I understand whether or not this is what
// i should be doing, or if this is a hack for something i'm doing wrong
// somewhere else. Should talk to sebastian about this perhaps
var node = (0, _findCurrentFiberUsingSlowPath.default)(vnode);
switch (node.tag) {
case FiberTags.HostRoot:
return childrenToTree(node.child);
case FiberTags.HostPortal:
{
var containerInfo = node.stateNode.containerInfo,
children = node.memoizedProps;
var props = {
containerInfo: containerInfo,
children: children
};
return {
nodeType: 'portal',
type: _reactIs.Portal,
props: props,
key: (0, _enzymeAdapterUtils.ensureKeyOrUndefined)(node.key),
ref: node.ref,
instance: null,
rendered: childrenToTree(node.child)
};
}
case FiberTags.ClassComponent:
return {
nodeType: 'class',
type: node.type,
props: _objectSpread({}, node.memoizedProps),
key: (0, _enzymeAdapterUtils.ensureKeyOrUndefined)(node.key),
ref: node.ref,
instance: node.stateNode,
rendered: childrenToTree(node.child)
};
case FiberTags.FunctionalComponent:
return {
nodeType: 'function',
type: node.type,
props: _objectSpread({}, node.memoizedProps),
key: (0, _enzymeAdapterUtils.ensureKeyOrUndefined)(node.key),
ref: node.ref,
instance: null,
rendered: childrenToTree(node.child)
};
case FiberTags.MemoClass:
return {
nodeType: 'class',
type: node.elementType.type,
props: _objectSpread({}, node.memoizedProps),
key: (0, _enzymeAdapterUtils.ensureKeyOrUndefined)(node.key),
ref: node.ref,
instance: node.stateNode,
rendered: childrenToTree(node.child.child)
};
case FiberTags.MemoSFC:
{
var renderedNodes = flatten(nodeAndSiblingsArray(node.child).map(_toTree));
if (renderedNodes.length === 0) {
renderedNodes = [node.memoizedProps.children];
}
return {
nodeType: 'function',
type: node.elementType,
props: _objectSpread({}, node.memoizedProps),
key: (0, _enzymeAdapterUtils.ensureKeyOrUndefined)(node.key),
ref: node.ref,
instance: null,
rendered: renderedNodes
};
}
case FiberTags.HostComponent:
{
var _renderedNodes = flatten(nodeAndSiblingsArray(node.child).map(_toTree));
if (_renderedNodes.length === 0) {
_renderedNodes = [node.memoizedProps.children];
}
return {
nodeType: 'host',
type: node.type,
props: _objectSpread({}, node.memoizedProps),
key: (0, _enzymeAdapterUtils.ensureKeyOrUndefined)(node.key),
ref: node.ref,
instance: node.stateNode,
rendered: _renderedNodes
};
}
case FiberTags.HostText:
return node.memoizedProps;
case FiberTags.Fragment:
case FiberTags.Mode:
case FiberTags.ContextProvider:
case FiberTags.ContextConsumer:
return childrenToTree(node.child);
case FiberTags.Profiler:
case FiberTags.ForwardRef:
{
return {
nodeType: 'function',
type: node.type,
props: _objectSpread({}, node.pendingProps),
key: (0, _enzymeAdapterUtils.ensureKeyOrUndefined)(node.key),
ref: node.ref,
instance: null,
rendered: childrenToTree(node.child)
};
}
case FiberTags.Suspense:
{
return {
nodeType: 'function',
type: _reactIs.Suspense,
props: _objectSpread({}, node.memoizedProps),
key: (0, _enzymeAdapterUtils.ensureKeyOrUndefined)(node.key),
ref: node.ref,
instance: null,
rendered: childrenToTree(node.child)
};
}
case FiberTags.Lazy:
return childrenToTree(node.child);
default:
throw new Error("Enzyme Internal Error: unknown node with tag ".concat(node.tag));
}
}
function childrenToTree(node) {
if (!node) {
return null;
}
var children = nodeAndSiblingsArray(node);
if (children.length === 0) {
return null;
}
if (children.length === 1) {
return _toTree(children[0]);
}
return flatten(children.map(_toTree));
}
function _nodeToHostNode(_node) {
// NOTE(lmr): node could be a function component
// which wont have an instance prop, but we can get the
// host node associated with its return value at that point.
// Although this breaks down if the return value is an array,
// as is possible with React 16.
var node = _node;
while (node && !Array.isArray(node) && node.instance === null) {
node = node.rendered;
} // if the SFC returned null effectively, there is no host node.
if (!node) {
return null;
}
var mapper = function mapper(item) {
if (item && item.instance) return _reactDom.default.findDOMNode(item.instance);
return null;
};
if (Array.isArray(node)) {
return node.map(mapper);
}
if (Array.isArray(node.rendered) && node.nodeType === 'class') {
return node.rendered.map(mapper);
}
return mapper(node);
}
function replaceLazyWithFallback(node, fallback) {
if (!node) {
return null;
}
if (Array.isArray(node)) {
return node.map(function (el) {
return replaceLazyWithFallback(el, fallback);
});
}
if (isLazy(node.type)) {
return fallback;
}
return _objectSpread({}, node, {
props: _objectSpread({}, node.props, {
children: replaceLazyWithFallback(node.props.children, fallback)
})
});
}
var eventOptions = {
animation: true,
pointerEvents: is164,
auxClick: is165
};
function getEmptyStateValue() {
// this handles a bug in React 16.0 - 16.2
// see https://github.com/facebook/react/commit/39be83565c65f9c522150e52375167568a2a1459
// also see https://github.com/facebook/react/pull/11965
// eslint-disable-next-line react/prefer-stateless-function
var EmptyState =
/*#__PURE__*/
function (_React$Component) {
_inherits(EmptyState, _React$Component);
function EmptyState() {
_classCallCheck(this, EmptyState);
return _possibleConstructorReturn(this, _getPrototypeOf(EmptyState).apply(this, arguments));
}
_createClass(EmptyState, [{
key: "render",
value: function render() {
return null;
}
}]);
return EmptyState;
}(_react.default.Component);
var testRenderer = new _shallow.default();
testRenderer.render(_react.default.createElement(EmptyState));
return testRenderer._instance.state;
}
function wrapAct(fn) {
if (!is168) {
return fn();
}
var returnVal;
_testUtils.default.act(function () {
returnVal = fn();
});
return returnVal;
}
function getProviderDefaultValue(Provider) {
// React stores references to the Provider's defaultValue differently across versions.
if ('_defaultValue' in Provider._context) {
return Provider._context._defaultValue;
}
if ('_currentValue' in Provider._context) {
return Provider._context._currentValue;
}
throw new Error('Enzyme Internal Error: can’t figure out how to get Provider’s default value');
}
function makeFakeElement(type) {
return {
$$typeof: _reactIs.Element,
type: type
};
}
function isStateful(Component) {
return Component.prototype && (Component.prototype.isReactComponent || Array.isArray(Component.__reactAutoBindPairs) // fallback for createClass components
);
}
var ReactSixteenAdapter =
/*#__PURE__*/
function (_EnzymeAdapter) {
_inherits(ReactSixteenAdapter, _EnzymeAdapter);
function ReactSixteenAdapter() {
var _this;
_classCallCheck(this, ReactSixteenAdapter);
_this = _possibleConstructorReturn(this, _getPrototypeOf(ReactSixteenAdapter).call(this));
var lifecycles = _this.options.lifecycles;
_this.options = _objectSpread({}, _this.options, {
enableComponentDidUpdateOnSetState: true,
// TODO: remove, semver-major
legacyContextMode: 'parent',
lifecycles: _objectSpread({}, lifecycles, {
componentDidUpdate: {
onSetState: true
},
getDerivedStateFromProps: {
hasShouldComponentUpdateBug: hasShouldComponentUpdateBug
},
getSnapshotBeforeUpdate: true,
setState: {
skipsComponentDidUpdateOnNullish: true
},
getChildContext: {
calledByRenderer: false
},
getDerivedStateFromError: is166
})
});
return _this;
}
_createClass(ReactSixteenAdapter, [{
key: "createMountRenderer",
value: function createMountRenderer(options) {
(0, _enzymeAdapterUtils.assertDomAvailable)('mount');
if ((0, _has.default)(options, 'suspenseFallback')) {
throw new TypeError('`suspenseFallback` is not supported by the `mount` renderer');
}
if (FiberTags === null) {
// Requires DOM.
FiberTags = (0, _detectFiberTags.default)();
}
var attachTo = options.attachTo,
hydrateIn = options.hydrateIn,
wrappingComponentProps = options.wrappingComponentProps;
var domNode = hydrateIn || attachTo || global.document.createElement('div');
var instance = null;
var adapter = this;
return _objectSpread({
render: function render(el, context, callback) {
return wrapAct(function () {
if (instance === null) {
var type = el.type,
props = el.props,
ref = el.ref;
var wrapperProps = _objectSpread({
Component: type,
props: props,
wrappingComponentProps: wrappingComponentProps,
context: context
}, ref && {
refProp: ref
});
var ReactWrapperComponent = (0, _enzymeAdapterUtils.createMountWrapper)(el, _objectSpread({}, options, {
adapter: adapter
}));
var wrappedEl = _react.default.createElement(ReactWrapperComponent, wrapperProps);
instance = hydrateIn ? _reactDom.default.hydrate(wrappedEl, domNode) : _reactDom.default.render(wrappedEl, domNode);
if (typeof callback === 'function') {
callback();
}
} else {
instance.setChildProps(el.props, context, callback);
}
});
},
unmount: function unmount() {
_reactDom.default.unmountComponentAtNode(domNode);
instance = null;
},
getNode: function getNode() {
if (!instance) {
return null;
}
return (0, _enzymeAdapterUtils.getNodeFromRootFinder)(adapter.isCustomComponent, _toTree(instance._reactInternalFiber), options);
},
simulateError: function simulateError(nodeHierarchy, rootNode, error) {
var isErrorBoundary = function isErrorBoundary(_ref) {
var elInstance = _ref.instance,
type = _ref.type;
if (is166 && type && type.getDerivedStateFromError) {
return true;
}
return elInstance && elInstance.componentDidCatch;
};
var _ref2 = nodeHierarchy.find(isErrorBoundary) || {},
catchingInstance = _ref2.instance,
catchingType = _ref2.type;
(0, _enzymeAdapterUtils.simulateError)(error, catchingInstance, rootNode, nodeHierarchy, nodeTypeFromType, adapter.displayNameOfNode, is166 ? catchingType : undefined);
},
simulateEvent: function simulateEvent(node, event, mock) {
var mappedEvent = (0, _enzymeAdapterUtils.mapNativeEventNames)(event, eventOptions);
var eventFn = _testUtils.default.Simulate[mappedEvent];
if (!eventFn) {
throw new TypeError("ReactWrapper::simulate() event '".concat(event, "' does not exist"));
}
wrapAct(function () {
eventFn(adapter.nodeToHostNode(node), mock);
});
},
batchedUpdates: function batchedUpdates(fn) {
return fn(); // return ReactDOM.unstable_batchedUpdates(fn);
},
getWrappingComponentRenderer: function getWrappingComponentRenderer() {
return _objectSpread({}, this, (0, _enzymeAdapterUtils.getWrappingComponentMountRenderer)({
toTree: function toTree(inst) {
return _toTree(inst._reactInternalFiber);
},
getMountWrapperInstance: function getMountWrapperInstance() {
return instance;
}
}));
}
}, is168 && {
wrapInvoke: wrapAct
});
}
}, {
key: "createShallowRenderer",
value: function createShallowRenderer() {
var _this2 = this;
var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
var adapter = this;
var renderer = new _shallow.default();
var suspenseFallback = options.suspenseFallback;
if (typeof suspenseFallback !== 'undefined' && typeof suspenseFallback !== 'boolean') {
throw TypeError('`options.suspenseFallback` should be boolean or undefined');
}
var isDOM = false;
var cachedNode = null;
var lastComponent = null;
var wrappedComponent = null;
var sentinel = {}; // wrap memo components with a PureComponent, or a class component with sCU
var wrapPureComponent = function wrapPureComponent(Component, compare) {
if (!is166) {
throw new RangeError('this function should not be called in React < 16.6. Please report this!');
}
if (lastComponent !== Component) {
if (isStateful(Component)) {
wrappedComponent =
/*#__PURE__*/
function (_Component) {
_inherits(wrappedComponent, _Component);
function wrappedComponent() {
_classCallCheck(this, wrappedComponent);
return _possibleConstructorReturn(this, _getPrototypeOf(wrappedComponent).apply(this, arguments));
}
return wrappedComponent;
}(Component); // eslint-disable-line react/prefer-stateless-function
if (compare) {
wrappedComponent.prototype.shouldComponentUpdate = function (nextProps) {
return !compare(_this2.props, nextProps);
};
} else {
wrappedComponent.prototype.isPureReactComponent = true;
}
} else {
var memoized = sentinel;
var prevProps;
wrappedComponent = function wrappedComponent(props) {
var shouldUpdate = memoized === sentinel || (compare ? !compare(prevProps, props) : !(0, _enzymeShallowEqual.default)(prevProps, props));
if (shouldUpdate) {
for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {
args[_key - 1] = arguments[_key];
}
memoized = Component.apply(void 0, [_objectSpread({}, Component.defaultProps, props)].concat(args));
prevProps = props;
}
return memoized;
};
}
Object.assign(wrappedComponent, Component, {
displayName: adapter.displayNameOfNode({
type: Component
})
});
lastComponent = Component;
}
return wrappedComponent;
}; // Wrap functional components on versions prior to 16.5,
// to avoid inadvertently pass a `this` instance to it.
var wrapFunctionalComponent = function wrapFunctionalComponent(Component) {
if (is166 && (0, _has.default)(Component, 'defaultProps')) {
if (lastComponent !== Component) {
wrappedComponent = Object.assign( // eslint-disable-next-line new-cap
function (props) {
for (var _len2 = arguments.length, args = new Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++) {
args[_key2 - 1] = arguments[_key2];
}
return Component.apply(void 0, [_objectSpread({}, Component.defaultProps, props)].concat(args));
}, Component, {
displayName: adapter.displayNameOfNode({
type: Component
})
});
lastComponent = Component;
}
return wrappedComponent;
}
if (is165) {
return Component;
}
if (lastComponent !== Component) {
wrappedComponent = Object.assign(function () {
return Component.apply(void 0, arguments);
}, // eslint-disable-line new-cap
Component);
lastComponent = Component;
}
return wrappedComponent;
};
return {
render: function render(el, unmaskedContext) {
var _ref3 = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {},
_ref3$providerValues = _ref3.providerValues,
providerValues = _ref3$providerValues === void 0 ? new Map() : _ref3$providerValues;
cachedNode = el;
/* eslint consistent-return: 0 */
if (typeof el.type === 'string') {
isDOM = true;
} else if ((0, _reactIs.isContextProvider)(el)) {
providerValues.set(el.type, el.props.value);
var MockProvider = Object.assign(function (props) {
return props.children;
}, el.type);
return (0, _enzymeAdapterUtils.withSetStateAllowed)(function () {
return renderer.render(_objectSpread({}, el, {
type: MockProvider
}));
});
} else if ((0, _reactIs.isContextConsumer)(el)) {
var Provider = adapter.getProviderFromConsumer(el.type);
var value = providerValues.has(Provider) ? providerValues.get(Provider) : getProviderDefaultValue(Provider);
var MockConsumer = Object.assign(function (props) {
return props.children(value);
}, el.type);
return (0, _enzymeAdapterUtils.withSetStateAllowed)(function () {
return renderer.render(_objectSpread({}, el, {
type: MockConsumer
}));
});
} else {
isDOM = false;
var renderedEl = el;
if (isLazy(renderedEl)) {
throw TypeError('`React.lazy` is not supported by shallow rendering.');
}
if ((0, _reactIs.isSuspense)(renderedEl)) {
var children = renderedEl.props.children;
if (suspenseFallback) {
var fallback = renderedEl.props.fallback;
children = replaceLazyWithFallback(children, fallback);
}
var FakeSuspenseWrapper = function FakeSuspenseWrapper() {
return children;
};
renderedEl = _react.default.createElement(FakeSuspenseWrapper, null, children);
}
var _renderedEl = renderedEl,
Component = _renderedEl.type;
var context = (0, _enzymeAdapterUtils.getMaskedContext)(Component.contextTypes, unmaskedContext);
if (isMemo(el.type)) {
var _el$type = el.type,
InnerComp = _el$type.type,
compare = _el$type.compare;
return (0, _enzymeAdapterUtils.withSetStateAllowed)(function () {
return renderer.render(_objectSpread({}, el, {
type: wrapPureComponent(InnerComp, compare)
}), context);
});
}
if (!isStateful(Component) && typeof Component === 'function') {
return (0, _enzymeAdapterUtils.withSetStateAllowed)(function () {
return renderer.render(_objectSpread({}, renderedEl, {
type: wrapFunctionalComponent(Component)
}), context);
});
}
if (isStateful) {
// fix react bug; see implementation of `getEmptyStateValue`
var emptyStateValue = getEmptyStateValue();
if (emptyStateValue) {
Object.defineProperty(Component.prototype, 'state', {
configurable: true,
enumerable: true,
get: function get() {
return null;
},
set: function set(value) {
if (value !== emptyStateValue) {
Object.defineProperty(this, 'state', {
configurable: true,
enumerable: true,
value: value,
writable: true
});
}
return true;
}
});
}
}
return (0, _enzymeAdapterUtils.withSetStateAllowed)(function () {
return renderer.render(renderedEl, context);
});
}
},
unmount: function unmount() {
renderer.unmount();
},
getNode: function getNode() {
if (isDOM) {
return elementToTree(cachedNode);
}
var output = renderer.getRenderOutput();
return {
nodeType: nodeTypeFromType(cachedNode.type),
type: cachedNode.type,
props: cachedNode.props,
key: (0, _enzymeAdapterUtils.ensureKeyOrUndefined)(cachedNode.key),
ref: cachedNode.ref,
instance: renderer._instance,
rendered: Array.isArray(output) ? flatten(output).map(function (el) {
return elementToTree(el);
}) : elementToTree(output)
};
},
simulateError: function simulateError(nodeHierarchy, rootNode, error) {
(0, _enzymeAdapterUtils.simulateError)(error, renderer._instance, cachedNode, nodeHierarchy.concat(cachedNode), nodeTypeFromType, adapter.displayNameOfNode, is166 ? cachedNode.type : undefined);
},
simulateEvent: function simulateEvent(node, event) {
for (var _len3 = arguments.length, args = new Array(_len3 > 2 ? _len3 - 2 : 0), _key3 = 2; _key3 < _len3; _key3++) {
args[_key3 - 2] = arguments[_key3];
}
var handler = node.props[(0, _enzymeAdapterUtils.propFromEvent)(event, eventOptions)];
if (handler) {
(0, _enzymeAdapterUtils.withSetStateAllowed)(function () {
// TODO(lmr): create/use synthetic events
// TODO(lmr): emulate React's event propagation
// ReactDOM.unstable_batchedUpdates(() => {
handler.apply(void 0, args); // });
});
}
},
batchedUpdates: function batchedUpdates(fn) {
return fn(); // return ReactDOM.unstable_batchedUpdates(fn);
},
checkPropTypes: function checkPropTypes(typeSpecs, values, location, hierarchy) {
return (0, _checkPropTypes2.default)(typeSpecs, values, location, (0, _enzymeAdapterUtils.displayNameOfNode)(cachedNode), function () {
return (0, _enzymeAdapterUtils.getComponentStack)(hierarchy.concat([cachedNode]));
});
}
};
}
}, {
key: "createStringRenderer",
value: function createStringRenderer(options) {
if ((0, _has.default)(options, 'suspenseFallback')) {
throw new TypeError('`suspenseFallback` should not be specified in options of string renderer');
}
return {
render: function render(el, context) {
if (options.context && (el.type.contextTypes || options.childContextTypes)) {
var childContextTypes = _objectSpread({}, el.type.contextTypes || {}, options.childContextTypes);
var ContextWrapper = (0, _enzymeAdapterUtils.createRenderWrapper)(el, context, childContextTypes);
return _server.default.renderToStaticMarkup(_react.default.createElement(ContextWrapper));
}
return _server.default.renderToStaticMarkup(el);
}
};
} // Provided a bag of options, return an `EnzymeRenderer`. Some options can be implementation
// specific, like `attach` etc. for React, but not part of this interface explicitly.
// eslint-disable-next-line class-methods-use-this
}, {
key: "createRenderer",
value: function createRenderer(options) {
switch (options.mode) {
case _enzyme.EnzymeAdapter.MODES.MOUNT:
return this.createMountRenderer(options);
case _enzyme.EnzymeAdapter.MODES.SHALLOW:
return this.createShallowRenderer(options);
case _enzyme.EnzymeAdapter.MODES.STRING:
return this.createStringRenderer(options);
default:
throw new Error("Enzyme Internal Error: Unrecognized mode: ".concat(options.mode));
}
}
}, {
key: "wrap",
value: function wrap(element) {
return (0, _enzymeAdapterUtils.wrap)(element);
} // converts an RSTNode to the corresponding JSX Pragma Element. This will be needed
// in order to implement the `Wrapper.mount()` and `Wrapper.shallow()` methods, but should
// be pretty straightforward for people to implement.
// eslint-disable-next-line class-methods-use-this
}, {
key: "nodeToElement",
value: function nodeToElement(node) {
if (!node || _typeof(node) !== 'object') return null;
var type = node.type;
return _react.default.createElement(unmemoType(type), (0, _enzymeAdapterUtils.propsWithKeysAndRef)(node));
} // eslint-disable-next-line class-methods-use-this
}, {
key: "matchesElementType",
value: function matchesElementType(node, matchingType) {
if (!node) {
return node;
}
var type = node.type;
return unmemoType(type) === unmemoType(matchingType);
}
}, {
key: "elementToNode",
value: function elementToNode(element) {
return elementToTree(element);
}
}, {
key: "nodeToHostNode",
value: function nodeToHostNode(node) {
var supportsArray = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
var nodes = _nodeToHostNode(node);
if (Array.isArray(nodes) && !supportsArray) {
return nodes[0];
}
return nodes;
}
}, {
key: "displayNameOfNode",
value: function displayNameOfNode(node) {
if (!node) return null;
var type = node.type,
$$typeof = node.$$typeof;
var nodeType = type || $$typeof; // newer node types may be undefined, so only test if the nodeType exists
if (nodeType) {
switch (nodeType) {
case (is166 ? _reactIs.ConcurrentMode : _reactIs.AsyncMode) || NaN:
return is166 ? 'ConcurrentMode' : 'AsyncMode';
case _reactIs.Fragment || NaN:
return 'Fragment';
case _reactIs.StrictMode || NaN:
return 'StrictMode';
case _reactIs.Profiler || NaN:
return 'Profiler';
case _reactIs.Portal || NaN:
return 'Portal';
case _reactIs.Suspense || NaN:
return 'Suspense';
default:
}
}
var $$typeofType = type && type.$$typeof;
switch ($$typeofType) {
case _reactIs.ContextConsumer || NaN:
return 'ContextConsumer';
case _reactIs.ContextProvider || NaN:
return 'ContextProvider';
case _reactIs.Memo || NaN:
{
var nodeName = (0, _enzymeAdapterUtils.displayNameOfNode)(node);
return typeof nodeName === 'string' ? nodeName : "Memo(".concat((0, _enzymeAdapterUtils.displayNameOfNode)(type), ")");
}
case _reactIs.ForwardRef || NaN:
{
if (type.displayName) {
return type.displayName;
}
var name = (0, _enzymeAdapterUtils.displayNameOfNode)({
type: type.render
});
return name ? "ForwardRef(".concat(name, ")") : 'ForwardRef';
}
case _reactIs.Lazy || NaN:
{
return 'lazy';
}
default:
return (0, _enzymeAdapterUtils.displayNameOfNode)(node);
}
}
}, {
key: "isValidElement",
value: function isValidElement(element) {
return (0, _reactIs.isElement)(element);
}
}, {
key: "isValidElementType",
value: function isValidElementType(object) {
return !!object && (0, _reactIs.isValidElementType)(object);
}
}, {
key: "isFragment",
value: function isFragment(fragment) {
return (0, _Utils.typeOfNode)(fragment) === _reactIs.Fragment;
}
}, {
key: "isCustomComponent",
value: function isCustomComponent(type) {
var fakeElement = makeFakeElement(type);
return !!type && (typeof type === 'function' || (0, _reactIs.isForwardRef)(fakeElement) || (0, _reactIs.isContextProvider)(fakeElement) || (0, _reactIs.isContextConsumer)(fakeElement) || (0, _reactIs.isSuspense)(fakeElement));
}
}, {
key: "isContextConsumer",
value: function isContextConsumer(type) {
return !!type && (0, _reactIs.isContextConsumer)(makeFakeElement(type));
}
}, {
key: "isCustomComponentElement",
value: function isCustomComponentElement(inst) {
if (!inst || !this.isValidElement(inst)) {
return false;
}
return this.isCustomComponent(inst.type);
}
}, {
key: "getProviderFromConsumer",
value: function getProviderFromConsumer(Consumer) {
// React stores references to the Provider on a Consumer differently across versions.
if (Consumer) {
var Provider;
if (Consumer._context) {
// check this first, to avoid a deprecation warning
Provider = Consumer._context.Provider;
} else if (Consumer.Provider) {
Provider = Consumer.Provider;
}
if (Provider) {
return Provider;
}
}
throw new Error('Enzyme Internal Error: can’t figure out how to get Provider from Consumer');
}
}, {
key: "createElement",
value: function createElement() {
return _react.default.createElement.apply(_react.default, arguments);
}
}, {
key: "wrapWithWrappingComponent",
value: function wrapWithWrappingComponent(node, options) {
return {
RootFinder: _enzymeAdapterUtils.RootFinder,
node: (0, _enzymeAdapterUtils.wrapWithWrappingComponent)(_react.default.createElement, node, options)
};
}
}]);
return ReactSixteenAdapter;
}(_enzyme.EnzymeAdapter);
module.exports = ReactSixteenAdapter;