add TowerLogo tests

This commit is contained in:
John Mitchell 2018-11-02 16:34:02 -04:00
parent 07f6508402
commit 96b8ab47c4
No known key found for this signature in database
GPG Key ID: FE6A9B5BD4EB5C94
2 changed files with 63 additions and 4 deletions

View File

@ -0,0 +1,58 @@
import React from 'react';
import { MemoryRouter } from 'react-router-dom';
import { mount } from 'enzyme';
import TowerLogo from '../../src/components/TowerLogo';
let logoWrapper;
let towerLogoElem;
let brandElem;
const findChildren = () => {
towerLogoElem = logoWrapper.find('TowerLogo');
brandElem = logoWrapper.find('Brand');
};
describe('<TowerLogo />', () => {
test('initially renders without crashing', () => {
logoWrapper = mount(<MemoryRouter><TowerLogo /></MemoryRouter>);
findChildren();
expect(logoWrapper.length).toBe(1);
expect(towerLogoElem.length).toBe(1);
expect(brandElem.length).toBe(1);
});
test('adds navigation to route history on click', () => {
const onLogoClick = jest.fn();
logoWrapper = mount(<MemoryRouter><TowerLogo onClick={onLogoClick} /></MemoryRouter>);
findChildren();
expect(towerLogoElem.props().history.length).toBe(1);
logoWrapper.simulate('click');
expect(towerLogoElem.props().history.length).toBe(2);
});
test('gracefully handles not being passed click handler', () => {
logoWrapper = mount(<MemoryRouter><TowerLogo /></MemoryRouter>);
findChildren();
expect(towerLogoElem.props().history.length).toBe(1);
logoWrapper.simulate('click');
expect(towerLogoElem.props().history.length).toBe(1);
});
test('handles mouse over and out state.hover changes', () => {
const onLogoClick = jest.fn();
logoWrapper = mount(<MemoryRouter><TowerLogo onClick={onLogoClick} /></MemoryRouter>);
findChildren();
findChildren();
expect(brandElem.props().src).toBe('tower-logo-header.svg');
brandElem.props().onMouseOver();
expect(towerLogoElem.state().hover).toBe(true);
logoWrapper.update();
findChildren();
expect(brandElem.props().src).toBe('tower-logo-header-hover.svg');
brandElem.props().onMouseOut();
expect(towerLogoElem.state().hover).toBe(false);
logoWrapper.update();
findChildren();
expect(brandElem.props().src).toBe('tower-logo-header.svg');
});
});

View File

@ -13,13 +13,13 @@ class TowerLogo extends Component {
}
onClick = () => {
if (!this.props.onClick) return;
const { history, onClick: handleClick } = this.props;
const { history } = this.props;
if (!handleClick) return;
history.push('/');
this.props.onClick();
handleClick();
};
onHover = () => {
@ -30,10 +30,11 @@ class TowerLogo extends Component {
render () {
const { hover } = this.state;
const { onClick: handleClick } = this.props;
let src = TowerLogoHeader;
if (hover && this.props.onClick) {
if (hover && handleClick) {
src = TowerLogoHeaderHover;
}