test.jsx 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. /*
  2. Copyright (C) 2017 Cloudbase Solutions SRL
  3. This program is free software: you can redistribute it and/or modify
  4. it under the terms of the GNU Affero General Public License as
  5. published by the Free Software Foundation, either version 3 of the
  6. License, or (at your option) any later version.
  7. This program is distributed in the hope that it will be useful,
  8. but WITHOUT ANY WARRANTY; without even the implied warranty of
  9. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  10. GNU Affero General Public License for more details.
  11. You should have received a copy of the GNU Affero General Public License
  12. along with this program. If not, see <http://www.gnu.org/licenses/>.
  13. */
  14. // @flow
  15. import React from 'react'
  16. import { shallow } from 'enzyme'
  17. import sinon from 'sinon'
  18. import DropdownLink from '.'
  19. const wrap = props => shallow(<DropdownLink {...props} />)
  20. describe('DropdownLink Component', () => {
  21. it('renders with selectedItem', () => {
  22. let onChange = sinon.spy()
  23. let wrapper = wrap({
  24. items: [
  25. { label: 'Item 1', value: 'item-1' },
  26. { label: 'Item 2', value: 'item-2' },
  27. { label: 'Item 3', value: 'item-3' },
  28. ],
  29. selectedItem: 'item-2',
  30. onChange,
  31. })
  32. expect(wrapper.findWhere(w => w.prop('data-test-id') === 'dropdownLinkLabel').dive().text()).toBe('Item 2')
  33. })
  34. // it('has selected item highlighted when opening the list', () => {
  35. // let onChange = sinon.spy()
  36. // let wrapper = wrap({
  37. // items: [
  38. // { label: 'Item 1', value: 'item-1' },
  39. // { label: 'Item 2', value: 'item-2' },
  40. // { label: 'Item 3', value: 'item-3' },
  41. // ],
  42. // selectedItem: 'item-2',
  43. // onChange,
  44. // })
  45. // wrapper.childAt(0).simulate('click')
  46. // let list = wrapper.childAt(1)
  47. // expect(list.children().length).toBe(3)
  48. // expect(list.childAt(1).prop('selected')).toBe(true)
  49. // expect(list.childAt(0).prop('selected')).toBe(false)
  50. // expect(list.childAt(2).prop('selected')).toBe(false)
  51. // })
  52. })