Skip to content

helio-training/react-testing

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

2 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Testing in React

Testing comes by default with JEST. Jest is simply a test runner similar to mocha, ava, etc. I installed the following packages to help test my new Login Component (Login.js).

npm i chai enzyme react-addons-test-utils react-scripts react-test-renderer -D

The two main libraries are:

  1. Chai - My assertion library, gives me the ability to write expect(true).to.be.true;
  2. Enzyme - React helper to render and test react components without rendering the whole application

Login Component

I created a login component with email/password fields, a form and a submit button.

JEST being the test runner allows me to setup tests against my components in a describe / it format.

describe('<Login />', () => {
  
  // You make up the tests that you want
  it('should do something cool', () => {
     // You assert in here your expectations using Chai
     expect(true).to.be.true;
  });
});

The create-react-app sets up nicely jest and gives you a sample test (App.test.js). I prefer to move tests into the __tests__ folder to separate out the my components from my tests.

Run jest using npm test or yarn test.

These are the tests I came up with.

import React from 'react';
import { expect } from 'chai';
import { shallow } from 'enzyme';

import Login from '../Login';

describe('<Login>', () => {
  it('has a login button', () => {
    const wrapper = shallow(<Login/>);
    expect(wrapper.containsMatchingElement(<button type="submit">Login</button>)).to.be.true;
  });

  it('has a email input field', () => {
    const wrapper = shallow(<Login/>);
    expect(wrapper.containsMatchingElement(<input type="email" />)).to.be.true;
  });

  it('has a password input field', () => {
    const wrapper = shallow(<Login/>);
    expect(wrapper.containsMatchingElement(<input type="password" />)).to.be.true;
  });

  it('passes login information', () => {
    const email = '[email protected]';
    const password = '123password';
    const wrapper = shallow(<Login handleLogin={state => {
      expect(state.email).to.be.equal(email);
      expect(state.password).to.be.equal(password);
    }}/>);
    wrapper.setState({ email: '[email protected]', password: '123password'});
    wrapper.find('button').simulate('click');
  });
});

Enzyme allows me to 'render' a React component without actually starting up a browser. Super handy for testing.

Using chai/enzyme combo you can create all sorts of combinations to facilitate testing in React. It's that simple.

Where does AVA come into play?

In React application you won't use AVA. JEST is the test runner that is used by react by default create-react-app. Don't try to use it in this type of project.

Ava is really good for testing a node application. Use it in the node space.

About

Example testing with React, Enzyme, and JEST

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published