fleet/frontend/components/buttons/DropdownButton/DropdownButton.tests.jsx
2017-01-05 09:26:10 -06:00

26 lines
855 B
JavaScript

import React from 'react';
import expect, { createSpy, restoreSpies } from 'expect';
import { mount } from 'enzyme';
import { noop } from 'lodash';
import { DropdownButton } from './DropdownButton';
describe('DropdownButton - component', () => {
afterEach(restoreSpies);
it("calls the clicked item's onClick attribute", () => {
const optionSpy = createSpy();
const dropdownOptions = [{ label: 'btn1', onClick: noop }, { label: 'btn2', onClick: optionSpy }];
const component = mount(
<DropdownButton options={dropdownOptions}>
New Button
</DropdownButton>
);
component.find('.dropdown-button').simulate('click');
expect(component.state().isOpen).toEqual(true);
component.find('li.dropdown-button__option').last().find('Button').simulate('click');
expect(optionSpy).toHaveBeenCalled();
});
});