2017-09-27 02:55:33 +08:00
|
|
|
import React from 'react';
|
|
|
|
import { scryRenderedDOMComponentsWithClass, Simulate } from 'react-dom/test-utils';
|
2016-07-12 03:28:37 +08:00
|
|
|
|
2017-09-27 02:55:33 +08:00
|
|
|
import MultiselectDropdown from '../../src/components/multiselect-dropdown';
|
|
|
|
import { renderIntoDocument } from '../mailspring-test-utils';
|
2016-07-12 03:28:37 +08:00
|
|
|
|
|
|
|
const makeDropdown = (items = [], props = {}) => {
|
2017-09-27 02:55:33 +08:00
|
|
|
return renderIntoDocument(<MultiselectDropdown {...props} items={items} />);
|
|
|
|
};
|
2016-07-12 03:28:37 +08:00
|
|
|
describe('MultiselectDropdown', function multiSelectedDropdown() {
|
|
|
|
describe('_onItemClick', () => {
|
|
|
|
it('calls onToggleItem function', () => {
|
2017-09-27 02:55:33 +08:00
|
|
|
const onToggleItem = jasmine.createSpy('onToggleItem');
|
|
|
|
const itemChecked = jasmine.createSpy('itemChecked');
|
|
|
|
const itemKey = i => i;
|
|
|
|
const dropdown = makeDropdown(['annie@nylas.com', 'anniecook@ostby.com'], {
|
|
|
|
onToggleItem,
|
|
|
|
itemChecked,
|
|
|
|
itemKey,
|
|
|
|
});
|
|
|
|
dropdown.setState({ selectingItems: true });
|
|
|
|
const item = scryRenderedDOMComponentsWithClass(dropdown, 'item')[0];
|
|
|
|
Simulate.mouseDown(item);
|
|
|
|
expect(onToggleItem).toHaveBeenCalled();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|