Testing Stateful Components

Learn how to test Stateful Components in this lesson by keeping track of the state and checking event handlers.

Introduction to testing stateful components

Both of the React components we’ve built so far are stateless. Their render output is determined entirely by the props they receive, allowing us to express them as a single function. This has the advantage of simplicity. But a carousel is stateful. It needs to keep track of which slide it’s currently showing. In this section, we’ll take a TDD approach to building a Carousel component with an internal state.

Start with a stub implementation of the component. Since functional components can’t have a state, make it a subclass of React.PureComponent:

// src/Carousel.js
import React from 'react';

class Carousel extends React.PureComponent {
  render() {
    return <div />;
  }
}

export default Carousel;

Using React.PureComponent instead of React.Component tells React that our component doesn’t need to be re-rendered unless its props or state change. It’s a good practice to keep components pure whenever possible, both for performance and for conceptual simplicity.

Add a skeletal test suite:

// src/tests/Carousel.test.js
import React from 'react';
import { shallow } from 'enzyme';
import Carousel from '../Carousel';

describe('Carousel', () => {
  let wrapper;

  beforeEach(() => {
    wrapper = shallow(<Carousel />);
  });

  it('renders a <div>', () => {
    expect(wrapper.type()).toBe('div');
  });
});

Now let’s outline some requirements for this component:

  • The carousel keeps track of the current slide with a number, slideIndex.

  • slideIndex is initially 0, meaning that the first slide is shown.

  • Clicking the “Prev” button decreases slideIndex, wrapping around to the index of the last slide when it goes below 0.

  • Clicking the “Next” button increases slideIndex, wrapping around to 0 when it goes above the index of the last slide.

  • The carousel takes an array named slides and renders the slide indicated by slideIndex.

Translating these requirements into tests will help us figure out exactly how to implement them.

Testing state

Enzyme’s API for working with state is analogous to its API for working with props.

  • Call wrapper.state(key) to get the piece of state corresponding to that key:

Get hands-on with 1300+ tech skills courses.