Browse Source

Make the Shallow Rendering example clearer (#8269)

* Make the Shallow Rendering example clearer

I was reading through the documentation, and I found that the `render` call on the `renderer` was missing.

* Use a regular function to define MyComponent
main
Michele Bertoli 8 years ago
committed by Dan Abramov
parent
commit
82802a0da9
  1. 10
      docs/addons-test-utils.md

10
docs/addons-test-utils.md

@ -53,20 +53,26 @@ Call [`createRenderer()`](#createrenderer) in your tests to create a shallow ren
After `shallowRenderer.render()` has been called, you can use [`shallowRenderer.getRenderOutput()`](#shallowrenderer.getrenderoutput) to get the shallowly rendered output. After `shallowRenderer.render()` has been called, you can use [`shallowRenderer.getRenderOutput()`](#shallowrenderer.getrenderoutput) to get the shallowly rendered output.
You can then begin to assert facts about the output. For example, if your component's render method returns: You can then begin to assert facts about the output. For example, if you have the following component:
```javascript ```javascript
function MyComponent() {
return (
<div> <div>
<span className="heading">Title</span> <span className="heading">Title</span>
<Subcomponent foo="bar" /> <Subcomponent foo="bar" />
</div> </div>
);
}
``` ```
Then you can assert: Then you can assert:
```javascript ```javascript
const renderer = ReactTestUtils.createRenderer(); const renderer = ReactTestUtils.createRenderer();
result = renderer.getRenderOutput(); renderer.render(<MyComponent />);
const result = renderer.getRenderOutput();
expect(result.type).toBe('div'); expect(result.type).toBe('div');
expect(result.props.children).toEqual([ expect(result.props.children).toEqual([
<span className="heading">Title</span>, <span className="heading">Title</span>,

Loading…
Cancel
Save