manner.js 0.0.47 → 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/client/index.js +34 -0
- package/client/lib/clearCookie.js +20 -0
- package/client/lib/filterNamespace.js +15 -0
- package/client/lib/readCookie.js +38 -0
- package/client/lib/setCookie.js +25 -0
- package/coverage/clover.xml +50 -15
- package/coverage/coverage-final.json +2 -1
- package/coverage/lcov-report/class/MultiFetch.js.html +241 -0
- package/coverage/lcov-report/class/index.html +116 -0
- package/coverage/lcov-report/formatHttpDate.js.html +1 -1
- package/coverage/lcov-report/formatHttpKey.js.html +1 -1
- package/coverage/lcov-report/index.html +22 -22
- package/coverage/lcov-report/lib/formatHttpDate.js.html +106 -0
- package/coverage/lcov-report/lib/formatHttpKey.js.html +100 -0
- package/coverage/lcov-report/lib/index.html +131 -0
- package/coverage/lcov.info +53 -0
- package/index.js +5 -0
- package/package.json +2 -1
- package/server/class/MultiFetch.js +63 -0
- package/server/index.js +27 -0
- package/server/lib/formatHttpDate.js +12 -0
- package/server/lib/formatHttpKey.js +11 -0
- package/server/lib/readCookie.js +27 -0
|
@@ -23,30 +23,30 @@
|
|
|
23
23
|
<div class='clearfix'>
|
|
24
24
|
|
|
25
25
|
<div class='fl pad1y space-right2'>
|
|
26
|
-
<span class="strong">
|
|
26
|
+
<span class="strong">81.25% </span>
|
|
27
27
|
<span class="quiet">Statements</span>
|
|
28
|
-
<span class='fraction'>
|
|
28
|
+
<span class='fraction'>26/32</span>
|
|
29
29
|
</div>
|
|
30
30
|
|
|
31
31
|
|
|
32
32
|
<div class='fl pad1y space-right2'>
|
|
33
|
-
<span class="strong">
|
|
33
|
+
<span class="strong">50% </span>
|
|
34
34
|
<span class="quiet">Branches</span>
|
|
35
|
-
<span class='fraction'>
|
|
35
|
+
<span class='fraction'>6/12</span>
|
|
36
36
|
</div>
|
|
37
37
|
|
|
38
38
|
|
|
39
39
|
<div class='fl pad1y space-right2'>
|
|
40
40
|
<span class="strong">100% </span>
|
|
41
41
|
<span class="quiet">Functions</span>
|
|
42
|
-
<span class='fraction'>
|
|
42
|
+
<span class='fraction'>6/6</span>
|
|
43
43
|
</div>
|
|
44
44
|
|
|
45
45
|
|
|
46
46
|
<div class='fl pad1y space-right2'>
|
|
47
|
-
<span class="strong">
|
|
47
|
+
<span class="strong">81.25% </span>
|
|
48
48
|
<span class="quiet">Lines</span>
|
|
49
|
-
<span class='fraction'>
|
|
49
|
+
<span class='fraction'>26/32</span>
|
|
50
50
|
</div>
|
|
51
51
|
|
|
52
52
|
|
|
@@ -79,33 +79,33 @@
|
|
|
79
79
|
</tr>
|
|
80
80
|
</thead>
|
|
81
81
|
<tbody><tr>
|
|
82
|
-
<td class="file
|
|
83
|
-
<td data-value="
|
|
84
|
-
<div class="chart"><div class="cover-fill
|
|
82
|
+
<td class="file medium" data-value="class"><a href="class/index.html">class</a></td>
|
|
83
|
+
<td data-value="76.92" class="pic medium">
|
|
84
|
+
<div class="chart"><div class="cover-fill" style="width: 76%"></div><div class="cover-empty" style="width: 24%"></div></div>
|
|
85
85
|
</td>
|
|
86
|
+
<td data-value="76.92" class="pct medium">76.92%</td>
|
|
87
|
+
<td data-value="26" class="abs medium">20/26</td>
|
|
88
|
+
<td data-value="50" class="pct medium">50%</td>
|
|
89
|
+
<td data-value="12" class="abs medium">6/12</td>
|
|
86
90
|
<td data-value="100" class="pct high">100%</td>
|
|
87
|
-
<td data-value="
|
|
88
|
-
<td data-value="
|
|
89
|
-
<td data-value="
|
|
90
|
-
<td data-value="100" class="pct high">100%</td>
|
|
91
|
-
<td data-value="1" class="abs high">1/1</td>
|
|
92
|
-
<td data-value="100" class="pct high">100%</td>
|
|
93
|
-
<td data-value="4" class="abs high">4/4</td>
|
|
91
|
+
<td data-value="3" class="abs high">3/3</td>
|
|
92
|
+
<td data-value="76.92" class="pct medium">76.92%</td>
|
|
93
|
+
<td data-value="26" class="abs medium">20/26</td>
|
|
94
94
|
</tr>
|
|
95
95
|
|
|
96
96
|
<tr>
|
|
97
|
-
<td class="file high" data-value="
|
|
97
|
+
<td class="file high" data-value="lib"><a href="lib/index.html">lib</a></td>
|
|
98
98
|
<td data-value="100" class="pic high">
|
|
99
99
|
<div class="chart"><div class="cover-fill cover-full" style="width: 100%"></div><div class="cover-empty" style="width: 0%"></div></div>
|
|
100
100
|
</td>
|
|
101
101
|
<td data-value="100" class="pct high">100%</td>
|
|
102
|
-
<td data-value="
|
|
102
|
+
<td data-value="6" class="abs high">6/6</td>
|
|
103
103
|
<td data-value="100" class="pct high">100%</td>
|
|
104
104
|
<td data-value="0" class="abs high">0/0</td>
|
|
105
105
|
<td data-value="100" class="pct high">100%</td>
|
|
106
|
-
<td data-value="
|
|
106
|
+
<td data-value="3" class="abs high">3/3</td>
|
|
107
107
|
<td data-value="100" class="pct high">100%</td>
|
|
108
|
-
<td data-value="
|
|
108
|
+
<td data-value="6" class="abs high">6/6</td>
|
|
109
109
|
</tr>
|
|
110
110
|
|
|
111
111
|
</tbody>
|
|
@@ -116,7 +116,7 @@
|
|
|
116
116
|
<div class='footer quiet pad2 space-top1 center small'>
|
|
117
117
|
Code coverage generated by
|
|
118
118
|
<a href="https://istanbul.js.org/" target="_blank" rel="noopener noreferrer">istanbul</a>
|
|
119
|
-
at 2025-06-
|
|
119
|
+
at 2025-06-02T09:47:44.080Z
|
|
120
120
|
</div>
|
|
121
121
|
<script src="prettify.js"></script>
|
|
122
122
|
<script>
|
|
@@ -0,0 +1,106 @@
|
|
|
1
|
+
|
|
2
|
+
<!doctype html>
|
|
3
|
+
<html lang="en">
|
|
4
|
+
|
|
5
|
+
<head>
|
|
6
|
+
<title>Code coverage report for lib/formatHttpDate.js</title>
|
|
7
|
+
<meta charset="utf-8" />
|
|
8
|
+
<link rel="stylesheet" href="../prettify.css" />
|
|
9
|
+
<link rel="stylesheet" href="../base.css" />
|
|
10
|
+
<link rel="shortcut icon" type="image/x-icon" href="../favicon.png" />
|
|
11
|
+
<meta name="viewport" content="width=device-width, initial-scale=1" />
|
|
12
|
+
<style type='text/css'>
|
|
13
|
+
.coverage-summary .sorter {
|
|
14
|
+
background-image: url(../sort-arrow-sprite.png);
|
|
15
|
+
}
|
|
16
|
+
</style>
|
|
17
|
+
</head>
|
|
18
|
+
|
|
19
|
+
<body>
|
|
20
|
+
<div class='wrapper'>
|
|
21
|
+
<div class='pad1'>
|
|
22
|
+
<h1><a href="../index.html">All files</a> / <a href="index.html">lib</a> formatHttpDate.js</h1>
|
|
23
|
+
<div class='clearfix'>
|
|
24
|
+
|
|
25
|
+
<div class='fl pad1y space-right2'>
|
|
26
|
+
<span class="strong">100% </span>
|
|
27
|
+
<span class="quiet">Statements</span>
|
|
28
|
+
<span class='fraction'>4/4</span>
|
|
29
|
+
</div>
|
|
30
|
+
|
|
31
|
+
|
|
32
|
+
<div class='fl pad1y space-right2'>
|
|
33
|
+
<span class="strong">100% </span>
|
|
34
|
+
<span class="quiet">Branches</span>
|
|
35
|
+
<span class='fraction'>0/0</span>
|
|
36
|
+
</div>
|
|
37
|
+
|
|
38
|
+
|
|
39
|
+
<div class='fl pad1y space-right2'>
|
|
40
|
+
<span class="strong">100% </span>
|
|
41
|
+
<span class="quiet">Functions</span>
|
|
42
|
+
<span class='fraction'>1/1</span>
|
|
43
|
+
</div>
|
|
44
|
+
|
|
45
|
+
|
|
46
|
+
<div class='fl pad1y space-right2'>
|
|
47
|
+
<span class="strong">100% </span>
|
|
48
|
+
<span class="quiet">Lines</span>
|
|
49
|
+
<span class='fraction'>4/4</span>
|
|
50
|
+
</div>
|
|
51
|
+
|
|
52
|
+
|
|
53
|
+
</div>
|
|
54
|
+
<p class="quiet">
|
|
55
|
+
Press <em>n</em> or <em>j</em> to go to the next uncovered block, <em>b</em>, <em>p</em> or <em>k</em> for the previous block.
|
|
56
|
+
</p>
|
|
57
|
+
<template id="filterTemplate">
|
|
58
|
+
<div class="quiet">
|
|
59
|
+
Filter:
|
|
60
|
+
<input type="search" id="fileSearch">
|
|
61
|
+
</div>
|
|
62
|
+
</template>
|
|
63
|
+
</div>
|
|
64
|
+
<div class='status-line high'></div>
|
|
65
|
+
<pre><table class="coverage">
|
|
66
|
+
<tr><td class="line-count quiet"><a name='L1'></a><a href='#L1'>1</a>
|
|
67
|
+
<a name='L2'></a><a href='#L2'>2</a>
|
|
68
|
+
<a name='L3'></a><a href='#L3'>3</a>
|
|
69
|
+
<a name='L4'></a><a href='#L4'>4</a>
|
|
70
|
+
<a name='L5'></a><a href='#L5'>5</a>
|
|
71
|
+
<a name='L6'></a><a href='#L6'>6</a>
|
|
72
|
+
<a name='L7'></a><a href='#L7'>7</a>
|
|
73
|
+
<a name='L8'></a><a href='#L8'>8</a></td><td class="line-coverage quiet"><span class="cline-any cline-neutral"> </span>
|
|
74
|
+
<span class="cline-any cline-yes">1x</span>
|
|
75
|
+
<span class="cline-any cline-yes">1x</span>
|
|
76
|
+
<span class="cline-any cline-yes">1x</span>
|
|
77
|
+
<span class="cline-any cline-yes">1x</span>
|
|
78
|
+
<span class="cline-any cline-neutral"> </span>
|
|
79
|
+
<span class="cline-any cline-neutral"> </span>
|
|
80
|
+
<span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">export default function formatHttpDate(ms) {
|
|
81
|
+
const date = new Date(ms);
|
|
82
|
+
let [week, month, day, year, time, zone] = date.toString().split(' ');
|
|
83
|
+
zone = zone.split('+')[0];
|
|
84
|
+
return week + ', ' + day + ' ' + month + ' ' + year + ' ' + time + ' ' + zone;
|
|
85
|
+
}
|
|
86
|
+
|
|
87
|
+
</pre></td></tr></table></pre>
|
|
88
|
+
|
|
89
|
+
<div class='push'></div><!-- for sticky footer -->
|
|
90
|
+
</div><!-- /wrapper -->
|
|
91
|
+
<div class='footer quiet pad2 space-top1 center small'>
|
|
92
|
+
Code coverage generated by
|
|
93
|
+
<a href="https://istanbul.js.org/" target="_blank" rel="noopener noreferrer">istanbul</a>
|
|
94
|
+
at 2025-06-02T09:47:44.080Z
|
|
95
|
+
</div>
|
|
96
|
+
<script src="../prettify.js"></script>
|
|
97
|
+
<script>
|
|
98
|
+
window.onload = function () {
|
|
99
|
+
prettyPrint();
|
|
100
|
+
};
|
|
101
|
+
</script>
|
|
102
|
+
<script src="../sorter.js"></script>
|
|
103
|
+
<script src="../block-navigation.js"></script>
|
|
104
|
+
</body>
|
|
105
|
+
</html>
|
|
106
|
+
|
|
@@ -0,0 +1,100 @@
|
|
|
1
|
+
|
|
2
|
+
<!doctype html>
|
|
3
|
+
<html lang="en">
|
|
4
|
+
|
|
5
|
+
<head>
|
|
6
|
+
<title>Code coverage report for lib/formatHttpKey.js</title>
|
|
7
|
+
<meta charset="utf-8" />
|
|
8
|
+
<link rel="stylesheet" href="../prettify.css" />
|
|
9
|
+
<link rel="stylesheet" href="../base.css" />
|
|
10
|
+
<link rel="shortcut icon" type="image/x-icon" href="../favicon.png" />
|
|
11
|
+
<meta name="viewport" content="width=device-width, initial-scale=1" />
|
|
12
|
+
<style type='text/css'>
|
|
13
|
+
.coverage-summary .sorter {
|
|
14
|
+
background-image: url(../sort-arrow-sprite.png);
|
|
15
|
+
}
|
|
16
|
+
</style>
|
|
17
|
+
</head>
|
|
18
|
+
|
|
19
|
+
<body>
|
|
20
|
+
<div class='wrapper'>
|
|
21
|
+
<div class='pad1'>
|
|
22
|
+
<h1><a href="../index.html">All files</a> / <a href="index.html">lib</a> formatHttpKey.js</h1>
|
|
23
|
+
<div class='clearfix'>
|
|
24
|
+
|
|
25
|
+
<div class='fl pad1y space-right2'>
|
|
26
|
+
<span class="strong">100% </span>
|
|
27
|
+
<span class="quiet">Statements</span>
|
|
28
|
+
<span class='fraction'>2/2</span>
|
|
29
|
+
</div>
|
|
30
|
+
|
|
31
|
+
|
|
32
|
+
<div class='fl pad1y space-right2'>
|
|
33
|
+
<span class="strong">100% </span>
|
|
34
|
+
<span class="quiet">Branches</span>
|
|
35
|
+
<span class='fraction'>0/0</span>
|
|
36
|
+
</div>
|
|
37
|
+
|
|
38
|
+
|
|
39
|
+
<div class='fl pad1y space-right2'>
|
|
40
|
+
<span class="strong">100% </span>
|
|
41
|
+
<span class="quiet">Functions</span>
|
|
42
|
+
<span class='fraction'>2/2</span>
|
|
43
|
+
</div>
|
|
44
|
+
|
|
45
|
+
|
|
46
|
+
<div class='fl pad1y space-right2'>
|
|
47
|
+
<span class="strong">100% </span>
|
|
48
|
+
<span class="quiet">Lines</span>
|
|
49
|
+
<span class='fraction'>2/2</span>
|
|
50
|
+
</div>
|
|
51
|
+
|
|
52
|
+
|
|
53
|
+
</div>
|
|
54
|
+
<p class="quiet">
|
|
55
|
+
Press <em>n</em> or <em>j</em> to go to the next uncovered block, <em>b</em>, <em>p</em> or <em>k</em> for the previous block.
|
|
56
|
+
</p>
|
|
57
|
+
<template id="filterTemplate">
|
|
58
|
+
<div class="quiet">
|
|
59
|
+
Filter:
|
|
60
|
+
<input type="search" id="fileSearch">
|
|
61
|
+
</div>
|
|
62
|
+
</template>
|
|
63
|
+
</div>
|
|
64
|
+
<div class='status-line high'></div>
|
|
65
|
+
<pre><table class="coverage">
|
|
66
|
+
<tr><td class="line-count quiet"><a name='L1'></a><a href='#L1'>1</a>
|
|
67
|
+
<a name='L2'></a><a href='#L2'>2</a>
|
|
68
|
+
<a name='L3'></a><a href='#L3'>3</a>
|
|
69
|
+
<a name='L4'></a><a href='#L4'>4</a>
|
|
70
|
+
<a name='L5'></a><a href='#L5'>5</a>
|
|
71
|
+
<a name='L6'></a><a href='#L6'>6</a></td><td class="line-coverage quiet"><span class="cline-any cline-neutral"> </span>
|
|
72
|
+
<span class="cline-any cline-yes">1x</span>
|
|
73
|
+
<span class="cline-any cline-yes">2x</span>
|
|
74
|
+
<span class="cline-any cline-neutral"> </span>
|
|
75
|
+
<span class="cline-any cline-neutral"> </span>
|
|
76
|
+
<span class="cline-any cline-neutral"> </span></td><td class="text"><pre class="prettyprint lang-js">export default function formatHttpKey(key) {
|
|
77
|
+
return key.split('-').map((v) => {
|
|
78
|
+
return v.substring(0, 1).toUpperCase() + v.substring(1, v.length);
|
|
79
|
+
}).join('-');
|
|
80
|
+
}
|
|
81
|
+
</pre></td></tr></table></pre>
|
|
82
|
+
|
|
83
|
+
<div class='push'></div><!-- for sticky footer -->
|
|
84
|
+
</div><!-- /wrapper -->
|
|
85
|
+
<div class='footer quiet pad2 space-top1 center small'>
|
|
86
|
+
Code coverage generated by
|
|
87
|
+
<a href="https://istanbul.js.org/" target="_blank" rel="noopener noreferrer">istanbul</a>
|
|
88
|
+
at 2025-06-02T09:47:44.080Z
|
|
89
|
+
</div>
|
|
90
|
+
<script src="../prettify.js"></script>
|
|
91
|
+
<script>
|
|
92
|
+
window.onload = function () {
|
|
93
|
+
prettyPrint();
|
|
94
|
+
};
|
|
95
|
+
</script>
|
|
96
|
+
<script src="../sorter.js"></script>
|
|
97
|
+
<script src="../block-navigation.js"></script>
|
|
98
|
+
</body>
|
|
99
|
+
</html>
|
|
100
|
+
|
|
@@ -0,0 +1,131 @@
|
|
|
1
|
+
|
|
2
|
+
<!doctype html>
|
|
3
|
+
<html lang="en">
|
|
4
|
+
|
|
5
|
+
<head>
|
|
6
|
+
<title>Code coverage report for lib</title>
|
|
7
|
+
<meta charset="utf-8" />
|
|
8
|
+
<link rel="stylesheet" href="../prettify.css" />
|
|
9
|
+
<link rel="stylesheet" href="../base.css" />
|
|
10
|
+
<link rel="shortcut icon" type="image/x-icon" href="../favicon.png" />
|
|
11
|
+
<meta name="viewport" content="width=device-width, initial-scale=1" />
|
|
12
|
+
<style type='text/css'>
|
|
13
|
+
.coverage-summary .sorter {
|
|
14
|
+
background-image: url(../sort-arrow-sprite.png);
|
|
15
|
+
}
|
|
16
|
+
</style>
|
|
17
|
+
</head>
|
|
18
|
+
|
|
19
|
+
<body>
|
|
20
|
+
<div class='wrapper'>
|
|
21
|
+
<div class='pad1'>
|
|
22
|
+
<h1><a href="../index.html">All files</a> lib</h1>
|
|
23
|
+
<div class='clearfix'>
|
|
24
|
+
|
|
25
|
+
<div class='fl pad1y space-right2'>
|
|
26
|
+
<span class="strong">100% </span>
|
|
27
|
+
<span class="quiet">Statements</span>
|
|
28
|
+
<span class='fraction'>6/6</span>
|
|
29
|
+
</div>
|
|
30
|
+
|
|
31
|
+
|
|
32
|
+
<div class='fl pad1y space-right2'>
|
|
33
|
+
<span class="strong">100% </span>
|
|
34
|
+
<span class="quiet">Branches</span>
|
|
35
|
+
<span class='fraction'>0/0</span>
|
|
36
|
+
</div>
|
|
37
|
+
|
|
38
|
+
|
|
39
|
+
<div class='fl pad1y space-right2'>
|
|
40
|
+
<span class="strong">100% </span>
|
|
41
|
+
<span class="quiet">Functions</span>
|
|
42
|
+
<span class='fraction'>3/3</span>
|
|
43
|
+
</div>
|
|
44
|
+
|
|
45
|
+
|
|
46
|
+
<div class='fl pad1y space-right2'>
|
|
47
|
+
<span class="strong">100% </span>
|
|
48
|
+
<span class="quiet">Lines</span>
|
|
49
|
+
<span class='fraction'>6/6</span>
|
|
50
|
+
</div>
|
|
51
|
+
|
|
52
|
+
|
|
53
|
+
</div>
|
|
54
|
+
<p class="quiet">
|
|
55
|
+
Press <em>n</em> or <em>j</em> to go to the next uncovered block, <em>b</em>, <em>p</em> or <em>k</em> for the previous block.
|
|
56
|
+
</p>
|
|
57
|
+
<template id="filterTemplate">
|
|
58
|
+
<div class="quiet">
|
|
59
|
+
Filter:
|
|
60
|
+
<input type="search" id="fileSearch">
|
|
61
|
+
</div>
|
|
62
|
+
</template>
|
|
63
|
+
</div>
|
|
64
|
+
<div class='status-line high'></div>
|
|
65
|
+
<div class="pad1">
|
|
66
|
+
<table class="coverage-summary">
|
|
67
|
+
<thead>
|
|
68
|
+
<tr>
|
|
69
|
+
<th data-col="file" data-fmt="html" data-html="true" class="file">File</th>
|
|
70
|
+
<th data-col="pic" data-type="number" data-fmt="html" data-html="true" class="pic"></th>
|
|
71
|
+
<th data-col="statements" data-type="number" data-fmt="pct" class="pct">Statements</th>
|
|
72
|
+
<th data-col="statements_raw" data-type="number" data-fmt="html" class="abs"></th>
|
|
73
|
+
<th data-col="branches" data-type="number" data-fmt="pct" class="pct">Branches</th>
|
|
74
|
+
<th data-col="branches_raw" data-type="number" data-fmt="html" class="abs"></th>
|
|
75
|
+
<th data-col="functions" data-type="number" data-fmt="pct" class="pct">Functions</th>
|
|
76
|
+
<th data-col="functions_raw" data-type="number" data-fmt="html" class="abs"></th>
|
|
77
|
+
<th data-col="lines" data-type="number" data-fmt="pct" class="pct">Lines</th>
|
|
78
|
+
<th data-col="lines_raw" data-type="number" data-fmt="html" class="abs"></th>
|
|
79
|
+
</tr>
|
|
80
|
+
</thead>
|
|
81
|
+
<tbody><tr>
|
|
82
|
+
<td class="file high" data-value="formatHttpDate.js"><a href="formatHttpDate.js.html">formatHttpDate.js</a></td>
|
|
83
|
+
<td data-value="100" class="pic high">
|
|
84
|
+
<div class="chart"><div class="cover-fill cover-full" style="width: 100%"></div><div class="cover-empty" style="width: 0%"></div></div>
|
|
85
|
+
</td>
|
|
86
|
+
<td data-value="100" class="pct high">100%</td>
|
|
87
|
+
<td data-value="4" class="abs high">4/4</td>
|
|
88
|
+
<td data-value="100" class="pct high">100%</td>
|
|
89
|
+
<td data-value="0" class="abs high">0/0</td>
|
|
90
|
+
<td data-value="100" class="pct high">100%</td>
|
|
91
|
+
<td data-value="1" class="abs high">1/1</td>
|
|
92
|
+
<td data-value="100" class="pct high">100%</td>
|
|
93
|
+
<td data-value="4" class="abs high">4/4</td>
|
|
94
|
+
</tr>
|
|
95
|
+
|
|
96
|
+
<tr>
|
|
97
|
+
<td class="file high" data-value="formatHttpKey.js"><a href="formatHttpKey.js.html">formatHttpKey.js</a></td>
|
|
98
|
+
<td data-value="100" class="pic high">
|
|
99
|
+
<div class="chart"><div class="cover-fill cover-full" style="width: 100%"></div><div class="cover-empty" style="width: 0%"></div></div>
|
|
100
|
+
</td>
|
|
101
|
+
<td data-value="100" class="pct high">100%</td>
|
|
102
|
+
<td data-value="2" class="abs high">2/2</td>
|
|
103
|
+
<td data-value="100" class="pct high">100%</td>
|
|
104
|
+
<td data-value="0" class="abs high">0/0</td>
|
|
105
|
+
<td data-value="100" class="pct high">100%</td>
|
|
106
|
+
<td data-value="2" class="abs high">2/2</td>
|
|
107
|
+
<td data-value="100" class="pct high">100%</td>
|
|
108
|
+
<td data-value="2" class="abs high">2/2</td>
|
|
109
|
+
</tr>
|
|
110
|
+
|
|
111
|
+
</tbody>
|
|
112
|
+
</table>
|
|
113
|
+
</div>
|
|
114
|
+
<div class='push'></div><!-- for sticky footer -->
|
|
115
|
+
</div><!-- /wrapper -->
|
|
116
|
+
<div class='footer quiet pad2 space-top1 center small'>
|
|
117
|
+
Code coverage generated by
|
|
118
|
+
<a href="https://istanbul.js.org/" target="_blank" rel="noopener noreferrer">istanbul</a>
|
|
119
|
+
at 2025-06-02T09:47:44.080Z
|
|
120
|
+
</div>
|
|
121
|
+
<script src="../prettify.js"></script>
|
|
122
|
+
<script>
|
|
123
|
+
window.onload = function () {
|
|
124
|
+
prettyPrint();
|
|
125
|
+
};
|
|
126
|
+
</script>
|
|
127
|
+
<script src="../sorter.js"></script>
|
|
128
|
+
<script src="../block-navigation.js"></script>
|
|
129
|
+
</body>
|
|
130
|
+
</html>
|
|
131
|
+
|
package/coverage/lcov.info
CHANGED
|
@@ -1,4 +1,57 @@
|
|
|
1
1
|
TN:
|
|
2
|
+
SF:src/server/class/MultiFetch.js
|
|
3
|
+
FN:5,(anonymous_0)
|
|
4
|
+
FN:13,(anonymous_1)
|
|
5
|
+
FN:29,(anonymous_2)
|
|
6
|
+
FNF:3
|
|
7
|
+
FNH:3
|
|
8
|
+
FNDA:1,(anonymous_0)
|
|
9
|
+
FNDA:1,(anonymous_1)
|
|
10
|
+
FNDA:20,(anonymous_2)
|
|
11
|
+
DA:6,1
|
|
12
|
+
DA:7,1
|
|
13
|
+
DA:8,1
|
|
14
|
+
DA:9,1
|
|
15
|
+
DA:10,1
|
|
16
|
+
DA:14,1
|
|
17
|
+
DA:15,0
|
|
18
|
+
DA:16,0
|
|
19
|
+
DA:17,0
|
|
20
|
+
DA:18,0
|
|
21
|
+
DA:21,1
|
|
22
|
+
DA:22,0
|
|
23
|
+
DA:24,1
|
|
24
|
+
DA:25,0
|
|
25
|
+
DA:34,20
|
|
26
|
+
DA:35,20
|
|
27
|
+
DA:36,20
|
|
28
|
+
DA:37,16
|
|
29
|
+
DA:39,4
|
|
30
|
+
DA:41,20
|
|
31
|
+
DA:42,20
|
|
32
|
+
DA:43,20
|
|
33
|
+
DA:44,20
|
|
34
|
+
DA:45,20
|
|
35
|
+
DA:47,20
|
|
36
|
+
DA:48,20
|
|
37
|
+
LF:26
|
|
38
|
+
LH:20
|
|
39
|
+
BRDA:14,0,0,0
|
|
40
|
+
BRDA:14,0,1,1
|
|
41
|
+
BRDA:17,1,0,0
|
|
42
|
+
BRDA:17,1,1,0
|
|
43
|
+
BRDA:21,2,0,0
|
|
44
|
+
BRDA:21,2,1,1
|
|
45
|
+
BRDA:24,3,0,0
|
|
46
|
+
BRDA:24,3,1,1
|
|
47
|
+
BRDA:36,4,0,16
|
|
48
|
+
BRDA:36,4,1,4
|
|
49
|
+
BRDA:43,5,0,20
|
|
50
|
+
BRDA:43,5,1,0
|
|
51
|
+
BRF:12
|
|
52
|
+
BRH:6
|
|
53
|
+
end_of_record
|
|
54
|
+
TN:
|
|
2
55
|
SF:src/server/lib/formatHttpDate.js
|
|
3
56
|
FN:1,formatHttpDate
|
|
4
57
|
FNF:1
|
package/index.js
ADDED
package/package.json
CHANGED
|
@@ -1,11 +1,12 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "manner.js",
|
|
3
|
-
"version": "0.0
|
|
3
|
+
"version": "1.0.0",
|
|
4
4
|
"description": "Frontend mode project.",
|
|
5
5
|
"repository": "git@github.com:leobrad/mode.git",
|
|
6
6
|
"author": "Leo Ely",
|
|
7
7
|
"license": "MIT",
|
|
8
8
|
"scripts": {
|
|
9
|
+
"run": "gulp build && node dist/index.js",
|
|
9
10
|
"build": "gulp build && gulp copy",
|
|
10
11
|
"clean": "rm -rf client server",
|
|
11
12
|
"test": "jest"
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.default = void 0;
|
|
7
|
+
var _https = _interopRequireDefault(require("https"));
|
|
8
|
+
var _nodeFetch = _interopRequireDefault(require("node-fetch"));
|
|
9
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
10
|
+
class MultiFetch {
|
|
11
|
+
constructor(bases, path, options) {
|
|
12
|
+
this.index = -1;
|
|
13
|
+
this.dealParams(bases, path, options);
|
|
14
|
+
this.bases = bases;
|
|
15
|
+
this.path = path;
|
|
16
|
+
this.options = options;
|
|
17
|
+
}
|
|
18
|
+
dealParams(bases, path, options) {
|
|
19
|
+
if (!Array.isArray(bases)) {
|
|
20
|
+
throw new Error('[Error] The bases parameter bases should be a array type.');
|
|
21
|
+
const {
|
|
22
|
+
length
|
|
23
|
+
} = bases;
|
|
24
|
+
if (length === 0) {
|
|
25
|
+
throw new Error('[Error] The bases parameter bases cannot have zero length.');
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
if (typeof path !== 'string') {
|
|
29
|
+
throw new Error('[Error] The path parameter path should be of string type.');
|
|
30
|
+
}
|
|
31
|
+
if (typeof options !== 'object') {
|
|
32
|
+
throw new Error('[Error] The options parameter should be a object type..');
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
async fetch() {
|
|
36
|
+
const {
|
|
37
|
+
bases,
|
|
38
|
+
path,
|
|
39
|
+
options
|
|
40
|
+
} = this;
|
|
41
|
+
const {
|
|
42
|
+
length
|
|
43
|
+
} = bases;
|
|
44
|
+
if (this.index < length - 1) {
|
|
45
|
+
this.index += 1;
|
|
46
|
+
} else {
|
|
47
|
+
this.index = 0;
|
|
48
|
+
}
|
|
49
|
+
const {
|
|
50
|
+
index
|
|
51
|
+
} = this;
|
|
52
|
+
const base = bases[index];
|
|
53
|
+
if (base.startsWith('https')) {
|
|
54
|
+
const httpsAgent = new _https.default.Agent({
|
|
55
|
+
rejectUnauthorized: false
|
|
56
|
+
});
|
|
57
|
+
options.agent = httpsAgent;
|
|
58
|
+
}
|
|
59
|
+
const url = base + path;
|
|
60
|
+
return (0, _nodeFetch.default)(url, options);
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
var _default = exports.default = MultiFetch;
|
package/server/index.js
ADDED
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
Object.defineProperty(exports, "formatHttpDate", {
|
|
7
|
+
enumerable: true,
|
|
8
|
+
get: function () {
|
|
9
|
+
return _formatHttpDate.default;
|
|
10
|
+
}
|
|
11
|
+
});
|
|
12
|
+
Object.defineProperty(exports, "formatHttpKey", {
|
|
13
|
+
enumerable: true,
|
|
14
|
+
get: function () {
|
|
15
|
+
return _formatHttpKey.default;
|
|
16
|
+
}
|
|
17
|
+
});
|
|
18
|
+
Object.defineProperty(exports, "readCookie", {
|
|
19
|
+
enumerable: true,
|
|
20
|
+
get: function () {
|
|
21
|
+
return _readCookie.default;
|
|
22
|
+
}
|
|
23
|
+
});
|
|
24
|
+
var _readCookie = _interopRequireDefault(require("./lib/readCookie"));
|
|
25
|
+
var _formatHttpKey = _interopRequireDefault(require("./lib/formatHttpKey"));
|
|
26
|
+
var _formatHttpDate = _interopRequireDefault(require("./lib/formatHttpDate"));
|
|
27
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.default = formatHttpDate;
|
|
7
|
+
function formatHttpDate(ms) {
|
|
8
|
+
const date = new Date(ms);
|
|
9
|
+
let [week, month, day, year, time, zone] = date.toString().split(' ');
|
|
10
|
+
zone = zone.split('+')[0];
|
|
11
|
+
return week + ', ' + day + ' ' + month + ' ' + year + ' ' + time + ' ' + zone;
|
|
12
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.default = formatHttpKey;
|
|
7
|
+
function formatHttpKey(key) {
|
|
8
|
+
return key.split('-').map(v => {
|
|
9
|
+
return v.substring(0, 1).toUpperCase() + v.substring(1, v.length);
|
|
10
|
+
}).join('-');
|
|
11
|
+
}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.readCookie = readCookie;
|
|
7
|
+
function readCookie(cookie) {
|
|
8
|
+
const cookies = {};
|
|
9
|
+
if (typeof cookie === 'string') {
|
|
10
|
+
cookie.split(';').forEach(i => {
|
|
11
|
+
const [key, value] = i.split('=');
|
|
12
|
+
cookies[key.trim()] = value;
|
|
13
|
+
});
|
|
14
|
+
}
|
|
15
|
+
const namespaces = {};
|
|
16
|
+
Object.keys(cookies).forEach(k => {
|
|
17
|
+
const result = k.split('_');
|
|
18
|
+
if (result.length === 2) {
|
|
19
|
+
const [namespace, key] = result;
|
|
20
|
+
if (namespaces[namespace] === undefined) {
|
|
21
|
+
namespaces[namespace] = {};
|
|
22
|
+
}
|
|
23
|
+
namespaces[namespace][key] = cookies[k];
|
|
24
|
+
}
|
|
25
|
+
});
|
|
26
|
+
return namespaces;
|
|
27
|
+
}
|