/
templateMouseEventsHaveKeyEventsRule.spec.ts
60 lines (56 loc) · 1.5 KB
/
templateMouseEventsHaveKeyEventsRule.spec.ts
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
import { Rule } from '../src/templateMouseEventsHaveKeyEventsRule';
import { assertAnnotated, assertSuccess } from './testHelper';
const {
FAILURE_STRING_MOUSE_OUT,
FAILURE_STRING_MOUSE_OVER,
metadata: { ruleName }
} = Rule;
describe(ruleName, () => {
describe('failure', () => {
it('should fail when mouseover is not accompanied with focus', () => {
const source = `
@Component({
template: \`
<div (mouseover)="onMouseOver()"></div>
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
\`
})
class Bar {}
`;
assertAnnotated({
message: FAILURE_STRING_MOUSE_OVER,
ruleName,
source
});
});
it('should fail when mouseout is not accompanied with blur', () => {
const source = `
@Component({
template: \`
<div (mouseout)="onMouseOut()"></div>
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
\`
})
class Bar {}
`;
assertAnnotated({
message: FAILURE_STRING_MOUSE_OUT,
ruleName,
source
});
});
});
describe('success', () => {
it('should work find when mouse events are associated with key events', () => {
const source = `
@Component({
template: \`
<div (mouseover)="onMouseOver()" (focus)="onMouseOver()" (mouseout)="onMouseOut()" (blur)="onMouseOut()"></div>
\`
})
class Bar {}
`;
assertSuccess(ruleName, source);
});
});
});