Skip to content

Latest commit

 

History

History
50 lines (35 loc) · 2.1 KB

README.md

File metadata and controls

50 lines (35 loc) · 2.1 KB

React Mocha JSDOM Example

A quick and concise example of testing React components in Mocha using JSDOM.

Note: Prefer Enzyme

It is better practice to use Enzyme to test your React components. However, that is not always strictly possible or the best option, so this repo serves as an alternative method for testing react components.

Some quick info

What JSDOM does for you

JSDOM emulates a DOM entiely in Nodejs. This lets you render React components into a fake DOM and poke at them the same way you would if you ran your tests in a browser or in PhantomJS.

What is lost (spoiler: not much)

You won't be testing your component in an actual browser, therefore you won't have the exact same level of certainty in your tests. If you are using this method for unit testing, you won't need to worry about much. If your components are doing very complex stuff with generating DOM elements outside of the flow of react's render methods, this may not be for you.

Setting it up

This is the wonderful part. There is hardly any setup. You just need a tiny bit of scaffolding that you require via mocha's --require flag. See test/setup for a documented example of what you'll need, and the test script defined in package.json in this repository for how to form your mocha call.

Writing tests

You can write your tests the same way you always have. If you haven't written tests before, you can see the example test files written in both ES5 and 6 living in the test directory of this repo. For the sake of brevity, I won't write complicated examples here. The example files have plenty of comments.

If something needs clarification, please open an issue and I will improve the documentation around that area in this repo's files.

"But I don't use Babel/ES6!"

That's fine, too! Not required at all. In that case, the only real difference is that you dont need the --compilers argument in the mocha call in your test script. You can see a standard ES5 example in the test directory as well.