forked from reactstrap/reactstrap
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathNavLink.spec.js
More file actions
86 lines (66 loc) · 2.33 KB
/
Copy pathNavLink.spec.js
File metadata and controls
86 lines (66 loc) · 2.33 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
import React from 'react';
import { shallow } from 'enzyme';
import { NavLink } from '../';
describe('NavLink', () => {
it('should render .nav-link markup', () => {
const wrapper = shallow(<NavLink />);
expect(wrapper.html()).toBe('<a class="nav-link"></a>');
});
it('should render custom tag', () => {
const wrapper = shallow(<NavLink tag="div" />);
expect(wrapper.html()).toBe('<div class="nav-link"></div>');
});
it('should render children', () => {
const wrapper = shallow(<NavLink>Children</NavLink>);
expect(wrapper.html()).toBe('<a class="nav-link">Children</a>');
});
it('should pass additional classNames', () => {
const wrapper = shallow(<NavLink className="extra" />);
expect(wrapper.hasClass('extra')).toBe(true);
expect(wrapper.hasClass('nav-link')).toBe(true);
});
it('should render active class', () => {
const wrapper = shallow(<NavLink active />);
expect(wrapper.hasClass('active')).toBe(true);
});
it('should render disabled markup', () => {
const wrapper = shallow(<NavLink disabled />);
expect(wrapper.hasClass('disabled')).toBe(true);
});
it('handles onClick prop', () => {
const onClick = jest.fn();
const e = createSpyObj('e', ['preventDefault']);
const wrapper = shallow(
<NavLink onClick={onClick} />
);
wrapper.find('a').simulate('click', e);
expect(onClick).toHaveBeenCalled();
expect(e.preventDefault).not.toHaveBeenCalled();
});
it('handles onClick events', () => {
const e = createSpyObj('e', ['preventDefault']);
const wrapper = shallow(
<NavLink />
);
wrapper.find('a').simulate('click', e);
expect(e.preventDefault).not.toHaveBeenCalled();
});
it('prevents link clicks via onClick for dropdown nav-items', () => {
const e = createSpyObj('e', ['preventDefault']);
const wrapper = shallow(
<NavLink href="#" />
);
wrapper.find('a').simulate('click', e);
expect(e.preventDefault).toHaveBeenCalled();
});
it('is not called when disabled', () => {
const onClick = jest.fn();
const e = createSpyObj('e', ['preventDefault']);
const wrapper = shallow(
<NavLink disabled onClick={onClick} />
);
wrapper.find('a').simulate('click', e);
expect(e.preventDefault).toHaveBeenCalled();
expect(onClick).not.toHaveBeenCalled();
});
});