2016-10-18 08:59:33 +08:00
|
|
|
/* eslint react/no-render-return-value: 0 */
|
2016-10-17 07:36:49 +08:00
|
|
|
import _ from 'underscore';
|
2017-09-27 02:33:08 +08:00
|
|
|
import ReactDOM from 'react-dom';
|
2017-06-25 16:24:25 +08:00
|
|
|
import ReactTestUtils from 'react-dom/test-utils';
|
2016-10-17 07:36:49 +08:00
|
|
|
|
|
|
|
export function scryRenderedComponentsWithTypeAndProps(root, type, props) {
|
2017-09-27 02:33:08 +08:00
|
|
|
if (!root) {
|
|
|
|
throw new Error('Must supply a root to scryRenderedComponentsWithTypeAndProps');
|
|
|
|
}
|
|
|
|
return _.compact(
|
|
|
|
_.map(ReactTestUtils.scryRenderedComponentsWithType(root, type), el => {
|
|
|
|
if (_.isEqual(_.pick(el.props, Object.keys(props)), props)) {
|
|
|
|
return el;
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
})
|
|
|
|
);
|
2016-10-17 07:36:49 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
let ReactElementContainers = [];
|
|
|
|
// Override ReactTestUtils.renderIntoDocument so that
|
|
|
|
// we can remove all the created elements after the test completes.
|
|
|
|
export function renderIntoDocument(element) {
|
|
|
|
const container = document.createElement('div');
|
|
|
|
ReactElementContainers.push(container);
|
|
|
|
return ReactDOM.render(element, container);
|
|
|
|
}
|
|
|
|
|
|
|
|
export function unmountAll() {
|
|
|
|
for (let i = 0; i < ReactElementContainers.length; i++) {
|
|
|
|
const container = ReactElementContainers[i];
|
|
|
|
ReactDOM.unmountComponentAtNode(container);
|
|
|
|
}
|
|
|
|
ReactElementContainers = [];
|
|
|
|
}
|