0
votes

I'm using enzyme to test a react component. However, the 'find' method isn't able to find any element. Doesn't find by className, element, etc. It's definitely something I'm doing wrong as I can use .find in a separate project, but I can't seem to find what I'm doing wrong.

  • node: 6.10.0
  • jest-cli: 12.1.1
  • babel-jest: 12.1.0
  • enzyme: 2.7.1
  • jest: 19.0.2
  • jest-enzyme: 2.1.2
  • React: 15.1.0

React Component

import React from 'react'
import Flippable from '../../components/flippable_two_pane/template'

class FLippableWidget extends React.Component {
  constructor (props) {
    super(props)

    this.defaultState()
  }

  // Set default state
  defaultState () {
    const state = {
      selected: 0
    }

    // If state exists, reset it.
    if (typeof this.state === 'object') {
      this.setState(state)

    // Otherwise, create state.
    } else {
      this.state = state
    }
  }


  // Click handler.
  handleClick (e) {
    const keyPress = e.keyCode
    const keyEnter = keyPress === 13
    // toggle the currently selected
    let index = this.state.selected === 0 ? 1 : 0

    // Exit, if not "Enter" key.
    if (keyPress && !keyEnter) {
      return
    }

    this.setState({
      selected: index
    })

    if (typeof this.props.clickCallback !== 'function') {
      return
    }

    this.props.clickCallback(e, index)
  }

  // Render method.
  render () {
    const classes = 'flippable-widget ' + this.props.className
    var isFlipped = this.props.isFlipped || this.state.selected ? true : false
    const handleClick = this.handleClick.bind(this)
    let children = this.props.children || []

    return (
      <div className='widget'>
        <h2>{this.props.title}</h2>

        {
          children.length === 3
          ? children[2]
          : <ul className='flippable-widget_list'>
            <li
              onClick={(e) => { handleClick(e) }}
              onKeyDown={(e) => { handleClick(e) }}
            >
            </li>
          </ul>
        }

        <Flippable height={this.props.height} isFlipped={isFlipped} widgetCategory={this.props.widgetCategory}>
          {/* front pane */}
          {children[0]}

          {/* back pane */}
          <div className='flippable-widget__overflow-container'>
            {children[1]}
          </div>
        </Flippable>
      </div>
    )
  }
}

FLippableWidget.propTypes = {
  children: React.PropTypes.node,
  className: React.PropTypes.string,
  title: React.PropTypes.string,
  height: React.PropTypes.string
}

export default FLippableWidget

Component Test

import FlippableWidget from '../source/components/widget_flippable/template';
import React from 'react';
import { shallow, mount } from 'enzyme';


jest.autoMockOff();

describe('<FlippableWidget/> ', () => {
  let wrapper;
  let props = {
    children: ['mock-front-pane','mock-back-pane'],
    className: 'mockClassName',
    title: 'mockTitle',
    height: '300px'
  };

  beforeEach(() => {
    wrapper = mount(<FlippableWidget {...props} />);
  });

  //***************************************
  // Test Structure
  //***************************************

  it('receives props upon loading', () => {
    expect(wrapper.prop('className')).toEqual('mockClassName');
    expect(wrapper.prop('title')).toEqual('mockTitle');
    expect(wrapper.prop('height')).toEqual('300px');
    expect(wrapper.prop('children')).toEqual(['mock-front-pane','mock-back-pane']);
  });

  it('renders a div with the correct className', () => {
    // console.log(wrapper).debug();
    expect(wrapper.find('.widget').length).toBe(1);
  });
});

Testing for props passes, but the second test '..renders a div..' doesn't pass. It shows an error of "Expected 0 to be 1". I understand what the error means, but I don't understand why it's occurring.

console.log(wrapper).debug()

