| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061 |
- /*
- Copyright (C) 2017 Cloudbase Solutions SRL
- This program is free software: you can redistribute it and/or modify
- it under the terms of the GNU Affero General Public License as
- published by the Free Software Foundation, either version 3 of the
- License, or (at your option) any later version.
- This program is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- GNU Affero General Public License for more details.
- You should have received a copy of the GNU Affero General Public License
- along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
- // @flow
- import React from 'react'
- import { shallow } from 'enzyme'
- import sinon from 'sinon'
- import TW from '../../../utils/TestWrapper'
- import Panel, { TEST_ID } from '.'
- import type { Props, NavigationItem } from '.'
- const navigationItems: NavigationItem[] = [
- { label: 'Navigation1', value: 'navigation1' },
- { label: 'Navigation2', value: 'navigation2' },
- ]
- const content = 'Content'
- const wrap = (props: Props) => new TW(shallow(
- <Panel {...props} />
- ), TEST_ID)
- describe('Panel Component', () => {
- it('renders navigation items', () => {
- let wrapper = wrap({ navigationItems, content, onChange: () => { }, selectedValue: 'navigation2' })
- navigationItems.forEach(i => {
- expect(wrapper.findText(`navItem-${i.value}`)).toBe(i.label)
- })
- })
- it('selects the selected value', () => {
- let wrapper = wrap({ navigationItems, content, onChange: () => { }, selectedValue: 'navigation2' })
- expect(wrapper.find('navItem-navigation1').prop('selected')).toBeFalsy()
- expect(wrapper.find('navItem-navigation2').prop('selected')).toBe(true)
- })
- it('dispatches onChange', () => {
- let onChange = sinon.spy()
- let wrapper = wrap({ navigationItems, content, onChange, selectedValue: 'navigation2' })
- wrapper.find('navItem-navigation1').simulate('click')
- expect(onChange.called).toBe(true)
- })
- it('renders content', () => {
- let wrapper = wrap({ navigationItems, content, onChange: () => { }, selectedValue: 'navigation2' })
- expect(wrapper.findText('content')).toBe(content)
- })
- })
|