Skip to content

Commit

Permalink
Make setNodesInternal module-scoped; add basic ReactWrapper test
Browse files Browse the repository at this point in the history
  • Loading branch information
vsiao committed Jan 27, 2018
1 parent 0d20a78 commit eabb9b8
Show file tree
Hide file tree
Showing 3 changed files with 41 additions and 28 deletions.
12 changes: 12 additions & 0 deletions packages/enzyme-test-suite/test/ReactWrapper-spec.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -3117,6 +3117,18 @@ describeWithDOM('mount', () => {
expect(rendered.html()).to.equal(null);
});

itIf(REACT16, 'works with class components that return arrays', () => {
class Foo extends React.Component {
render() {
return [<div />, <div />];
}
}
const wrapper = mount(<Foo />);
expect(wrapper).to.have.length(1);
expect(wrapper.type()).to.equal(Foo);
expect(wrapper.find('div')).to.have.length(2);
});

itIf(is('>=15 || ^16.0.0-alpha'), 'works with SFCs that return null', () => {
const Foo = () => null;

Expand Down
31 changes: 16 additions & 15 deletions packages/enzyme/src/ReactWrapper.js
Original file line number Diff line number Diff line change
Expand Up @@ -63,6 +63,20 @@ function filterWhereUnwrapped(wrapper, predicate) {
return wrapper.wrap(compact(wrapper.getNodesInternal().filter(predicate)));
}

function privateSetNodes(wrapper, nodes) {
if (!nodes) {
privateSet(wrapper, NODE, null);
privateSet(wrapper, NODES, []);
} else if (!Array.isArray(nodes)) {
privateSet(wrapper, NODE, nodes);
privateSet(wrapper, NODES, [nodes]);
} else {
privateSet(wrapper, NODE, nodes[0]);
privateSet(wrapper, NODES, nodes);
}
wrapper.length = wrapper[NODES].length;
}

/**
* @class ReactWrapper
*/
Expand All @@ -79,25 +93,12 @@ class ReactWrapper {
privateSet(this, RENDERER, renderer);
renderer.render(nodes, options.context);
privateSet(this, ROOT, this);
const node = this[RENDERER].getNode();
privateSet(this, NODE, node);
privateSet(this, NODES, [node]);
this.length = 1;
privateSetNodes(this, this[RENDERER].getNode());
} else {
privateSet(this, UNRENDERED, null);
privateSet(this, RENDERER, root[RENDERER]);
privateSet(this, ROOT, root);
if (!nodes) {
privateSet(this, NODE, null);
privateSet(this, NODES, []);
} else if (!Array.isArray(nodes)) {
privateSet(this, NODE, nodes);
privateSet(this, NODES, [nodes]);
} else {
privateSet(this, NODE, nodes[0]);
privateSet(this, NODES, nodes);
}
this.length = this[NODES].length;
privateSetNodes(this, nodes);
}
privateSet(this, OPTIONS, root ? root[OPTIONS] : options);
}
Expand Down
26 changes: 13 additions & 13 deletions packages/enzyme/src/ShallowWrapper.js
Original file line number Diff line number Diff line change
Expand Up @@ -99,6 +99,17 @@ function getRootNode(node) {
return node.rendered;
}

function privateSetNodes(wrapper, nodes) {
if (!Array.isArray(nodes)) {
privateSet(wrapper, NODE, nodes);
privateSet(wrapper, NODES, [nodes]);
} else {
privateSet(wrapper, NODE, nodes[0]);
privateSet(wrapper, NODES, nodes);
}
wrapper.length = wrapper[NODES].length;
}

/**
* @class ShallowWrapper
*/
Expand All @@ -122,27 +133,16 @@ class ShallowWrapper {
instance.componentDidMount();
});
}
this.setNodesInternal(getRootNode(this[RENDERER].getNode()));
privateSetNodes(this, getRootNode(this[RENDERER].getNode()));
} else {
privateSet(this, ROOT, root);
privateSet(this, UNRENDERED, null);
privateSet(this, RENDERER, root[RENDERER]);
this.setNodesInternal(nodes);
privateSetNodes(this, nodes);
}
privateSet(this, OPTIONS, root ? root[OPTIONS] : options);
}

setNodesInternal(nodes) {
if (!Array.isArray(nodes)) {
privateSet(this, NODE, nodes);
privateSet(this, NODES, [nodes]);
} else {
privateSet(this, NODE, nodes[0]);
privateSet(this, NODES, nodes);
}
this.length = this[NODES].length;
}

/**
* Returns the root wrapper
*
Expand Down

0 comments on commit eabb9b8

Please sign in to comment.