ReactWrapper {
  component:
   ReactClassComponent {
     setChildProps:
      { [Function: bound setChildProps]
        __reactBoundContext: [Circular],
        __reactBoundMethod: [Function: setChildProps],
        __reactBoundArguments: null,
        bind: [Function] },
     setChildContext:
      { [Function: bound setChildContext]
        __reactBoundContext: [Circular],
        __reactBoundMethod: [Function: setChildContext],
        __reactBoundArguments: null,
        bind: [Function] },
     getInstance:
      { [Function: bound getInstance]
        __reactBoundContext: [Circular],
        __reactBoundMethod: [Function: getInstance],
        __reactBoundArguments: null,
        bind: [Function] },
     getWrappedComponent:
      { [Function: bound getWrappedComponent]
        __reactBoundContext: [Circular],
        __reactBoundMethod: [Function: getWrappedComponent],
        __reactBoundArguments: null,
        bind: [Function] },
     props: { Component: [Object], props: [Object], context: null },
     context: {},
     refs: {},
     updater:
      { isMounted: [Function: isMounted],
        enqueueCallback: [Function: enqueueCallback],
        enqueueCallbackInternal: [Function: enqueueCallbackInternal],
        enqueueForceUpdate: [Function: enqueueForceUpdate],
        enqueueReplaceState: [Function: enqueueReplaceState],
        enqueueSetState: [Function: enqueueSetState],
        enqueueElementInternal: [Function: enqueueElementInternal],
        validateCallback: [Function: validateCallback] },
     state: { mount: true, props: [Object], context: null },
     _reactInternalInstance:
      ReactCompositeComponentWrapper {
        _currentElement: [Object],
        _rootNodeID: 0,
        _compositeType: 0,
        _instance: [Circular],
        _hostParent: null,
        _hostContainerInfo: [Object],
        _updateBatchNumber: null,
        _pendingElement: null,
        _pendingStateQueue: null,
        _pendingReplaceState: false,
        _pendingForceUpdate: false,
        _renderedNodeType: 1,
        _renderedComponent: [Object],
        _context: {},
        _mountOrder: 8,
        _topLevelWrapper: [Object],
        _pendingCallbacks: null,
        _calledComponentWillUnmount: false,
        _warnedAboutRefsInRender: false,
        _mountIndex: 0,
        _mountImage: null,
        _debugID: 5 } },
  root: [Circular],
  node:
   FLippableWidget {
     defaultState:
      { [Function: defaultState]
        _isMockFunction: true,
        _getMockImplementation: [Function],
        mock: [Object],
        mockClear: [Function],
        mockReturnValueOnce: [Function],
        mockReturnValue: [Function],
        mockImplementationOnce: [Function],
        mockImpl: [Function],
        mockImplementation: [Function],
        mockReturnThis: [Function],
        _protoImpl: [Object] },
     handleClick:
      { [Function: handleClick]
        _isMockFunction: true,
        _getMockImplementation: [Function],
        mock: [Object],
        mockClear: [Function],
        mockReturnValueOnce: [Function],
        mockReturnValue: [Function],
        mockImplementationOnce: [Function],
        mockImpl: [Function],
        mockImplementation: [Function],
        mockReturnThis: [Function],
        _protoImpl: [Object] },
     render:
      { [Function: render]
        _isMockFunction: true,
        _getMockImplementation: [Function],
        mock: [Object],
        mockClear: [Function],
        mockReturnValueOnce: [Function],
        mockReturnValue: [Function],
        mockImplementationOnce: [Function],
        mockImpl: [Function],
        mockImplementation: [Function],
        mockReturnThis: [Function],
        _protoImpl: [Object] },
     setState:
      { [Function: mockConstructor]
        _isMockFunction: true,
        _getMockImplementation: [Function],
        mock: [Object],
        mockClear: [Function],
        mockReturnValueOnce: [Function],
        mockReturnValue: [Function],
        mockImplementationOnce: [Function],
        mockImpl: [Function],
        mockImplementation: [Function],
        mockReturnThis: [Function],
        _protoImpl: [Object] },
     forceUpdate:
      { [Function: mockConstructor]
        _isMockFunction: true,
        _getMockImplementation: [Function],
        mock: [Object],
        mockClear: [Function],
        mockReturnValueOnce: [Function],
        mockReturnValue: [Function],
        mockImplementationOnce: [Function],
        mockImpl: [Function],
        mockImplementation: [Function],
        mockReturnThis: [Function],
        _protoImpl: [Object] },
     props:
      { children: [Object],
        className: 'mockClassName',
        title: 'mockTitle',
        height: '300px' },
     context: {},
     refs: {},
     updater:
      { isMounted: [Function: isMounted],
        enqueueCallback: [Function: enqueueCallback],
        enqueueCallbackInternal: [Function: enqueueCallbackInternal],
        enqueueForceUpdate: [Function: enqueueForceUpdate],
        enqueueReplaceState: [Function: enqueueReplaceState],
        enqueueSetState: [Function: enqueueSetState],
        enqueueElementInternal: [Function: enqueueElementInternal],
        validateCallback: [Function: validateCallback] },
     _reactInternalInstance:
      ReactCompositeComponentWrapper {
        _currentElement: [Object],
        _rootNodeID: 0,
        _compositeType: 0,
        _instance: [Circular],
        _hostParent: null,
        _hostContainerInfo: [Object],
        _updateBatchNumber: null,
        _pendingElement: null,
        _pendingStateQueue: null,
        _pendingReplaceState: false,
        _pendingForceUpdate: false,
        _renderedNodeType: 2,
        _renderedComponent: [Object],
        _context: {},
        _mountOrder: 9,
        _topLevelWrapper: null,
        _pendingCallbacks: null,
        _calledComponentWillUnmount: false,
        _warnedAboutRefsInRender: false,
        _mountIndex: 0,
        _mountImage: null,
        _debugID: 6 },
     state: null },
  nodes:
   [ FLippableWidget {
       defaultState: [Object],
       setIconColorByClassName: [Object],
       handleClick: [Object],
       render: [Object],
       setState: [Object],
       forceUpdate: [Object],
       props: [Object],
       context: {},
       refs: {},
       updater: [Object],
       _reactInternalInstance: [Object],
       state: null } ],
  length: 1,
  options: {},
  complexSelector:
   ComplexSelector {
     buildPredicate: [Function: buildInstPredicate],
     findWhereUnwrapped: [Function: findWhereUnwrapped],
     childrenOfNode: [Function: childrenOfInst] } }
1
Note: I know testing that the mounted <FlippableWidget /> has certain props is pointless-new to enzyme, so I'm just testing it out.Tom

1 Answers

0
votes

Turns out it was the version of React that was causing the issue. Fixed by updating to 15.4.2