9 [Enzyme](http://airbnb.io/enzyme) lets you write unit tests for React components. This guide covers Enzyme 2.x.
19 import {shallow, mount} from 'enzyme'
24 wrap = shallow(<MyComponent />)
28 wrap = mount(<MyComponent />)
31 Shallow wrapping doesn't descend down to sub-components.
32 A full mount also mounts sub-components.
33 See: [Shallow rendering](http://airbnb.io/enzyme/docs/api/shallow.html),
34 [Full rendering](http://airbnb.io/enzyme/docs/api/mount.html)
39 import toJson from 'enzyme-to-json'
45 wrap = mount(<MyComponent />)
46 expect(toJson(wrap)).toMatchSnapshot()
50 Converts an Enzyme wrapper to a format compatible with Jest snapshots. See: [enzyme-to-json](https://www.npmjs.com/package/enzyme-to-json)
55 console.log(wrap.debug())
58 Shows HTML for debugging purposes. See: [debug()](http://airbnb.io/enzyme/docs/api/ReactWrapper/debug.html)
65 wrap.find('button') // => ReactWrapper
66 wrap.filter('button') // => ReactWrapper
67 wrap.not('span') // => ReactWrapper (inverse of filter())
68 wrap.children() // => ReactWrapper
69 wrap.parent() // => ReactWrapper
70 wrap.closest('div') // => ReactWrapper
71 wrap.childAt(0) // => ReactWrapper
72 wrap.at(0) // => ReactWrapper
73 wrap.first() // => ReactWrapper
74 wrap.last() // => ReactWrapper
78 wrap.get(0) // => ReactElement
79 wrap.getNode() // => ReactElement
80 wrap.getNodes() // => Array<ReactElement>
81 wrap.getDOMNode() // => DOMComponent
84 See: [Full rendering API](http://airbnb.io/enzyme/docs/api/mount.html)
89 wrap.simulate('click')
95 wrap.setState({ ... })
96 wrap.setProps({ ... })
97 wrap.setContext({ ... })
99 wrap.state() // => Any (get state)
100 wrap.props() // => object (get props)
101 wrap.context() // => Any (get context)
103 wrap.instance() // => ReactComponent
111 wrap.update() // calls forceUpdate()
117 wrap.debug() // => string
118 wrap.html() // => string
119 wrap.text() // => string
120 wrap.type() // => string | function
121 wrap.name() // => string
122 wrap.is('.classname') // => boolean
123 wrap.hasClass('class') // => boolean
124 wrap.exists() // => boolean
125 wrap.contains(<div />) // => boolean
126 wrap.contains([ <div /> ]) // => boolean
128 wrap.containsMatchingElement(<div />) // => boolean
129 wrap.containsAllMatchingElements([ <div /> ]) // => boolean
130 wrap.containsAnyMatchingElements([ <div /> ]) // => boolean
135 - <https://airbnb.io/enzyme>