forked from ElemeFE/element
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtooltip.spec.js
90 lines (79 loc) · 2.31 KB
/
tooltip.spec.js
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
87
88
89
90
import { createVue, triggerEvent, destroyVM } from '../util';
describe('Tooltip', () => {
let vm;
afterEach(() => {
destroyVM(vm);
});
it('create', () => {
vm = createVue(`
<el-tooltip content="提示文字">
<button>click</button>
</el-tooltip>`);
expect(vm.$el.querySelector('.el-tooltip__popper')).to.have.property('textContent', '提示文字');
});
it('custom popper class', () => {
vm = createVue(`
<el-tooltip content="提示文字" popper-class="custom-popper">
<button>click</button>
</el-tooltip>`);
expect(vm.$el.querySelector('.el-tooltip__popper').classList.contains('custom-popper')).to.true;
});
describe('manual', () => {
const vm = createVue({
template: `
<el-tooltip ref="tooltip" manual content="abc" v-model="show">
<button>click</button>
</el-tooltip>
`,
data() {
return { show: false };
}
}, true);
const tooltip = vm.$refs.tooltip;
it('showPopper is false', () => {
triggerEvent(tooltip.$el, 'mouseenter');
expect(tooltip.showPopper).to.false;
});
it('show', done => {
vm.show = true;
vm.$nextTick(_ => {
expect(tooltip.showPopper).to.true;
done();
});
});
it('still show when trigger mouseleave', () => {
triggerEvent(tooltip.$el, 'mouseleave');
expect(tooltip.showPopper).to.true;
});
it('hidden', done => {
vm.show = false;
vm.$nextTick(_ => {
expect(tooltip.showPopper).to.false;
done();
});
});
});
describe('hover', () => {
const vm = createVue(`
<el-tooltip ref="tooltip" content="提示文字">
<button>click</button>
</el-tooltip>
`);
const tooltip = vm.$refs.tooltip;
triggerEvent(tooltip.$el, 'mouseenter');
it('popperElm is exist', () => expect(tooltip.popperElm).to.exist);
it('showPopper is true', () => expect(tooltip.showPopper).to.true);
it('close popper', () => {
triggerEvent(tooltip.$el, 'mouseleave');
expect(tooltip.showPopper).to.false;
});
});
it('light mode', () => {
vm = createVue(`
<el-tooltip content="abc" effect="light">
<button>abc</button>
</el-tooltip>
`);
expect(vm.$el.querySelector('.is-light')).to.exist;
});
});