/
templateAccessibilityLabelForRule.spec.ts
127 lines (118 loc) · 2.81 KB
/
templateAccessibilityLabelForRule.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
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
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
import { Rule } from '../src/templateAccessibilityLabelForRule';
import { assertAnnotated, assertSuccess } from './testHelper';
const {
FAILURE_STRING,
metadata: { ruleName }
} = Rule;
describe(ruleName, () => {
describe('failure', () => {
it("should fail when label doesn't have for attribute", () => {
const source = `
@Component({
template: \`
<label>Label</label>
~~~~~~~
\`
})
class Bar {}
`;
assertAnnotated({
message: FAILURE_STRING,
ruleName,
source
});
});
it("should fail when custom label doesn't have label attribute", () => {
const source = `
@Component({
template: \`
<app-label></app-label>
~~~~~~~~~~~
\`
})
class Bar {}
`;
assertAnnotated({
message: FAILURE_STRING,
ruleName,
source,
options: {
labelComponents: ['app-label'],
labelAttributes: ['id']
}
});
});
});
describe('success', () => {
it('should work when label has for attribute', () => {
const source = `
@Component({
template: \`
<label for="id"></label>
<label [attr.for]="id"></label>
\`
})
class Bar {}
`;
assertSuccess(ruleName, source);
});
it('should work when label are associated implicitly', () => {
const source = `
@Component({
template: \`
<label>
Label
<input />
</label>
<label>
Label
<span><input /></span>
</label>
<app-label>
<span>
<app-input></app-input>
</span>
</app-label>
\`
})
class Bar {}
`;
assertSuccess(ruleName, source, {
labelComponents: ['app-label'],
controlComponents: ['app-input']
});
});
it("should fail when label doesn't have for attribute", () => {
const source = `
@Component({
template: \`
<label>
<span>
<span>
<input>
</span>
</span>
</label>
\`
})
class Bar {}
`;
assertSuccess(ruleName, source);
});
it('should work when custom label has label attribute', () => {
const source = `
@Component({
template: \`
<app-label id="name"></app-label>
<app-label [id]="name"></app-label>
\`
})
class Bar {}
`;
assertSuccess(ruleName, source, {
labelComponents: ['app-label'],
labelAttributes: ['id']
});
});
});
});