Skip to content

Commit

Permalink
setState returning null and undefined is no-op on the ShallowRenderer…
Browse files Browse the repository at this point in the history
… (#12756)
  • Loading branch information
koba04 authored and aweary committed May 8, 2018
1 parent 76cdd65 commit 7127e87
Show file tree
Hide file tree
Showing 2 changed files with 33 additions and 0 deletions.
5 changes: 5 additions & 0 deletions src/ReactShallowRenderer.js
Original file line number Diff line number Diff line change
Expand Up @@ -301,6 +301,11 @@ class Updater {
partialState = partialState(currentState, publicInstance.props);
}

// Null and undefined are treated as no-ops.
if (partialState === null || partialState === undefined) {
return;
}

this._renderer._newState = {
...currentState,
...partialState,
Expand Down
28 changes: 28 additions & 0 deletions src/__tests__/ReactShallowRenderer-test.js
Original file line number Diff line number Diff line change
Expand Up @@ -1305,4 +1305,32 @@ describe('ReactShallowRenderer', () => {
'UNSAFE_componentWillUpdate',
]);
});

it('should stop the upade when setState returns null or undefined', () => {
const log = [];
let instance;
class Component extends React.Component {
constructor(props) {
super(props);
this.state = {
count: 0,
};
}
render() {
log.push('render');
instance = this;
return null;
}
}
const shallowRenderer = createRenderer();
shallowRenderer.render(<Component />);
log.length = 0;
instance.setState(() => null);
instance.setState(() => undefined);
instance.setState(null);
instance.setState(undefined);
expect(log).toEqual([]);
instance.setState(state => ({count: state.count + 1}));
expect(log).toEqual(['render']);
});
});

0 comments on commit 7127e87

Please sign in to comment.