@copilotkitnext/core 0.0.1
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/.turbo/turbo-build.log +22 -0
- package/.turbo/turbo-check-types.log +4 -0
- package/.turbo/turbo-lint.log +12 -0
- package/.turbo/turbo-test.log +96 -0
- package/LICENSE +11 -0
- package/coverage/base.css +224 -0
- package/coverage/block-navigation.js +87 -0
- package/coverage/favicon.png +0 -0
- package/coverage/index.html +131 -0
- package/coverage/lcov-report/base.css +224 -0
- package/coverage/lcov-report/block-navigation.js +87 -0
- package/coverage/lcov-report/favicon.png +0 -0
- package/coverage/lcov-report/index.html +131 -0
- package/coverage/lcov-report/prettify.css +1 -0
- package/coverage/lcov-report/prettify.js +2 -0
- package/coverage/lcov-report/sort-arrow-sprite.png +0 -0
- package/coverage/lcov-report/sorter.js +210 -0
- package/coverage/lcov-report/src/agent.ts.html +193 -0
- package/coverage/lcov-report/src/core.ts.html +919 -0
- package/coverage/lcov-report/src/index.html +146 -0
- package/coverage/lcov-report/src/types.ts.html +112 -0
- package/coverage/lcov-report/src/utils/index.html +116 -0
- package/coverage/lcov-report/src/utils/markdown.ts.html +895 -0
- package/coverage/lcov.info +556 -0
- package/coverage/prettify.css +1 -0
- package/coverage/prettify.js +2 -0
- package/coverage/sort-arrow-sprite.png +0 -0
- package/coverage/sorter.js +210 -0
- package/coverage/src/agent.ts.html +193 -0
- package/coverage/src/core.ts.html +919 -0
- package/coverage/src/index.html +146 -0
- package/coverage/src/types.ts.html +112 -0
- package/coverage/src/utils/index.html +116 -0
- package/coverage/src/utils/markdown.ts.html +895 -0
- package/dist/index.d.mts +93 -0
- package/dist/index.d.ts +93 -0
- package/dist/index.js +526 -0
- package/dist/index.js.map +1 -0
- package/dist/index.mjs +502 -0
- package/dist/index.mjs.map +1 -0
- package/eslint.config.mjs +3 -0
- package/package.json +46 -0
- package/src/__tests__/core-agent-constraints.test.ts +86 -0
- package/src/__tests__/core-basic-functionality.test.ts +158 -0
- package/src/__tests__/core-basic.test.ts +27 -0
- package/src/__tests__/core-edge-cases.test.ts +166 -0
- package/src/__tests__/core-follow-up.test.ts +216 -0
- package/src/__tests__/core-full.test.ts +320 -0
- package/src/__tests__/core-simple.test.ts +24 -0
- package/src/__tests__/core-tool-minimal.test.ts +41 -0
- package/src/__tests__/core-tool-simple.test.ts +40 -0
- package/src/__tests__/core-wildcard.test.ts +45 -0
- package/src/__tests__/import.test.ts +13 -0
- package/src/__tests__/simple.test.ts +7 -0
- package/src/__tests__/test-utils.ts +162 -0
- package/src/agent.ts +37 -0
- package/src/core.ts +336 -0
- package/src/index.ts +4 -0
- package/src/types.ts +23 -0
- package/src/utils/markdown.ts +271 -0
- package/tsconfig.json +12 -0
- package/tsup.config.ts +11 -0
- package/vitest.config.mjs +15 -0
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
|
|
2
|
+
> @copilotkitnext/core@0.0.0 build /Users/mme/Code/CopilotKit2/packages/core
|
|
3
|
+
> tsup
|
|
4
|
+
|
|
5
|
+
CLI Building entry: src/index.ts
|
|
6
|
+
CLI Using tsconfig: tsconfig.json
|
|
7
|
+
CLI tsup v8.5.0
|
|
8
|
+
CLI Using tsup config: /Users/mme/Code/CopilotKit2/packages/core/tsup.config.ts
|
|
9
|
+
CLI Target: es2022
|
|
10
|
+
CLI Cleaning output folder
|
|
11
|
+
CJS Build start
|
|
12
|
+
ESM Build start
|
|
13
|
+
ESM dist/index.mjs 15.02 KB
|
|
14
|
+
ESM dist/index.mjs.map 30.38 KB
|
|
15
|
+
ESM ⚡️ Build success in 11ms
|
|
16
|
+
CJS dist/index.js 16.30 KB
|
|
17
|
+
CJS dist/index.js.map 30.55 KB
|
|
18
|
+
CJS ⚡️ Build success in 11ms
|
|
19
|
+
DTS Build start
|
|
20
|
+
DTS ⚡️ Build success in 1070ms
|
|
21
|
+
DTS dist/index.d.ts 3.38 KB
|
|
22
|
+
DTS dist/index.d.mts 3.38 KB
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
|
|
2
|
+
> @copilotkit/core@0.0.0 lint /Users/mme/Code/CopilotKit2/packages/core
|
|
3
|
+
> eslint . --max-warnings 0
|
|
4
|
+
|
|
5
|
+
|
|
6
|
+
/Users/mme/Code/CopilotKit2/packages/core/src/core.ts
|
|
7
|
+
3:34 warning 'HttpAgent' is defined but never used @typescript-eslint/no-unused-vars
|
|
8
|
+
|
|
9
|
+
✖ 1 problem (0 errors, 1 warning)
|
|
10
|
+
|
|
11
|
+
ESLint found too many warnings (maximum: 0).
|
|
12
|
+
ELIFECYCLE Command failed with exit code 1.
|
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
|
|
2
|
+
> @copilotkitnext/core@0.0.0 test /Users/mme/Code/CopilotKit2/packages/core
|
|
3
|
+
> vitest run
|
|
4
|
+
|
|
5
|
+
|
|
6
|
+
RUN v3.2.4 /Users/mme/Code/CopilotKit2/packages/core
|
|
7
|
+
|
|
8
|
+
stdout | src/__tests__/core-full.test.ts > CopilotKitCore.runAgent - Full Test Suite > Tests that might reveal problems > TEST 4: should handle follow-up with recursion
|
|
9
|
+
TEST 4: Starting follow-up test
|
|
10
|
+
TEST 4: Call count: 1
|
|
11
|
+
|
|
12
|
+
stdout | src/__tests__/core-full.test.ts > CopilotKitCore.runAgent - Full Test Suite > Tests that might reveal problems > TEST 4: should handle follow-up with recursion
|
|
13
|
+
TEST 4: Call count: 2
|
|
14
|
+
|
|
15
|
+
stdout | src/__tests__/core-full.test.ts > CopilotKitCore.runAgent - Full Test Suite > Tests that might reveal problems > TEST 4: should handle follow-up with recursion
|
|
16
|
+
TEST 4: Success - calls: 2
|
|
17
|
+
|
|
18
|
+
stdout | src/__tests__/core-full.test.ts > CopilotKitCore.runAgent - Full Test Suite > Tests that might reveal problems > TEST 5: should handle multiple tools with at least one follow-up
|
|
19
|
+
TEST 5: Starting multiple tools test
|
|
20
|
+
TEST 5: Call count: 1
|
|
21
|
+
|
|
22
|
+
stdout | src/__tests__/core-full.test.ts > CopilotKitCore.runAgent - Full Test Suite > Tests that might reveal problems > TEST 5: should handle multiple tools with at least one follow-up
|
|
23
|
+
TEST 5: Call count: 2
|
|
24
|
+
|
|
25
|
+
stdout | src/__tests__/core-full.test.ts > CopilotKitCore.runAgent - Full Test Suite > Tests that might reveal problems > TEST 5: should handle multiple tools with at least one follow-up
|
|
26
|
+
TEST 5: Success - calls: 2
|
|
27
|
+
|
|
28
|
+
stdout | src/__tests__/core-full.test.ts > CopilotKitCore.runAgent - Full Test Suite > Tests that might reveal problems > TEST 6: should handle tool with undefined follow-up (defaults to true)
|
|
29
|
+
TEST 6: Starting undefined follow-up test
|
|
30
|
+
TEST 6: Call count: 1
|
|
31
|
+
|
|
32
|
+
stdout | src/__tests__/core-full.test.ts > CopilotKitCore.runAgent - Full Test Suite > Tests that might reveal problems > TEST 6: should handle tool with undefined follow-up (defaults to true)
|
|
33
|
+
TEST 6: Call count: 2
|
|
34
|
+
|
|
35
|
+
stdout | src/__tests__/core-full.test.ts > CopilotKitCore.runAgent - Full Test Suite > Tests that might reveal problems > TEST 6: should handle tool with undefined follow-up (defaults to true)
|
|
36
|
+
TEST 6: Success - calls: 2
|
|
37
|
+
|
|
38
|
+
stdout | src/__tests__/core-full.test.ts > CopilotKitCore.runAgent - Full Test Suite > Tests that might reveal problems > TEST 7: should handle invalid JSON in tool arguments
|
|
39
|
+
TEST 7: Starting invalid JSON test
|
|
40
|
+
|
|
41
|
+
stdout | src/__tests__/core-full.test.ts > CopilotKitCore.runAgent - Full Test Suite > Tests that might reveal problems > TEST 7: should handle invalid JSON in tool arguments
|
|
42
|
+
TEST 7: Success - caught error: SyntaxError: Expected property name or '}' in JSON at position 2
|
|
43
|
+
|
|
44
|
+
stdout | src/__tests__/core-full.test.ts > CopilotKitCore.runAgent - Full Test Suite > Tests that might reveal problems > TEST 8: should handle empty string arguments
|
|
45
|
+
TEST 8: Starting empty arguments test
|
|
46
|
+
|
|
47
|
+
stdout | src/__tests__/core-full.test.ts > CopilotKitCore.runAgent - Full Test Suite > Tests that might reveal problems > TEST 8: should handle empty string arguments
|
|
48
|
+
TEST 8: Success - caught error: SyntaxError: Unexpected end of JSON input
|
|
49
|
+
|
|
50
|
+
stdout | src/__tests__/core-full.test.ts > CopilotKitCore.runAgent - Full Test Suite > Tests that might reveal problems > TEST 9: should handle chain of follow-ups
|
|
51
|
+
TEST 9: Starting chain test
|
|
52
|
+
TEST 9: Call count: 1
|
|
53
|
+
|
|
54
|
+
stdout | src/__tests__/core-full.test.ts > CopilotKitCore.runAgent - Full Test Suite > Tests that might reveal problems > TEST 9: should handle chain of follow-ups
|
|
55
|
+
TEST 9: Call count: 2
|
|
56
|
+
|
|
57
|
+
stdout | src/__tests__/core-full.test.ts > CopilotKitCore.runAgent - Full Test Suite > Tests that might reveal problems > TEST 9: should handle chain of follow-ups
|
|
58
|
+
TEST 9: Call count: 3
|
|
59
|
+
|
|
60
|
+
stdout | src/__tests__/core-full.test.ts > CopilotKitCore.runAgent - Full Test Suite > Tests that might reveal problems > TEST 9: should handle chain of follow-ups
|
|
61
|
+
TEST 9: Success - calls: 3
|
|
62
|
+
|
|
63
|
+
stdout | src/__tests__/core-full.test.ts > CopilotKitCore.runAgent - Full Test Suite > Tests that might reveal problems > TEST 10: should handle concurrent tool calls
|
|
64
|
+
TEST 10: Starting concurrent tools test
|
|
65
|
+
|
|
66
|
+
✓ src/__tests__/core-basic.test.ts (2 tests) 14ms
|
|
67
|
+
✓ src/__tests__/core-wildcard.test.ts (2 tests) 3ms
|
|
68
|
+
✓ src/__tests__/core-simple.test.ts (1 test) 2ms
|
|
69
|
+
stdout | src/__tests__/core-tool-simple.test.ts > CopilotKitCore Tool Simple > should execute a simple tool
|
|
70
|
+
Starting simple tool test
|
|
71
|
+
About to run agent
|
|
72
|
+
|
|
73
|
+
stdout | src/__tests__/core-tool-simple.test.ts > CopilotKitCore Tool Simple > should execute a simple tool
|
|
74
|
+
Tool handler called
|
|
75
|
+
|
|
76
|
+
✓ src/__tests__/core-basic-functionality.test.ts (10 tests) 61ms
|
|
77
|
+
✓ src/__tests__/core-tool-minimal.test.ts (2 tests) 4ms
|
|
78
|
+
stdout | src/__tests__/core-full.test.ts > CopilotKitCore.runAgent - Full Test Suite > Tests that might reveal problems > TEST 10: should handle concurrent tool calls
|
|
79
|
+
TEST 10: Success - duration: 176ms
|
|
80
|
+
|
|
81
|
+
stdout | src/__tests__/core-tool-simple.test.ts > CopilotKitCore Tool Simple > should execute a simple tool
|
|
82
|
+
Agent run complete
|
|
83
|
+
|
|
84
|
+
✓ src/__tests__/core-follow-up.test.ts (7 tests) 16ms
|
|
85
|
+
✓ src/__tests__/core-full.test.ts (10 tests) 194ms
|
|
86
|
+
✓ src/__tests__/core-edge-cases.test.ts (7 tests) 23ms
|
|
87
|
+
✓ src/__tests__/core-tool-simple.test.ts (1 test) 79ms
|
|
88
|
+
✓ src/__tests__/simple.test.ts (1 test) 4ms
|
|
89
|
+
✓ src/__tests__/import.test.ts (1 test) 1ms
|
|
90
|
+
✓ src/__tests__/core-agent-constraints.test.ts (3 tests) 3ms
|
|
91
|
+
|
|
92
|
+
Test Files 12 passed (12)
|
|
93
|
+
Tests 47 passed (47)
|
|
94
|
+
Start at 10:38:15
|
|
95
|
+
Duration 2.27s (transform 488ms, setup 0ms, collect 5.43s, tests 404ms, environment 1ms, prepare 4.27s)
|
|
96
|
+
|
package/LICENSE
ADDED
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
Note: This license does not apply to the whole project. Individual packages may contain their own licenses.
|
|
2
|
+
|
|
3
|
+
MIT License
|
|
4
|
+
|
|
5
|
+
Copyright 2025 Tawkit Inc.
|
|
6
|
+
|
|
7
|
+
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the “Software”), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
|
|
8
|
+
|
|
9
|
+
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
|
|
10
|
+
|
|
11
|
+
THE SOFTWARE IS PROVIDED “AS IS”, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
@@ -0,0 +1,224 @@
|
|
|
1
|
+
body, html {
|
|
2
|
+
margin:0; padding: 0;
|
|
3
|
+
height: 100%;
|
|
4
|
+
}
|
|
5
|
+
body {
|
|
6
|
+
font-family: Helvetica Neue, Helvetica, Arial;
|
|
7
|
+
font-size: 14px;
|
|
8
|
+
color:#333;
|
|
9
|
+
}
|
|
10
|
+
.small { font-size: 12px; }
|
|
11
|
+
*, *:after, *:before {
|
|
12
|
+
-webkit-box-sizing:border-box;
|
|
13
|
+
-moz-box-sizing:border-box;
|
|
14
|
+
box-sizing:border-box;
|
|
15
|
+
}
|
|
16
|
+
h1 { font-size: 20px; margin: 0;}
|
|
17
|
+
h2 { font-size: 14px; }
|
|
18
|
+
pre {
|
|
19
|
+
font: 12px/1.4 Consolas, "Liberation Mono", Menlo, Courier, monospace;
|
|
20
|
+
margin: 0;
|
|
21
|
+
padding: 0;
|
|
22
|
+
-moz-tab-size: 2;
|
|
23
|
+
-o-tab-size: 2;
|
|
24
|
+
tab-size: 2;
|
|
25
|
+
}
|
|
26
|
+
a { color:#0074D9; text-decoration:none; }
|
|
27
|
+
a:hover { text-decoration:underline; }
|
|
28
|
+
.strong { font-weight: bold; }
|
|
29
|
+
.space-top1 { padding: 10px 0 0 0; }
|
|
30
|
+
.pad2y { padding: 20px 0; }
|
|
31
|
+
.pad1y { padding: 10px 0; }
|
|
32
|
+
.pad2x { padding: 0 20px; }
|
|
33
|
+
.pad2 { padding: 20px; }
|
|
34
|
+
.pad1 { padding: 10px; }
|
|
35
|
+
.space-left2 { padding-left:55px; }
|
|
36
|
+
.space-right2 { padding-right:20px; }
|
|
37
|
+
.center { text-align:center; }
|
|
38
|
+
.clearfix { display:block; }
|
|
39
|
+
.clearfix:after {
|
|
40
|
+
content:'';
|
|
41
|
+
display:block;
|
|
42
|
+
height:0;
|
|
43
|
+
clear:both;
|
|
44
|
+
visibility:hidden;
|
|
45
|
+
}
|
|
46
|
+
.fl { float: left; }
|
|
47
|
+
@media only screen and (max-width:640px) {
|
|
48
|
+
.col3 { width:100%; max-width:100%; }
|
|
49
|
+
.hide-mobile { display:none!important; }
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
.quiet {
|
|
53
|
+
color: #7f7f7f;
|
|
54
|
+
color: rgba(0,0,0,0.5);
|
|
55
|
+
}
|
|
56
|
+
.quiet a { opacity: 0.7; }
|
|
57
|
+
|
|
58
|
+
.fraction {
|
|
59
|
+
font-family: Consolas, 'Liberation Mono', Menlo, Courier, monospace;
|
|
60
|
+
font-size: 10px;
|
|
61
|
+
color: #555;
|
|
62
|
+
background: #E8E8E8;
|
|
63
|
+
padding: 4px 5px;
|
|
64
|
+
border-radius: 3px;
|
|
65
|
+
vertical-align: middle;
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
div.path a:link, div.path a:visited { color: #333; }
|
|
69
|
+
table.coverage {
|
|
70
|
+
border-collapse: collapse;
|
|
71
|
+
margin: 10px 0 0 0;
|
|
72
|
+
padding: 0;
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
table.coverage td {
|
|
76
|
+
margin: 0;
|
|
77
|
+
padding: 0;
|
|
78
|
+
vertical-align: top;
|
|
79
|
+
}
|
|
80
|
+
table.coverage td.line-count {
|
|
81
|
+
text-align: right;
|
|
82
|
+
padding: 0 5px 0 20px;
|
|
83
|
+
}
|
|
84
|
+
table.coverage td.line-coverage {
|
|
85
|
+
text-align: right;
|
|
86
|
+
padding-right: 10px;
|
|
87
|
+
min-width:20px;
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
table.coverage td span.cline-any {
|
|
91
|
+
display: inline-block;
|
|
92
|
+
padding: 0 5px;
|
|
93
|
+
width: 100%;
|
|
94
|
+
}
|
|
95
|
+
.missing-if-branch {
|
|
96
|
+
display: inline-block;
|
|
97
|
+
margin-right: 5px;
|
|
98
|
+
border-radius: 3px;
|
|
99
|
+
position: relative;
|
|
100
|
+
padding: 0 4px;
|
|
101
|
+
background: #333;
|
|
102
|
+
color: yellow;
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
.skip-if-branch {
|
|
106
|
+
display: none;
|
|
107
|
+
margin-right: 10px;
|
|
108
|
+
position: relative;
|
|
109
|
+
padding: 0 4px;
|
|
110
|
+
background: #ccc;
|
|
111
|
+
color: white;
|
|
112
|
+
}
|
|
113
|
+
.missing-if-branch .typ, .skip-if-branch .typ {
|
|
114
|
+
color: inherit !important;
|
|
115
|
+
}
|
|
116
|
+
.coverage-summary {
|
|
117
|
+
border-collapse: collapse;
|
|
118
|
+
width: 100%;
|
|
119
|
+
}
|
|
120
|
+
.coverage-summary tr { border-bottom: 1px solid #bbb; }
|
|
121
|
+
.keyline-all { border: 1px solid #ddd; }
|
|
122
|
+
.coverage-summary td, .coverage-summary th { padding: 10px; }
|
|
123
|
+
.coverage-summary tbody { border: 1px solid #bbb; }
|
|
124
|
+
.coverage-summary td { border-right: 1px solid #bbb; }
|
|
125
|
+
.coverage-summary td:last-child { border-right: none; }
|
|
126
|
+
.coverage-summary th {
|
|
127
|
+
text-align: left;
|
|
128
|
+
font-weight: normal;
|
|
129
|
+
white-space: nowrap;
|
|
130
|
+
}
|
|
131
|
+
.coverage-summary th.file { border-right: none !important; }
|
|
132
|
+
.coverage-summary th.pct { }
|
|
133
|
+
.coverage-summary th.pic,
|
|
134
|
+
.coverage-summary th.abs,
|
|
135
|
+
.coverage-summary td.pct,
|
|
136
|
+
.coverage-summary td.abs { text-align: right; }
|
|
137
|
+
.coverage-summary td.file { white-space: nowrap; }
|
|
138
|
+
.coverage-summary td.pic { min-width: 120px !important; }
|
|
139
|
+
.coverage-summary tfoot td { }
|
|
140
|
+
|
|
141
|
+
.coverage-summary .sorter {
|
|
142
|
+
height: 10px;
|
|
143
|
+
width: 7px;
|
|
144
|
+
display: inline-block;
|
|
145
|
+
margin-left: 0.5em;
|
|
146
|
+
background: url(sort-arrow-sprite.png) no-repeat scroll 0 0 transparent;
|
|
147
|
+
}
|
|
148
|
+
.coverage-summary .sorted .sorter {
|
|
149
|
+
background-position: 0 -20px;
|
|
150
|
+
}
|
|
151
|
+
.coverage-summary .sorted-desc .sorter {
|
|
152
|
+
background-position: 0 -10px;
|
|
153
|
+
}
|
|
154
|
+
.status-line { height: 10px; }
|
|
155
|
+
/* yellow */
|
|
156
|
+
.cbranch-no { background: yellow !important; color: #111; }
|
|
157
|
+
/* dark red */
|
|
158
|
+
.red.solid, .status-line.low, .low .cover-fill { background:#C21F39 }
|
|
159
|
+
.low .chart { border:1px solid #C21F39 }
|
|
160
|
+
.highlighted,
|
|
161
|
+
.highlighted .cstat-no, .highlighted .fstat-no, .highlighted .cbranch-no{
|
|
162
|
+
background: #C21F39 !important;
|
|
163
|
+
}
|
|
164
|
+
/* medium red */
|
|
165
|
+
.cstat-no, .fstat-no, .cbranch-no, .cbranch-no { background:#F6C6CE }
|
|
166
|
+
/* light red */
|
|
167
|
+
.low, .cline-no { background:#FCE1E5 }
|
|
168
|
+
/* light green */
|
|
169
|
+
.high, .cline-yes { background:rgb(230,245,208) }
|
|
170
|
+
/* medium green */
|
|
171
|
+
.cstat-yes { background:rgb(161,215,106) }
|
|
172
|
+
/* dark green */
|
|
173
|
+
.status-line.high, .high .cover-fill { background:rgb(77,146,33) }
|
|
174
|
+
.high .chart { border:1px solid rgb(77,146,33) }
|
|
175
|
+
/* dark yellow (gold) */
|
|
176
|
+
.status-line.medium, .medium .cover-fill { background: #f9cd0b; }
|
|
177
|
+
.medium .chart { border:1px solid #f9cd0b; }
|
|
178
|
+
/* light yellow */
|
|
179
|
+
.medium { background: #fff4c2; }
|
|
180
|
+
|
|
181
|
+
.cstat-skip { background: #ddd; color: #111; }
|
|
182
|
+
.fstat-skip { background: #ddd; color: #111 !important; }
|
|
183
|
+
.cbranch-skip { background: #ddd !important; color: #111; }
|
|
184
|
+
|
|
185
|
+
span.cline-neutral { background: #eaeaea; }
|
|
186
|
+
|
|
187
|
+
.coverage-summary td.empty {
|
|
188
|
+
opacity: .5;
|
|
189
|
+
padding-top: 4px;
|
|
190
|
+
padding-bottom: 4px;
|
|
191
|
+
line-height: 1;
|
|
192
|
+
color: #888;
|
|
193
|
+
}
|
|
194
|
+
|
|
195
|
+
.cover-fill, .cover-empty {
|
|
196
|
+
display:inline-block;
|
|
197
|
+
height: 12px;
|
|
198
|
+
}
|
|
199
|
+
.chart {
|
|
200
|
+
line-height: 0;
|
|
201
|
+
}
|
|
202
|
+
.cover-empty {
|
|
203
|
+
background: white;
|
|
204
|
+
}
|
|
205
|
+
.cover-full {
|
|
206
|
+
border-right: none !important;
|
|
207
|
+
}
|
|
208
|
+
pre.prettyprint {
|
|
209
|
+
border: none !important;
|
|
210
|
+
padding: 0 !important;
|
|
211
|
+
margin: 0 !important;
|
|
212
|
+
}
|
|
213
|
+
.com { color: #999 !important; }
|
|
214
|
+
.ignore-none { color: #999; font-weight: normal; }
|
|
215
|
+
|
|
216
|
+
.wrapper {
|
|
217
|
+
min-height: 100%;
|
|
218
|
+
height: auto !important;
|
|
219
|
+
height: 100%;
|
|
220
|
+
margin: 0 auto -48px;
|
|
221
|
+
}
|
|
222
|
+
.footer, .push {
|
|
223
|
+
height: 48px;
|
|
224
|
+
}
|
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
/* eslint-disable */
|
|
2
|
+
var jumpToCode = (function init() {
|
|
3
|
+
// Classes of code we would like to highlight in the file view
|
|
4
|
+
var missingCoverageClasses = ['.cbranch-no', '.cstat-no', '.fstat-no'];
|
|
5
|
+
|
|
6
|
+
// Elements to highlight in the file listing view
|
|
7
|
+
var fileListingElements = ['td.pct.low'];
|
|
8
|
+
|
|
9
|
+
// We don't want to select elements that are direct descendants of another match
|
|
10
|
+
var notSelector = ':not(' + missingCoverageClasses.join('):not(') + ') > '; // becomes `:not(a):not(b) > `
|
|
11
|
+
|
|
12
|
+
// Selector that finds elements on the page to which we can jump
|
|
13
|
+
var selector =
|
|
14
|
+
fileListingElements.join(', ') +
|
|
15
|
+
', ' +
|
|
16
|
+
notSelector +
|
|
17
|
+
missingCoverageClasses.join(', ' + notSelector); // becomes `:not(a):not(b) > a, :not(a):not(b) > b`
|
|
18
|
+
|
|
19
|
+
// The NodeList of matching elements
|
|
20
|
+
var missingCoverageElements = document.querySelectorAll(selector);
|
|
21
|
+
|
|
22
|
+
var currentIndex;
|
|
23
|
+
|
|
24
|
+
function toggleClass(index) {
|
|
25
|
+
missingCoverageElements
|
|
26
|
+
.item(currentIndex)
|
|
27
|
+
.classList.remove('highlighted');
|
|
28
|
+
missingCoverageElements.item(index).classList.add('highlighted');
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
function makeCurrent(index) {
|
|
32
|
+
toggleClass(index);
|
|
33
|
+
currentIndex = index;
|
|
34
|
+
missingCoverageElements.item(index).scrollIntoView({
|
|
35
|
+
behavior: 'smooth',
|
|
36
|
+
block: 'center',
|
|
37
|
+
inline: 'center'
|
|
38
|
+
});
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
function goToPrevious() {
|
|
42
|
+
var nextIndex = 0;
|
|
43
|
+
if (typeof currentIndex !== 'number' || currentIndex === 0) {
|
|
44
|
+
nextIndex = missingCoverageElements.length - 1;
|
|
45
|
+
} else if (missingCoverageElements.length > 1) {
|
|
46
|
+
nextIndex = currentIndex - 1;
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
makeCurrent(nextIndex);
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
function goToNext() {
|
|
53
|
+
var nextIndex = 0;
|
|
54
|
+
|
|
55
|
+
if (
|
|
56
|
+
typeof currentIndex === 'number' &&
|
|
57
|
+
currentIndex < missingCoverageElements.length - 1
|
|
58
|
+
) {
|
|
59
|
+
nextIndex = currentIndex + 1;
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
makeCurrent(nextIndex);
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
return function jump(event) {
|
|
66
|
+
if (
|
|
67
|
+
document.getElementById('fileSearch') === document.activeElement &&
|
|
68
|
+
document.activeElement != null
|
|
69
|
+
) {
|
|
70
|
+
// if we're currently focused on the search input, we don't want to navigate
|
|
71
|
+
return;
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
switch (event.which) {
|
|
75
|
+
case 78: // n
|
|
76
|
+
case 74: // j
|
|
77
|
+
goToNext();
|
|
78
|
+
break;
|
|
79
|
+
case 66: // b
|
|
80
|
+
case 75: // k
|
|
81
|
+
case 80: // p
|
|
82
|
+
goToPrevious();
|
|
83
|
+
break;
|
|
84
|
+
}
|
|
85
|
+
};
|
|
86
|
+
})();
|
|
87
|
+
window.addEventListener('keydown', jumpToCode);
|
|
Binary file
|
|
@@ -0,0 +1,131 @@
|
|
|
1
|
+
|
|
2
|
+
<!doctype html>
|
|
3
|
+
<html lang="en">
|
|
4
|
+
|
|
5
|
+
<head>
|
|
6
|
+
<title>Code coverage report for All files</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>All files</h1>
|
|
23
|
+
<div class='clearfix'>
|
|
24
|
+
|
|
25
|
+
<div class='fl pad1y space-right2'>
|
|
26
|
+
<span class="strong">25.67% </span>
|
|
27
|
+
<span class="quiet">Statements</span>
|
|
28
|
+
<span class='fraction'>114/444</span>
|
|
29
|
+
</div>
|
|
30
|
+
|
|
31
|
+
|
|
32
|
+
<div class='fl pad1y space-right2'>
|
|
33
|
+
<span class="strong">82.35% </span>
|
|
34
|
+
<span class="quiet">Branches</span>
|
|
35
|
+
<span class='fraction'>28/34</span>
|
|
36
|
+
</div>
|
|
37
|
+
|
|
38
|
+
|
|
39
|
+
<div class='fl pad1y space-right2'>
|
|
40
|
+
<span class="strong">33.33% </span>
|
|
41
|
+
<span class="quiet">Functions</span>
|
|
42
|
+
<span class='fraction'>7/21</span>
|
|
43
|
+
</div>
|
|
44
|
+
|
|
45
|
+
|
|
46
|
+
<div class='fl pad1y space-right2'>
|
|
47
|
+
<span class="strong">25.67% </span>
|
|
48
|
+
<span class="quiet">Lines</span>
|
|
49
|
+
<span class='fraction'>114/444</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 low'></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 medium" data-value="src"><a href="src/index.html">src</a></td>
|
|
83
|
+
<td data-value="50.22" class="pic medium">
|
|
84
|
+
<div class="chart"><div class="cover-fill" style="width: 50%"></div><div class="cover-empty" style="width: 50%"></div></div>
|
|
85
|
+
</td>
|
|
86
|
+
<td data-value="50.22" class="pct medium">50.22%</td>
|
|
87
|
+
<td data-value="227" class="abs medium">114/227</td>
|
|
88
|
+
<td data-value="84.84" class="pct high">84.84%</td>
|
|
89
|
+
<td data-value="33" class="abs high">28/33</td>
|
|
90
|
+
<td data-value="35" class="pct low">35%</td>
|
|
91
|
+
<td data-value="20" class="abs low">7/20</td>
|
|
92
|
+
<td data-value="50.22" class="pct medium">50.22%</td>
|
|
93
|
+
<td data-value="227" class="abs medium">114/227</td>
|
|
94
|
+
</tr>
|
|
95
|
+
|
|
96
|
+
<tr>
|
|
97
|
+
<td class="file low" data-value="src/utils"><a href="src/utils/index.html">src/utils</a></td>
|
|
98
|
+
<td data-value="0" class="pic low">
|
|
99
|
+
<div class="chart"><div class="cover-fill" style="width: 0%"></div><div class="cover-empty" style="width: 100%"></div></div>
|
|
100
|
+
</td>
|
|
101
|
+
<td data-value="0" class="pct low">0%</td>
|
|
102
|
+
<td data-value="217" class="abs low">0/217</td>
|
|
103
|
+
<td data-value="0" class="pct low">0%</td>
|
|
104
|
+
<td data-value="1" class="abs low">0/1</td>
|
|
105
|
+
<td data-value="0" class="pct low">0%</td>
|
|
106
|
+
<td data-value="1" class="abs low">0/1</td>
|
|
107
|
+
<td data-value="0" class="pct low">0%</td>
|
|
108
|
+
<td data-value="217" class="abs low">0/217</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-09-01T08:36:26.937Z
|
|
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
|
+
|