1018 lines
42 KiB
HTML
1018 lines
42 KiB
HTML
<!doctype html>
|
|
<html lang="en">
|
|
<head>
|
|
<title>Code coverage report for spec/builtins.js</title>
|
|
<meta charset="utf-8">
|
|
|
|
<link rel="stylesheet" href="../prettify.css">
|
|
|
|
<style>
|
|
body, html {
|
|
margin:0; padding: 0;
|
|
}
|
|
body {
|
|
font-family: Helvetica Neue, Helvetica,Arial;
|
|
font-size: 10pt;
|
|
}
|
|
div.header, div.footer {
|
|
background: #eee;
|
|
padding: 1em;
|
|
}
|
|
div.header {
|
|
z-index: 100;
|
|
position: fixed;
|
|
top: 0;
|
|
border-bottom: 1px solid #666;
|
|
width: 100%;
|
|
}
|
|
div.footer {
|
|
border-top: 1px solid #666;
|
|
}
|
|
div.body {
|
|
margin-top: 10em;
|
|
}
|
|
div.meta {
|
|
font-size: 90%;
|
|
text-align: center;
|
|
}
|
|
h1, h2, h3 {
|
|
font-weight: normal;
|
|
}
|
|
h1 {
|
|
font-size: 12pt;
|
|
}
|
|
h2 {
|
|
font-size: 10pt;
|
|
}
|
|
pre {
|
|
font-family: Consolas, Menlo, Monaco, monospace;
|
|
margin: 0;
|
|
padding: 0;
|
|
line-height: 14px;
|
|
font-size: 14px;
|
|
-moz-tab-size: 2;
|
|
-o-tab-size: 2;
|
|
tab-size: 2;
|
|
}
|
|
|
|
div.path { font-size: 110%; }
|
|
div.path a:link, div.path a:visited { color: #000; }
|
|
table.coverage { border-collapse: collapse; margin:0; padding: 0 }
|
|
|
|
table.coverage td {
|
|
margin: 0;
|
|
padding: 0;
|
|
color: #111;
|
|
vertical-align: top;
|
|
}
|
|
table.coverage td.line-count {
|
|
width: 50px;
|
|
text-align: right;
|
|
padding-right: 5px;
|
|
}
|
|
table.coverage td.line-coverage {
|
|
color: #777 !important;
|
|
text-align: right;
|
|
border-left: 1px solid #666;
|
|
border-right: 1px solid #666;
|
|
}
|
|
|
|
table.coverage td.text {
|
|
}
|
|
|
|
table.coverage td span.cline-any {
|
|
display: inline-block;
|
|
padding: 0 5px;
|
|
width: 40px;
|
|
}
|
|
table.coverage td span.cline-neutral {
|
|
background: #eee;
|
|
}
|
|
table.coverage td span.cline-yes {
|
|
background: #b5d592;
|
|
color: #999;
|
|
}
|
|
table.coverage td span.cline-no {
|
|
background: #fc8c84;
|
|
}
|
|
|
|
.cstat-yes { color: #111; }
|
|
.cstat-no { background: #fc8c84; color: #111; }
|
|
.fstat-no { background: #ffc520; color: #111 !important; }
|
|
.cbranch-no { background: yellow !important; color: #111; }
|
|
|
|
.cstat-skip { background: #ddd; color: #111; }
|
|
.fstat-skip { background: #ddd; color: #111 !important; }
|
|
.cbranch-skip { background: #ddd !important; color: #111; }
|
|
|
|
.missing-if-branch {
|
|
display: inline-block;
|
|
margin-right: 10px;
|
|
position: relative;
|
|
padding: 0 4px;
|
|
background: black;
|
|
color: yellow;
|
|
}
|
|
|
|
.skip-if-branch {
|
|
display: none;
|
|
margin-right: 10px;
|
|
position: relative;
|
|
padding: 0 4px;
|
|
background: #ccc;
|
|
color: white;
|
|
}
|
|
|
|
.missing-if-branch .typ, .skip-if-branch .typ {
|
|
color: inherit !important;
|
|
}
|
|
|
|
.entity, .metric { font-weight: bold; }
|
|
.metric { display: inline-block; border: 1px solid #333; padding: 0.3em; background: white; }
|
|
.metric small { font-size: 80%; font-weight: normal; color: #666; }
|
|
|
|
div.coverage-summary table { border-collapse: collapse; margin: 3em; font-size: 110%; }
|
|
div.coverage-summary td, div.coverage-summary table th { margin: 0; padding: 0.25em 1em; border-top: 1px solid #666; border-bottom: 1px solid #666; }
|
|
div.coverage-summary th { text-align: left; border: 1px solid #666; background: #eee; font-weight: normal; }
|
|
div.coverage-summary th.file { border-right: none !important; }
|
|
div.coverage-summary th.pic { border-left: none !important; text-align: right; }
|
|
div.coverage-summary th.pct { border-right: none !important; }
|
|
div.coverage-summary th.abs { border-left: none !important; text-align: right; }
|
|
div.coverage-summary td.pct { text-align: right; border-left: 1px solid #666; }
|
|
div.coverage-summary td.abs { text-align: right; font-size: 90%; color: #444; border-right: 1px solid #666; }
|
|
div.coverage-summary td.file { text-align: right; border-left: 1px solid #666; white-space: nowrap; }
|
|
div.coverage-summary td.pic { min-width: 120px !important; }
|
|
div.coverage-summary a:link { text-decoration: none; color: #000; }
|
|
div.coverage-summary a:visited { text-decoration: none; color: #333; }
|
|
div.coverage-summary a:hover { text-decoration: underline; }
|
|
div.coverage-summary tfoot td { border-top: 1px solid #666; }
|
|
|
|
div.coverage-summary .yui3-datatable-sort-indicator, div.coverage-summary .dummy-sort-indicator {
|
|
height: 10px;
|
|
width: 7px;
|
|
display: inline-block;
|
|
margin-left: 0.5em;
|
|
}
|
|
div.coverage-summary .yui3-datatable-sort-indicator {
|
|
background: url("https://yui-s.yahooapis.com/3.6.0/build/datatable-sort/assets/skins/sam/sort-arrow-sprite.png") no-repeat scroll 0 0 transparent;
|
|
}
|
|
div.coverage-summary .yui3-datatable-sorted .yui3-datatable-sort-indicator {
|
|
background-position: 0 -20px;
|
|
}
|
|
div.coverage-summary .yui3-datatable-sorted-desc .yui3-datatable-sort-indicator {
|
|
background-position: 0 -10px;
|
|
}
|
|
|
|
.high { background: #b5d592 !important; }
|
|
.medium { background: #ffe87c !important; }
|
|
.low { background: #fc8c84 !important; }
|
|
|
|
span.cover-fill, span.cover-empty {
|
|
display:inline-block;
|
|
border:1px solid #444;
|
|
background: white;
|
|
height: 12px;
|
|
}
|
|
span.cover-fill {
|
|
background: #ccc;
|
|
border-right: 1px solid #444;
|
|
}
|
|
span.cover-empty {
|
|
background: white;
|
|
border-left: none;
|
|
}
|
|
span.cover-full {
|
|
border-right: none !important;
|
|
}
|
|
pre.prettyprint {
|
|
border: none !important;
|
|
padding: 0 !important;
|
|
margin: 0 !important;
|
|
}
|
|
.com { color: #999 !important; }
|
|
.ignore-none { color: #999; font-weight: normal; }
|
|
|
|
</style>
|
|
</head>
|
|
<body>
|
|
<div class="header low">
|
|
<h1>Code coverage report for <span class="entity">spec/builtins.js</span></h1>
|
|
<h2>
|
|
|
|
Statements: <span class="metric">20% <small>(27 / 135)</small></span>
|
|
|
|
|
|
Branches: <span class="metric">0% <small>(0 / 4)</small></span>
|
|
|
|
|
|
Functions: <span class="metric">13.89% <small>(5 / 36)</small></span>
|
|
|
|
|
|
Lines: <span class="metric">20.93% <small>(27 / 129)</small></span>
|
|
|
|
Ignored: <span class="metric"><span class="ignore-none">none</span></span>
|
|
</h2>
|
|
<div class="path"><a href="../index.html">All files</a> » <a href="index.html">spec/</a> » builtins.js</div>
|
|
</div>
|
|
<div class="body">
|
|
<pre><table class="coverage">
|
|
<tr><td class="line-count">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
|
|
128
|
|
129
|
|
130
|
|
131
|
|
132
|
|
133
|
|
134
|
|
135
|
|
136
|
|
137
|
|
138
|
|
139
|
|
140
|
|
141
|
|
142
|
|
143
|
|
144
|
|
145
|
|
146
|
|
147
|
|
148
|
|
149
|
|
150
|
|
151
|
|
152
|
|
153
|
|
154
|
|
155
|
|
156
|
|
157
|
|
158
|
|
159
|
|
160
|
|
161
|
|
162
|
|
163
|
|
164
|
|
165
|
|
166
|
|
167
|
|
168
|
|
169
|
|
170
|
|
171
|
|
172
|
|
173
|
|
174
|
|
175
|
|
176
|
|
177
|
|
178
|
|
179
|
|
180
|
|
181
|
|
182
|
|
183
|
|
184
|
|
185
|
|
186
|
|
187
|
|
188
|
|
189
|
|
190
|
|
191
|
|
192
|
|
193
|
|
194
|
|
195
|
|
196
|
|
197
|
|
198
|
|
199
|
|
200
|
|
201
|
|
202
|
|
203
|
|
204
|
|
205
|
|
206
|
|
207
|
|
208
|
|
209
|
|
210
|
|
211
|
|
212
|
|
213
|
|
214
|
|
215
|
|
216
|
|
217
|
|
218
|
|
219
|
|
220
|
|
221
|
|
222
|
|
223
|
|
224
|
|
225
|
|
226
|
|
227
|
|
228
|
|
229
|
|
230
|
|
231
|
|
232
|
|
233</td><td class="line-coverage"><span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-yes">3</span>
|
|
<span class="cline-any cline-yes">3</span>
|
|
<span class="cline-any cline-yes">3</span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-yes">3</span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-yes">3</span>
|
|
<span class="cline-any cline-yes">3</span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-yes">3</span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-yes">3</span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-yes">3</span>
|
|
<span class="cline-any cline-yes">3</span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-yes">3</span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-yes">3</span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-yes">3</span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-yes">3</span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-yes">3</span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-yes">3</span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-yes">3</span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-yes">3</span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-yes">3</span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-yes">3</span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-yes">3</span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-yes">3</span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-yes">3</span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-yes">3</span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-yes">3</span>
|
|
<span class="cline-any cline-yes">3</span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-yes">3</span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-no"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-neutral"> </span>
|
|
<span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">/*global CompilerContext, shouldCompileTo, shouldThrow, compileWithPartials, handlebarsEnv */
|
|
describe('builtin helpers', function() {
|
|
describe('#if', function() {
|
|
it("if", <span class="fstat-no" title="function not covered" >function() {</span>
|
|
<span class="cstat-no" title="statement not covered" > var string = "{{#if goodbye}}GOODBYE {{/if}}cruel {{world}}!";</span>
|
|
<span class="cstat-no" title="statement not covered" > shouldCompileTo(string, {goodbye: true, world: "world"}, "GOODBYE cruel world!",</span>
|
|
"if with boolean argument shows the contents when true");
|
|
<span class="cstat-no" title="statement not covered" > shouldCompileTo(string, {goodbye: "dummy", world: "world"}, "GOODBYE cruel world!",</span>
|
|
"if with string argument shows the contents");
|
|
<span class="cstat-no" title="statement not covered" > shouldCompileTo(string, {goodbye: false, world: "world"}, "cruel world!",</span>
|
|
"if with boolean argument does not show the contents when false");
|
|
<span class="cstat-no" title="statement not covered" > shouldCompileTo(string, {world: "world"}, "cruel world!",</span>
|
|
"if with undefined does not show the contents");
|
|
<span class="cstat-no" title="statement not covered" > shouldCompileTo(string, {goodbye: ['foo'], world: "world"}, "GOODBYE cruel world!",</span>
|
|
"if with non-empty array shows the contents");
|
|
<span class="cstat-no" title="statement not covered" > shouldCompileTo(string, {goodbye: [], world: "world"}, "cruel world!",</span>
|
|
"if with empty array does not show the contents");
|
|
<span class="cstat-no" title="statement not covered" > shouldCompileTo(string, {goodbye: 0, world: "world"}, "cruel world!",</span>
|
|
"if with zero does not show the contents");
|
|
<span class="cstat-no" title="statement not covered" > shouldCompileTo("{{#if goodbye includeZero=true}}GOODBYE {{/if}}cruel {{world}}!",</span>
|
|
{goodbye: 0, world: "world"}, "GOODBYE cruel world!",
|
|
"if with zero does not show the contents");
|
|
});
|
|
|
|
it("if with function argument", <span class="fstat-no" title="function not covered" >function() {</span>
|
|
<span class="cstat-no" title="statement not covered" > var string = "{{#if goodbye}}GOODBYE {{/if}}cruel {{world}}!";</span>
|
|
<span class="cstat-no" title="statement not covered" > shouldCompileTo(string, {goodbye: <span class="fstat-no" title="function not covered" >function() {<span class="cstat-no" title="statement not covered" ></span>return true;}</span>, world: "world"}, "GOODBYE cruel world!",</span>
|
|
"if with function shows the contents when function returns true");
|
|
<span class="cstat-no" title="statement not covered" > shouldCompileTo(string, {goodbye: <span class="fstat-no" title="function not covered" >function() {<span class="cstat-no" title="statement not covered" ></span>return this.world;}</span>, world: "world"}, "GOODBYE cruel world!",</span>
|
|
"if with function shows the contents when function returns string");
|
|
<span class="cstat-no" title="statement not covered" > shouldCompileTo(string, {goodbye: <span class="fstat-no" title="function not covered" >function() {<span class="cstat-no" title="statement not covered" ></span>return false;}</span>, world: "world"}, "cruel world!",</span>
|
|
"if with function does not show the contents when returns false");
|
|
<span class="cstat-no" title="statement not covered" > shouldCompileTo(string, {goodbye: <span class="fstat-no" title="function not covered" >function() {<span class="cstat-no" title="statement not covered" ></span>return this.foo;}</span>, world: "world"}, "cruel world!",</span>
|
|
"if with function does not show the contents when returns undefined");
|
|
});
|
|
});
|
|
|
|
describe('#with', function() {
|
|
it("with", <span class="fstat-no" title="function not covered" >function() {</span>
|
|
<span class="cstat-no" title="statement not covered" > var string = "{{#with person}}{{first}} {{last}}{{/with}}";</span>
|
|
<span class="cstat-no" title="statement not covered" > shouldCompileTo(string, {person: {first: "Alan", last: "Johnson"}}, "Alan Johnson");</span>
|
|
});
|
|
it("with with function argument", <span class="fstat-no" title="function not covered" >function() {</span>
|
|
<span class="cstat-no" title="statement not covered" > var string = "{{#with person}}{{first}} {{last}}{{/with}}";</span>
|
|
<span class="cstat-no" title="statement not covered" > shouldCompileTo(string, {person: <span class="fstat-no" title="function not covered" >function() {</span> <span class="cstat-no" title="statement not covered" >return {first: "Alan", last: "Johnson"};}</span>}, "Alan Johnson");</span>
|
|
});
|
|
it("with with else", <span class="fstat-no" title="function not covered" >function() {</span>
|
|
<span class="cstat-no" title="statement not covered" > var string = "{{#with person}}Person is present{{else}}Person is not present{{/with}}";</span>
|
|
<span class="cstat-no" title="statement not covered" > shouldCompileTo(string, {}, "Person is not present");</span>
|
|
});
|
|
});
|
|
|
|
describe('#each', function() {
|
|
beforeEach(<span class="fstat-no" title="function not covered" >function() {</span>
|
|
<span class="cstat-no" title="statement not covered" > handlebarsEnv.registerHelper('detectDataInsideEach', <span class="fstat-no" title="function not covered" >function(options) {</span></span>
|
|
<span class="cstat-no" title="statement not covered" > return options.data && options.data.exclaim;</span>
|
|
});
|
|
});
|
|
|
|
it("each", <span class="fstat-no" title="function not covered" >function() {</span>
|
|
<span class="cstat-no" title="statement not covered" > var string = "{{#each goodbyes}}{{text}}! {{/each}}cruel {{world}}!";</span>
|
|
<span class="cstat-no" title="statement not covered" > var hash = {goodbyes: [{text: "goodbye"}, {text: "Goodbye"}, {text: "GOODBYE"}], world: "world"};</span>
|
|
<span class="cstat-no" title="statement not covered" > shouldCompileTo(string, hash, "goodbye! Goodbye! GOODBYE! cruel world!",</span>
|
|
"each with array argument iterates over the contents when not empty");
|
|
<span class="cstat-no" title="statement not covered" > shouldCompileTo(string, {goodbyes: [], world: "world"}, "cruel world!",</span>
|
|
"each with array argument ignores the contents when empty");
|
|
});
|
|
|
|
it("each with an object and @key", <span class="fstat-no" title="function not covered" >function() {</span>
|
|
<span class="cstat-no" title="statement not covered" > var string = "{{#each goodbyes}}{{@key}}. {{text}}! {{/each}}cruel {{world}}!";</span>
|
|
<span class="cstat-no" title="statement not covered" > var hash = {goodbyes: {"<b>#1</b>": {text: "goodbye"}, 2: {text: "GOODBYE"}}, world: "world"};</span>
|
|
|
|
// Object property iteration order is undefined according to ECMA spec,
|
|
// so we need to check both possible orders
|
|
// @see http://stackoverflow.com/questions/280713/elements-order-in-a-for-in-loop
|
|
<span class="cstat-no" title="statement not covered" > var actual = compileWithPartials(string, hash);</span>
|
|
<span class="cstat-no" title="statement not covered" > var expected1 = "&lt;b&gt;#1&lt;/b&gt;. goodbye! 2. GOODBYE! cruel world!";</span>
|
|
<span class="cstat-no" title="statement not covered" > var expected2 = "2. GOODBYE! &lt;b&gt;#1&lt;/b&gt;. goodbye! cruel world!";</span>
|
|
|
|
<span class="cstat-no" title="statement not covered" > equals(actual === expected1 || actual === expected2, true, "each with object argument iterates over the contents when not empty");</span>
|
|
<span class="cstat-no" title="statement not covered" > shouldCompileTo(string, {goodbyes: [], world: "world"}, "cruel world!",</span>
|
|
"each with object argument ignores the contents when empty");
|
|
});
|
|
|
|
it("each with @index", <span class="fstat-no" title="function not covered" >function() {</span>
|
|
<span class="cstat-no" title="statement not covered" > var string = "{{#each goodbyes}}{{@index}}. {{text}}! {{/each}}cruel {{world}}!";</span>
|
|
<span class="cstat-no" title="statement not covered" > var hash = {goodbyes: [{text: "goodbye"}, {text: "Goodbye"}, {text: "GOODBYE"}], world: "world"};</span>
|
|
|
|
<span class="cstat-no" title="statement not covered" > var template = CompilerContext.compile(string);</span>
|
|
<span class="cstat-no" title="statement not covered" > var result = template(hash);</span>
|
|
|
|
<span class="cstat-no" title="statement not covered" > equal(result, "0. goodbye! 1. Goodbye! 2. GOODBYE! cruel world!", "The @index variable is used");</span>
|
|
});
|
|
|
|
it("each with nested @index", <span class="fstat-no" title="function not covered" >function() {</span>
|
|
<span class="cstat-no" title="statement not covered" > var string = "{{#each goodbyes}}{{@index}}. {{text}}! {{#each ../goodbyes}}{{@index}} {{/each}}After {{@index}} {{/each}}{{@index}}cruel {{world}}!";</span>
|
|
<span class="cstat-no" title="statement not covered" > var hash = {goodbyes: [{text: "goodbye"}, {text: "Goodbye"}, {text: "GOODBYE"}], world: "world"};</span>
|
|
|
|
<span class="cstat-no" title="statement not covered" > var template = CompilerContext.compile(string);</span>
|
|
<span class="cstat-no" title="statement not covered" > var result = template(hash);</span>
|
|
|
|
<span class="cstat-no" title="statement not covered" > equal(result, "0. goodbye! 0 1 2 After 0 1. Goodbye! 0 1 2 After 1 2. GOODBYE! 0 1 2 After 2 cruel world!", "The @index variable is used");</span>
|
|
});
|
|
|
|
it("each object with @index", <span class="fstat-no" title="function not covered" >function() {</span>
|
|
<span class="cstat-no" title="statement not covered" > var string = "{{#each goodbyes}}{{@index}}. {{text}}! {{/each}}cruel {{world}}!";</span>
|
|
<span class="cstat-no" title="statement not covered" > var hash = {goodbyes: {'a': {text: "goodbye"}, b: {text: "Goodbye"}, c: {text: "GOODBYE"}}, world: "world"};</span>
|
|
|
|
<span class="cstat-no" title="statement not covered" > var template = CompilerContext.compile(string);</span>
|
|
<span class="cstat-no" title="statement not covered" > var result = template(hash);</span>
|
|
|
|
<span class="cstat-no" title="statement not covered" > equal(result, "0. goodbye! 1. Goodbye! 2. GOODBYE! cruel world!", "The @index variable is used");</span>
|
|
});
|
|
|
|
|
|
it("each with @first", <span class="fstat-no" title="function not covered" >function() {</span>
|
|
<span class="cstat-no" title="statement not covered" > var string = "{{#each goodbyes}}{{#if @first}}{{text}}! {{/if}}{{/each}}cruel {{world}}!";</span>
|
|
<span class="cstat-no" title="statement not covered" > var hash = {goodbyes: [{text: "goodbye"}, {text: "Goodbye"}, {text: "GOODBYE"}], world: "world"};</span>
|
|
|
|
<span class="cstat-no" title="statement not covered" > var template = CompilerContext.compile(string);</span>
|
|
<span class="cstat-no" title="statement not covered" > var result = template(hash);</span>
|
|
|
|
<span class="cstat-no" title="statement not covered" > equal(result, "goodbye! cruel world!", "The @first variable is used");</span>
|
|
});
|
|
|
|
it("each with nested @first", <span class="fstat-no" title="function not covered" >function() {</span>
|
|
<span class="cstat-no" title="statement not covered" > var string = "{{#each goodbyes}}({{#if @first}}{{text}}! {{/if}}{{#each ../goodbyes}}{{#if @first}}{{text}}!{{/if}}{{/each}}{{#if @first}} {{text}}!{{/if}}) {{/each}}cruel {{world}}!";</span>
|
|
<span class="cstat-no" title="statement not covered" > var hash = {goodbyes: [{text: "goodbye"}, {text: "Goodbye"}, {text: "GOODBYE"}], world: "world"};</span>
|
|
|
|
<span class="cstat-no" title="statement not covered" > var template = CompilerContext.compile(string);</span>
|
|
<span class="cstat-no" title="statement not covered" > var result = template(hash);</span>
|
|
|
|
<span class="cstat-no" title="statement not covered" > equal(result, "(goodbye! goodbye! goodbye!) (goodbye!) (goodbye!) cruel world!", "The @first variable is used");</span>
|
|
});
|
|
|
|
it("each object with @first", <span class="fstat-no" title="function not covered" >function() {</span>
|
|
<span class="cstat-no" title="statement not covered" > var string = "{{#each goodbyes}}{{#if @first}}{{text}}! {{/if}}{{/each}}cruel {{world}}!";</span>
|
|
<span class="cstat-no" title="statement not covered" > var hash = {goodbyes: {'foo': {text: "goodbye"}, bar: {text: "Goodbye"}}, world: "world"};</span>
|
|
|
|
<span class="cstat-no" title="statement not covered" > var template = CompilerContext.compile(string);</span>
|
|
<span class="cstat-no" title="statement not covered" > var result = template(hash);</span>
|
|
|
|
<span class="cstat-no" title="statement not covered" > equal(result, "goodbye! cruel world!", "The @first variable is used");</span>
|
|
});
|
|
|
|
it("each with @last", <span class="fstat-no" title="function not covered" >function() {</span>
|
|
<span class="cstat-no" title="statement not covered" > var string = "{{#each goodbyes}}{{#if @last}}{{text}}! {{/if}}{{/each}}cruel {{world}}!";</span>
|
|
<span class="cstat-no" title="statement not covered" > var hash = {goodbyes: [{text: "goodbye"}, {text: "Goodbye"}, {text: "GOODBYE"}], world: "world"};</span>
|
|
|
|
<span class="cstat-no" title="statement not covered" > var template = CompilerContext.compile(string);</span>
|
|
<span class="cstat-no" title="statement not covered" > var result = template(hash);</span>
|
|
|
|
<span class="cstat-no" title="statement not covered" > equal(result, "GOODBYE! cruel world!", "The @last variable is used");</span>
|
|
});
|
|
|
|
it("each with nested @last", <span class="fstat-no" title="function not covered" >function() {</span>
|
|
<span class="cstat-no" title="statement not covered" > var string = "{{#each goodbyes}}({{#if @last}}{{text}}! {{/if}}{{#each ../goodbyes}}{{#if @last}}{{text}}!{{/if}}{{/each}}{{#if @last}} {{text}}!{{/if}}) {{/each}}cruel {{world}}!";</span>
|
|
<span class="cstat-no" title="statement not covered" > var hash = {goodbyes: [{text: "goodbye"}, {text: "Goodbye"}, {text: "GOODBYE"}], world: "world"};</span>
|
|
|
|
<span class="cstat-no" title="statement not covered" > var template = CompilerContext.compile(string);</span>
|
|
<span class="cstat-no" title="statement not covered" > var result = template(hash);</span>
|
|
|
|
<span class="cstat-no" title="statement not covered" > equal(result, "(GOODBYE!) (GOODBYE!) (GOODBYE! GOODBYE! GOODBYE!) cruel world!", "The @last variable is used");</span>
|
|
});
|
|
|
|
it("each with function argument", <span class="fstat-no" title="function not covered" >function() {</span>
|
|
<span class="cstat-no" title="statement not covered" > var string = "{{#each goodbyes}}{{text}}! {{/each}}cruel {{world}}!";</span>
|
|
<span class="cstat-no" title="statement not covered" > var hash = {goodbyes: <span class="fstat-no" title="function not covered" >function () {</span> <span class="cstat-no" title="statement not covered" >return [{text: "goodbye"}, {text: "Goodbye"}, {text: "GOODBYE"}];}</span>, world: "world"};</span>
|
|
<span class="cstat-no" title="statement not covered" > shouldCompileTo(string, hash, "goodbye! Goodbye! GOODBYE! cruel world!",</span>
|
|
"each with array function argument iterates over the contents when not empty");
|
|
<span class="cstat-no" title="statement not covered" > shouldCompileTo(string, {goodbyes: [], world: "world"}, "cruel world!",</span>
|
|
"each with array function argument ignores the contents when empty");
|
|
});
|
|
|
|
it("data passed to helpers", <span class="fstat-no" title="function not covered" >function() {</span>
|
|
<span class="cstat-no" title="statement not covered" > var string = "{{#each letters}}{{this}}{{detectDataInsideEach}}{{/each}}";</span>
|
|
<span class="cstat-no" title="statement not covered" > var hash = {letters: ['a', 'b', 'c']};</span>
|
|
|
|
<span class="cstat-no" title="statement not covered" > var template = CompilerContext.compile(string);</span>
|
|
<span class="cstat-no" title="statement not covered" > var result = template(hash, {</span>
|
|
data: {
|
|
exclaim: '!'
|
|
}
|
|
});
|
|
<span class="cstat-no" title="statement not covered" > equal(result, 'a!b!c!', 'should output data');</span>
|
|
});
|
|
|
|
it("each on implicit context", <span class="fstat-no" title="function not covered" >function() {</span>
|
|
<span class="cstat-no" title="statement not covered" > shouldThrow(<span class="fstat-no" title="function not covered" >function() {</span></span>
|
|
<span class="cstat-no" title="statement not covered" > var template = CompilerContext.compile("{{#each}}{{text}}! {{/each}}cruel world!");</span>
|
|
<span class="cstat-no" title="statement not covered" > template({});</span>
|
|
}, handlebarsEnv.Exception, 'Must pass iterator to #each');
|
|
});
|
|
});
|
|
|
|
it("#log", <span class="fstat-no" title="function not covered" >function() {</span>
|
|
<span class="cstat-no" title="statement not covered" > var string = "{{log blah}}";</span>
|
|
<span class="cstat-no" title="statement not covered" > var hash = { blah: "whee" };</span>
|
|
|
|
<span class="cstat-no" title="statement not covered" > var levelArg, logArg;</span>
|
|
<span class="cstat-no" title="statement not covered" > handlebarsEnv.log = <span class="fstat-no" title="function not covered" >function(level, arg){</span></span>
|
|
<span class="cstat-no" title="statement not covered" > levelArg = level;</span>
|
|
<span class="cstat-no" title="statement not covered" > logArg = arg;</span>
|
|
};
|
|
|
|
<span class="cstat-no" title="statement not covered" > shouldCompileTo(string, hash, "", "log should not display");</span>
|
|
<span class="cstat-no" title="statement not covered" > equals(1, levelArg, "should call log with 1");</span>
|
|
<span class="cstat-no" title="statement not covered" > equals("whee", logArg, "should call log with 'whee'");</span>
|
|
});
|
|
|
|
|
|
describe('#lookup', function() {
|
|
it('should lookup arbitrary content', <span class="fstat-no" title="function not covered" >function() {</span>
|
|
<span class="cstat-no" title="statement not covered" > var string = '{{#each goodbyes}}{{lookup ../data .}}{{/each}}',</span>
|
|
hash = {goodbyes: [0, 1], data: ['foo', 'bar']};
|
|
|
|
<span class="cstat-no" title="statement not covered" > var template = CompilerContext.compile(string);</span>
|
|
<span class="cstat-no" title="statement not covered" > var result = template(hash);</span>
|
|
|
|
<span class="cstat-no" title="statement not covered" > equal(result, 'foobar');</span>
|
|
});
|
|
it('should not fail on undefined value', <span class="fstat-no" title="function not covered" >function() {</span>
|
|
<span class="cstat-no" title="statement not covered" > var string = '{{#each goodbyes}}{{lookup ../bar .}}{{/each}}',</span>
|
|
hash = {goodbyes: [0, 1], data: ['foo', 'bar']};
|
|
|
|
<span class="cstat-no" title="statement not covered" > var template = CompilerContext.compile(string);</span>
|
|
<span class="cstat-no" title="statement not covered" > var result = template(hash);</span>
|
|
|
|
<span class="cstat-no" title="statement not covered" > equal(result, '');</span>
|
|
});
|
|
});
|
|
});
|
|
</pre></td></tr>
|
|
</table></pre>
|
|
|
|
</div>
|
|
<div class="footer">
|
|
<div class="meta">Generated by <a href="http://istanbul-js.org/" target="_blank">istanbul</a> at Wed Aug 13 2014 23:50:21 GMT-0500 (CDT)</div>
|
|
</div>
|
|
|
|
<script src="../prettify.js"></script>
|
|
|
|
<script src="https://yui-s.yahooapis.com/3.6.0/build/yui/yui-min.js"></script>
|
|
<script>
|
|
|
|
YUI().use('datatable', function (Y) {
|
|
|
|
var formatters = {
|
|
pct: function (o) {
|
|
o.className += o.record.get('classes')[o.column.key];
|
|
try {
|
|
return o.value.toFixed(2) + '%';
|
|
} catch (ex) { return o.value + '%'; }
|
|
},
|
|
html: function (o) {
|
|
o.className += o.record.get('classes')[o.column.key];
|
|
return o.record.get(o.column.key + '_html');
|
|
}
|
|
},
|
|
defaultFormatter = function (o) {
|
|
o.className += o.record.get('classes')[o.column.key];
|
|
return o.value;
|
|
};
|
|
|
|
function getColumns(theadNode) {
|
|
var colNodes = theadNode.all('tr th'),
|
|
cols = [],
|
|
col;
|
|
colNodes.each(function (colNode) {
|
|
col = {
|
|
key: colNode.getAttribute('data-col'),
|
|
label: colNode.get('innerHTML') || ' ',
|
|
sortable: !colNode.getAttribute('data-nosort'),
|
|
className: colNode.getAttribute('class'),
|
|
type: colNode.getAttribute('data-type'),
|
|
allowHTML: colNode.getAttribute('data-html') === 'true' || colNode.getAttribute('data-fmt') === 'html'
|
|
};
|
|
col.formatter = formatters[colNode.getAttribute('data-fmt')] || defaultFormatter;
|
|
cols.push(col);
|
|
});
|
|
return cols;
|
|
}
|
|
|
|
function getRowData(trNode, cols) {
|
|
var tdNodes = trNode.all('td'),
|
|
i,
|
|
row = { classes: {} },
|
|
node,
|
|
name;
|
|
for (i = 0; i < cols.length; i += 1) {
|
|
name = cols[i].key;
|
|
node = tdNodes.item(i);
|
|
row[name] = node.getAttribute('data-value') || node.get('innerHTML');
|
|
row[name + '_html'] = node.get('innerHTML');
|
|
row.classes[name] = node.getAttribute('class');
|
|
//Y.log('Name: ' + name + '; Value: ' + row[name]);
|
|
if (cols[i].type === 'number') { row[name] = row[name] * 1; }
|
|
}
|
|
//Y.log(row);
|
|
return row;
|
|
}
|
|
|
|
function getData(tbodyNode, cols) {
|
|
var data = [];
|
|
tbodyNode.all('tr').each(function (trNode) {
|
|
data.push(getRowData(trNode, cols));
|
|
});
|
|
return data;
|
|
}
|
|
|
|
function replaceTable(node) {
|
|
if (!node) { return; }
|
|
var cols = getColumns(node.one('thead')),
|
|
data = getData(node.one('tbody'), cols),
|
|
table,
|
|
parent = node.get('parentNode');
|
|
|
|
table = new Y.DataTable({
|
|
columns: cols,
|
|
data: data,
|
|
sortBy: 'file'
|
|
});
|
|
parent.set('innerHTML', '');
|
|
table.render(parent);
|
|
}
|
|
|
|
Y.on('domready', function () {
|
|
replaceTable(Y.one('div.coverage-summary table'));
|
|
if (typeof prettyPrint === 'function') {
|
|
prettyPrint();
|
|
}
|
|
});
|
|
});
|
|
</script>
|
|
</body>
|
|
</html>
|