@hygiene/core
Version:
Keep your TODOs and FIXMEs healthy
183 lines (182 loc) • 6.23 kB
HTML
<html lang="en">
<head>
<title>Code coverage report for parseText.ts</title>
<meta charset="utf-8" />
<link rel="stylesheet" href="prettify.css" />
<link rel="stylesheet" href="base.css" />
<meta name="viewport" content="width=device-width, initial-scale=1">
<style type='text/css'>
.coverage-summary .sorter {
background-image: url(sort-arrow-sprite.png);
}
</style>
</head>
<body>
<div class='wrapper'>
<div class='pad1'>
<h1>
<a href="index.html">All files</a> parseText.ts
</h1>
<div class='clearfix'>
<div class='fl pad1y space-right2'>
<span class="strong">0% </span>
<span class="quiet">Statements</span>
<span class='fraction'>0/10</span>
</div>
<div class='fl pad1y space-right2'>
<span class="strong">0% </span>
<span class="quiet">Branches</span>
<span class='fraction'>0/2</span>
</div>
<div class='fl pad1y space-right2'>
<span class="strong">0% </span>
<span class="quiet">Functions</span>
<span class='fraction'>0/4</span>
</div>
<div class='fl pad1y space-right2'>
<span class="strong">0% </span>
<span class="quiet">Lines</span>
<span class='fraction'>0/9</span>
</div>
</div>
</div>
<div class='status-line low'></div>
<pre><table class="coverage">
<tr><td class="line-count quiet">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</td><td class="line-coverage quiet"><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-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-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-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-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-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-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-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-neutral"> </span>
<span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js"><span class="cstat-no" title="statement not covered" >import * as leasot from "leasot";</span>
<span class="cstat-no" title="statement not covered" >import { codeFrameColumns } from "@babel/code-frame";</span>
import { AnnotatedComment } from "./AnnotatedComment";
import { Plugin } from "./Plugin";
<span class="cstat-no" title="statement not covered" >export function <span class="fstat-no" title="function not covered" >parseText<</span>T>(</span>
content: string,
filename: string,
extension: string,
bodyParser: Plugin<any, any>["parse"]
): Promise<AnnotatedComment<T>[]> {
<span class="cstat-no" title="statement not covered" > if (!leasot.isExtensionSupported(extension)) {</span>
<span class="cstat-no" title="statement not covered" > return Promise.resolve([]);</span>
}
const promises = <span class="cstat-no" title="statement not covered" >leasot</span>
.parse(content, {
extension,
filename,
withInlineFiles: true
})
.map(
<span class="fstat-no" title="function not covered" > async</span> (todoComment): Promise<AnnotatedComment<T>> => (<span class="cstat-no" title="statement not covered" >{</span>
kind: todoComment.tag,
file: todoComment.file,
line: todoComment.line,
text: todoComment.text,
codeFrame: codeFrameColumns(content, {
start: { line: todoComment.line }
}),
// @ts-ignore Filter annotation is missing immediately
annotation: await bodyParser(todoComment.text)
})
);
<span class="cstat-no" title="statement not covered" > return Promise.all(promises).then(<span class="fstat-no" title="function not covered" >comments</span> =></span>
<span class="cstat-no" title="statement not covered" > comments.filter(<span class="fstat-no" title="function not covered" >comment</span> => <span class="cstat-no" title="statement not covered" >!!comment.annotation)</span></span>
);
}
</pre></td></tr>
</table></pre>
<div class='push'></div><!-- for sticky footer -->
</div><!-- /wrapper -->
<div class='footer quiet pad2 space-top1 center small'>
Code coverage
generated by <a href="https://istanbul.js.org/" target="_blank">istanbul</a> at Sun Dec 30 2018 20:34:55 GMT+0900 (JST)
</div>
</div>
<script src="prettify.js"></script>
<script>
window.onload = function () {
if (typeof prettyPrint === 'function') {
prettyPrint();
}
};
</script>
<script src="sorter.js"></script>
</body>
</html>