@healflow/playwright 0.1.2 → 0.1.3
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/README.md +35 -18
- package/dist/index.d.ts +2 -22
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +4 -691
- package/dist/index.js.map +1 -1
- package/dist/plugin/classification.d.ts +6 -0
- package/dist/plugin/classification.d.ts.map +1 -0
- package/dist/plugin/classification.js +343 -0
- package/dist/plugin/classification.js.map +1 -0
- package/dist/plugin/constants.d.ts +5 -0
- package/dist/plugin/constants.d.ts.map +1 -0
- package/dist/plugin/constants.js +55 -0
- package/dist/plugin/constants.js.map +1 -0
- package/dist/plugin/heal-emit.d.ts +5 -0
- package/dist/plugin/heal-emit.d.ts.map +1 -0
- package/dist/plugin/heal-emit.js +69 -0
- package/dist/plugin/heal-emit.js.map +1 -0
- package/dist/plugin/index.d.ts +5 -0
- package/dist/plugin/index.d.ts.map +1 -0
- package/dist/plugin/index.js +11 -0
- package/dist/plugin/index.js.map +1 -0
- package/dist/plugin/locator-wrap.d.ts +4 -0
- package/dist/plugin/locator-wrap.d.ts.map +1 -0
- package/dist/plugin/locator-wrap.js +68 -0
- package/dist/plugin/locator-wrap.js.map +1 -0
- package/dist/plugin/options.d.ts +3 -0
- package/dist/plugin/options.d.ts.map +1 -0
- package/dist/plugin/options.js +25 -0
- package/dist/plugin/options.js.map +1 -0
- package/dist/plugin/page-wrap.d.ts +9 -0
- package/dist/plugin/page-wrap.d.ts.map +1 -0
- package/dist/plugin/page-wrap.js +99 -0
- package/dist/plugin/page-wrap.js.map +1 -0
- package/dist/plugin/types.d.ts +19 -0
- package/dist/plugin/types.d.ts.map +1 -0
- package/dist/plugin/types.js +3 -0
- package/dist/plugin/types.js.map +1 -0
- package/dist/report-html/build.d.ts +7 -0
- package/dist/report-html/build.d.ts.map +1 -0
- package/dist/report-html/build.js +138 -0
- package/dist/report-html/build.js.map +1 -0
- package/dist/report-html/format.d.ts +6 -0
- package/dist/report-html/format.d.ts.map +1 -0
- package/dist/report-html/format.js +37 -0
- package/dist/report-html/format.js.map +1 -0
- package/dist/report-html/icons.d.ts +4 -0
- package/dist/report-html/icons.d.ts.map +1 -0
- package/dist/report-html/icons.js +7 -0
- package/dist/report-html/icons.js.map +1 -0
- package/dist/report-html/index.d.ts +3 -0
- package/dist/report-html/index.d.ts.map +1 -0
- package/dist/report-html/index.js +6 -0
- package/dist/report-html/index.js.map +1 -0
- package/dist/report-html/render.d.ts +6 -0
- package/dist/report-html/render.d.ts.map +1 -0
- package/dist/report-html/render.js +139 -0
- package/dist/report-html/render.js.map +1 -0
- package/dist/report-html/script.d.ts +2 -0
- package/dist/report-html/script.d.ts.map +1 -0
- package/dist/report-html/script.js +75 -0
- package/dist/report-html/script.js.map +1 -0
- package/dist/report-html/status.d.ts +2 -0
- package/dist/report-html/status.d.ts.map +1 -0
- package/dist/report-html/status.js +13 -0
- package/dist/report-html/status.js.map +1 -0
- package/dist/report-html/styles.d.ts +2 -0
- package/dist/report-html/styles.d.ts.map +1 -0
- package/dist/report-html/styles.js +441 -0
- package/dist/report-html/styles.js.map +1 -0
- package/dist/report-html/tree.d.ts +8 -0
- package/dist/report-html/tree.d.ts.map +1 -0
- package/dist/report-html/tree.js +57 -0
- package/dist/report-html/tree.js.map +1 -0
- package/dist/report-html/types.d.ts +19 -0
- package/dist/report-html/types.d.ts.map +1 -0
- package/dist/report-html/types.js +3 -0
- package/dist/report-html/types.js.map +1 -0
- package/dist/report-html.d.ts +2 -6
- package/dist/report-html.d.ts.map +1 -1
- package/dist/report-html.js +3 -859
- package/dist/report-html.js.map +1 -1
- package/dist/runtime-ladder.d.ts +17 -0
- package/dist/runtime-ladder.d.ts.map +1 -0
- package/dist/runtime-ladder.js +61 -0
- package/dist/runtime-ladder.js.map +1 -0
- package/dist/runtime-techniques/heal-helpers.d.ts +10 -0
- package/dist/runtime-techniques/heal-helpers.d.ts.map +1 -0
- package/dist/runtime-techniques/heal-helpers.js +304 -0
- package/dist/runtime-techniques/heal-helpers.js.map +1 -0
- package/dist/runtime-techniques/index.d.ts +11 -0
- package/dist/runtime-techniques/index.d.ts.map +1 -0
- package/dist/runtime-techniques/index.js +34 -0
- package/dist/runtime-techniques/index.js.map +1 -0
- package/dist/runtime-techniques/registry.d.ts +5 -0
- package/dist/runtime-techniques/registry.d.ts.map +1 -0
- package/dist/runtime-techniques/registry.js +29 -0
- package/dist/runtime-techniques/registry.js.map +1 -0
- package/dist/runtime-techniques/shared/constants.d.ts +4 -0
- package/dist/runtime-techniques/shared/constants.d.ts.map +1 -0
- package/dist/runtime-techniques/shared/constants.js +7 -0
- package/dist/runtime-techniques/shared/constants.js.map +1 -0
- package/dist/runtime-techniques/shared/error-utils.d.ts +9 -0
- package/dist/runtime-techniques/shared/error-utils.d.ts.map +1 -0
- package/dist/runtime-techniques/shared/error-utils.js +27 -0
- package/dist/runtime-techniques/shared/error-utils.js.map +1 -0
- package/dist/runtime-techniques/shared/heal-alternate.d.ts +6 -0
- package/dist/runtime-techniques/shared/heal-alternate.d.ts.map +1 -0
- package/dist/runtime-techniques/shared/heal-alternate.js +130 -0
- package/dist/runtime-techniques/shared/heal-alternate.js.map +1 -0
- package/dist/runtime-techniques/shared/heal-candidates.d.ts +11 -0
- package/dist/runtime-techniques/shared/heal-candidates.d.ts.map +1 -0
- package/dist/runtime-techniques/shared/heal-candidates.js +127 -0
- package/dist/runtime-techniques/shared/heal-candidates.js.map +1 -0
- package/dist/runtime-techniques/shared/heal-history.d.ts +10 -0
- package/dist/runtime-techniques/shared/heal-history.d.ts.map +1 -0
- package/dist/runtime-techniques/shared/heal-history.js +42 -0
- package/dist/runtime-techniques/shared/heal-history.js.map +1 -0
- package/dist/runtime-techniques/shared/locator-actions.d.ts +6 -0
- package/dist/runtime-techniques/shared/locator-actions.d.ts.map +1 -0
- package/dist/runtime-techniques/shared/locator-actions.js +66 -0
- package/dist/runtime-techniques/shared/locator-actions.js.map +1 -0
- package/dist/runtime-techniques/shared/page-waits.d.ts +6 -0
- package/dist/runtime-techniques/shared/page-waits.d.ts.map +1 -0
- package/dist/runtime-techniques/shared/page-waits.js +57 -0
- package/dist/runtime-techniques/shared/page-waits.js.map +1 -0
- package/dist/runtime-techniques/shared.d.ts +8 -0
- package/dist/runtime-techniques/shared.d.ts.map +1 -0
- package/dist/runtime-techniques/shared.js +24 -0
- package/dist/runtime-techniques/shared.js.map +1 -0
- package/dist/runtime-techniques/t0-retry.d.ts +4 -0
- package/dist/runtime-techniques/t0-retry.d.ts.map +1 -0
- package/dist/runtime-techniques/t0-retry.js +334 -0
- package/dist/runtime-techniques/t0-retry.js.map +1 -0
- package/dist/runtime-techniques/t1-scope.d.ts +4 -0
- package/dist/runtime-techniques/t1-scope.d.ts.map +1 -0
- package/dist/runtime-techniques/t1-scope.js +70 -0
- package/dist/runtime-techniques/t1-scope.js.map +1 -0
- package/dist/runtime-techniques/t2-normalize.d.ts +3 -0
- package/dist/runtime-techniques/t2-normalize.d.ts.map +1 -0
- package/dist/runtime-techniques/t2-normalize.js +12 -0
- package/dist/runtime-techniques/t2-normalize.js.map +1 -0
- package/dist/runtime-techniques/t3-fingerprint.d.ts +4 -0
- package/dist/runtime-techniques/t3-fingerprint.d.ts.map +1 -0
- package/dist/runtime-techniques/t3-fingerprint.js +13 -0
- package/dist/runtime-techniques/t3-fingerprint.js.map +1 -0
- package/dist/runtime-techniques/t4-trace.d.ts +4 -0
- package/dist/runtime-techniques/t4-trace.d.ts.map +1 -0
- package/dist/runtime-techniques/t4-trace.js +125 -0
- package/dist/runtime-techniques/t4-trace.js.map +1 -0
- package/dist/runtime-techniques/t5-history.d.ts +3 -0
- package/dist/runtime-techniques/t5-history.d.ts.map +1 -0
- package/dist/runtime-techniques/t5-history.js +50 -0
- package/dist/runtime-techniques/t5-history.js.map +1 -0
- package/dist/runtime-techniques/types.d.ts +36 -0
- package/dist/runtime-techniques/types.d.ts.map +1 -0
- package/dist/runtime-techniques/types.js +3 -0
- package/dist/runtime-techniques/types.js.map +1 -0
- package/dist/runtime-techniques.d.ts +2 -0
- package/dist/runtime-techniques.d.ts.map +1 -0
- package/dist/runtime-techniques.js +18 -0
- package/dist/runtime-techniques.js.map +1 -0
- package/dist/terminal.d.ts.map +1 -1
- package/dist/terminal.js +52 -3
- package/dist/terminal.js.map +1 -1
- package/package.json +3 -3
|
@@ -0,0 +1,139 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.renderSidebarTree = renderSidebarTree;
|
|
4
|
+
exports.renderTestDetailPanels = renderTestDetailPanels;
|
|
5
|
+
exports.renderCategorySummary = renderCategorySummary;
|
|
6
|
+
const terminal_js_1 = require("../terminal.js");
|
|
7
|
+
const format_js_1 = require("./format.js");
|
|
8
|
+
const icons_js_1 = require("./icons.js");
|
|
9
|
+
const tree_js_1 = require("./tree.js");
|
|
10
|
+
function renderSidebarTree(groups) {
|
|
11
|
+
if (groups.length === 0) {
|
|
12
|
+
return '<div class="tree-empty">No heals recorded this run.</div>';
|
|
13
|
+
}
|
|
14
|
+
return groups
|
|
15
|
+
.map((group) => {
|
|
16
|
+
const tests = group.tests
|
|
17
|
+
.map((test) => {
|
|
18
|
+
const healLabel = test.heals.length > 1 ? ` (${test.heals.length})` : '';
|
|
19
|
+
return `
|
|
20
|
+
<div class="tree-item test-tree-item" data-test-id="${(0, format_js_1.escapeHtml)(test.id)}" role="button" tabindex="0">
|
|
21
|
+
<span class="status-icon status-healed" aria-hidden="true">${icons_js_1.STATUS_ICON_HEALED}</span>
|
|
22
|
+
<span class="tree-item-title">${(0, format_js_1.escapeHtml)(test.testTitle)}${(0, format_js_1.escapeHtml)(healLabel)}</span>
|
|
23
|
+
</div>`;
|
|
24
|
+
})
|
|
25
|
+
.join('');
|
|
26
|
+
return `
|
|
27
|
+
<div class="file-group" data-file="${(0, format_js_1.escapeHtml)(group.testFile)}">
|
|
28
|
+
<div class="tree-item file-tree-item" role="presentation">
|
|
29
|
+
<span class="file-chevron" aria-hidden="true">▸</span>
|
|
30
|
+
<span class="tree-item-title file-title">${(0, format_js_1.escapeHtml)(group.fileName)}</span>
|
|
31
|
+
<span class="file-heal-count">${group.healCount}</span>
|
|
32
|
+
</div>
|
|
33
|
+
<div class="file-tests">${tests}</div>
|
|
34
|
+
</div>`;
|
|
35
|
+
})
|
|
36
|
+
.join('');
|
|
37
|
+
}
|
|
38
|
+
function renderHealCards(test) {
|
|
39
|
+
return test.heals
|
|
40
|
+
.map((heal) => {
|
|
41
|
+
const selectorChange = heal.oldValue || heal.newValue
|
|
42
|
+
? `
|
|
43
|
+
<div class="detail-row">
|
|
44
|
+
<span class="detail-label">Selector</span>
|
|
45
|
+
<span class="detail-value selector-change">
|
|
46
|
+
<code>${(0, format_js_1.escapeHtml)(heal.oldValue ?? '—')}</code>
|
|
47
|
+
<span class="arrow">→</span>
|
|
48
|
+
<code>${(0, format_js_1.escapeHtml)(heal.newValue ?? '—')}</code>
|
|
49
|
+
</span>
|
|
50
|
+
</div>`
|
|
51
|
+
: '';
|
|
52
|
+
return `
|
|
53
|
+
<article class="heal-card" data-heal-id="${(0, format_js_1.escapeHtml)(heal.id)}">
|
|
54
|
+
<div class="heal-card-header">
|
|
55
|
+
<span class="category-badge category-${(0, format_js_1.escapeHtml)(heal.category.toLowerCase())}">${(0, format_js_1.escapeHtml)(heal.category)}</span>
|
|
56
|
+
<span class="confidence-badge">${(0, format_js_1.formatConfidence)(heal.confidence)} confidence</span>
|
|
57
|
+
</div>
|
|
58
|
+
<p class="heal-description">${(0, format_js_1.escapeHtml)((0, terminal_js_1.formatHealDescription)(heal))}</p>
|
|
59
|
+
<div class="detail-grid">
|
|
60
|
+
<div class="detail-row">
|
|
61
|
+
<span class="detail-label">Root cause</span>
|
|
62
|
+
<span class="detail-value">${(0, format_js_1.escapeHtml)(heal.rootCause)}</span>
|
|
63
|
+
</div>
|
|
64
|
+
${selectorChange}
|
|
65
|
+
<div class="detail-row">
|
|
66
|
+
<span class="detail-label">Healed at</span>
|
|
67
|
+
<span class="detail-value">${(0, format_js_1.escapeHtml)((0, format_js_1.formatTimestamp)(heal.healedAt))}</span>
|
|
68
|
+
</div>
|
|
69
|
+
<div class="detail-row">
|
|
70
|
+
<span class="detail-label">Heal ID</span>
|
|
71
|
+
<span class="detail-value mono">${(0, format_js_1.escapeHtml)(heal.id)}</span>
|
|
72
|
+
</div>
|
|
73
|
+
</div>
|
|
74
|
+
</article>`;
|
|
75
|
+
})
|
|
76
|
+
.join('');
|
|
77
|
+
}
|
|
78
|
+
function renderFixProposal(fix) {
|
|
79
|
+
if (!fix)
|
|
80
|
+
return '';
|
|
81
|
+
return `
|
|
82
|
+
<section class="detail-section">
|
|
83
|
+
<div class="chip-header">Fix proposal</div>
|
|
84
|
+
<div class="chip-body">
|
|
85
|
+
<div class="detail-grid">
|
|
86
|
+
<div class="detail-row">
|
|
87
|
+
<span class="detail-label">Strategy</span>
|
|
88
|
+
<span class="detail-value">${(0, format_js_1.escapeHtml)(fix.strategy)}</span>
|
|
89
|
+
</div>
|
|
90
|
+
<div class="detail-row">
|
|
91
|
+
<span class="detail-label">Dry run</span>
|
|
92
|
+
<span class="detail-value">${fix.dryRun ? 'Yes' : 'No'}</span>
|
|
93
|
+
</div>
|
|
94
|
+
<div class="detail-row">
|
|
95
|
+
<span class="detail-label">Confidence</span>
|
|
96
|
+
<span class="detail-value">${(0, format_js_1.formatConfidence)(fix.confidence)}</span>
|
|
97
|
+
</div>
|
|
98
|
+
</div>
|
|
99
|
+
</div>
|
|
100
|
+
</section>`;
|
|
101
|
+
}
|
|
102
|
+
function renderTestDetailPanels(groups) {
|
|
103
|
+
const panels = groups.flatMap((group) => group.tests.map((test) => {
|
|
104
|
+
const relativePath = test.testFile;
|
|
105
|
+
return `
|
|
106
|
+
<section class="test-detail" id="test-${(0, format_js_1.escapeHtml)(test.id)}" hidden>
|
|
107
|
+
<div class="test-file-header">
|
|
108
|
+
<div class="test-file-title-row">
|
|
109
|
+
<span class="status-icon status-healed" aria-hidden="true">${icons_js_1.STATUS_ICON_HEALED}</span>
|
|
110
|
+
<h2 class="test-file-title">${(0, format_js_1.escapeHtml)(test.testTitle)}</h2>
|
|
111
|
+
</div>
|
|
112
|
+
<div class="test-file-path">${(0, format_js_1.escapeHtml)(relativePath)}</div>
|
|
113
|
+
</div>
|
|
114
|
+
<section class="detail-section">
|
|
115
|
+
<div class="chip-header">Runtime heals (${test.heals.length})</div>
|
|
116
|
+
<div class="chip-body heal-cards">${renderHealCards(test)}</div>
|
|
117
|
+
</section>
|
|
118
|
+
${renderFixProposal(test.fix)}
|
|
119
|
+
</section>`;
|
|
120
|
+
}));
|
|
121
|
+
return panels.join('');
|
|
122
|
+
}
|
|
123
|
+
function renderCategorySummary(heals) {
|
|
124
|
+
const counts = (0, tree_js_1.categoryCounts)(heals);
|
|
125
|
+
if (counts.length === 0) {
|
|
126
|
+
return '<p class="muted">No heal categories to summarize.</p>';
|
|
127
|
+
}
|
|
128
|
+
return `
|
|
129
|
+
<div class="category-summary">
|
|
130
|
+
${counts
|
|
131
|
+
.map((entry) => `
|
|
132
|
+
<div class="category-stat">
|
|
133
|
+
<span class="category-badge category-${(0, format_js_1.escapeHtml)(entry.category.toLowerCase())}">${(0, format_js_1.escapeHtml)(entry.category)}</span>
|
|
134
|
+
<span class="category-count">${entry.count}</span>
|
|
135
|
+
</div>`)
|
|
136
|
+
.join('')}
|
|
137
|
+
</div>`;
|
|
138
|
+
}
|
|
139
|
+
//# sourceMappingURL=render.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"render.js","sourceRoot":"","sources":["../../src/report-html/render.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export declare const REPORT_SCRIPT = "\n(function () {\n const data = JSON.parse(document.getElementById('healflow-data').textContent);\n const searchInput = document.getElementById('tree-search');\n const overview = document.getElementById('overview-panel');\n const details = Array.from(document.querySelectorAll('.test-detail'));\n const testItems = Array.from(document.querySelectorAll('.test-tree-item'));\n const fileGroups = Array.from(document.querySelectorAll('.file-group'));\n\n function showOverview() {\n overview.hidden = false;\n details.forEach((panel) => { panel.hidden = true; });\n testItems.forEach((item) => {\n item.classList.toggle('selected', !item.dataset.testId);\n });\n }\n\n function showTest(testId) {\n overview.hidden = true;\n details.forEach((panel) => {\n panel.hidden = panel.id !== 'test-' + testId;\n });\n testItems.forEach((item) => {\n item.classList.toggle('selected', item.dataset.testId === testId);\n });\n }\n\n testItems.forEach((item) => {\n item.addEventListener('click', () => {\n if (!item.dataset.testId) {\n showOverview();\n return;\n }\n showTest(item.dataset.testId);\n });\n item.addEventListener('keydown', (event) => {\n if (event.key === 'Enter' || event.key === ' ') {\n event.preventDefault();\n if (!item.dataset.testId) {\n showOverview();\n return;\n }\n showTest(item.dataset.testId);\n }\n });\n });\n\n fileGroups.forEach((group) => {\n group.classList.add('expanded');\n const header = group.querySelector('.file-tree-item');\n header.addEventListener('click', () => group.classList.toggle('expanded'));\n });\n\n searchInput.addEventListener('input', () => {\n const query = searchInput.value.trim().toLowerCase();\n fileGroups.forEach((group) => {\n let visibleTests = 0;\n group.querySelectorAll('.test-tree-item').forEach((item) => {\n const title = item.textContent.toLowerCase();\n const match = !query || title.includes(query);\n item.style.display = match ? '' : 'none';\n if (match) visibleTests += 1;\n });\n const fileName = group.querySelector('.file-title').textContent.toLowerCase();\n const showGroup = visibleTests > 0 || fileName.includes(query);\n group.style.display = showGroup ? '' : 'none';\n if (showGroup && query) group.classList.add('expanded');\n });\n });\n\n})();";
|
|
2
|
+
//# sourceMappingURL=script.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"script.d.ts","sourceRoot":"","sources":["../../src/report-html/script.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,aAAa,g6EAsEpB,CAAC"}
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.REPORT_SCRIPT = void 0;
|
|
4
|
+
exports.REPORT_SCRIPT = `
|
|
5
|
+
(function () {
|
|
6
|
+
const data = JSON.parse(document.getElementById('healflow-data').textContent);
|
|
7
|
+
const searchInput = document.getElementById('tree-search');
|
|
8
|
+
const overview = document.getElementById('overview-panel');
|
|
9
|
+
const details = Array.from(document.querySelectorAll('.test-detail'));
|
|
10
|
+
const testItems = Array.from(document.querySelectorAll('.test-tree-item'));
|
|
11
|
+
const fileGroups = Array.from(document.querySelectorAll('.file-group'));
|
|
12
|
+
|
|
13
|
+
function showOverview() {
|
|
14
|
+
overview.hidden = false;
|
|
15
|
+
details.forEach((panel) => { panel.hidden = true; });
|
|
16
|
+
testItems.forEach((item) => {
|
|
17
|
+
item.classList.toggle('selected', !item.dataset.testId);
|
|
18
|
+
});
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
function showTest(testId) {
|
|
22
|
+
overview.hidden = true;
|
|
23
|
+
details.forEach((panel) => {
|
|
24
|
+
panel.hidden = panel.id !== 'test-' + testId;
|
|
25
|
+
});
|
|
26
|
+
testItems.forEach((item) => {
|
|
27
|
+
item.classList.toggle('selected', item.dataset.testId === testId);
|
|
28
|
+
});
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
testItems.forEach((item) => {
|
|
32
|
+
item.addEventListener('click', () => {
|
|
33
|
+
if (!item.dataset.testId) {
|
|
34
|
+
showOverview();
|
|
35
|
+
return;
|
|
36
|
+
}
|
|
37
|
+
showTest(item.dataset.testId);
|
|
38
|
+
});
|
|
39
|
+
item.addEventListener('keydown', (event) => {
|
|
40
|
+
if (event.key === 'Enter' || event.key === ' ') {
|
|
41
|
+
event.preventDefault();
|
|
42
|
+
if (!item.dataset.testId) {
|
|
43
|
+
showOverview();
|
|
44
|
+
return;
|
|
45
|
+
}
|
|
46
|
+
showTest(item.dataset.testId);
|
|
47
|
+
}
|
|
48
|
+
});
|
|
49
|
+
});
|
|
50
|
+
|
|
51
|
+
fileGroups.forEach((group) => {
|
|
52
|
+
group.classList.add('expanded');
|
|
53
|
+
const header = group.querySelector('.file-tree-item');
|
|
54
|
+
header.addEventListener('click', () => group.classList.toggle('expanded'));
|
|
55
|
+
});
|
|
56
|
+
|
|
57
|
+
searchInput.addEventListener('input', () => {
|
|
58
|
+
const query = searchInput.value.trim().toLowerCase();
|
|
59
|
+
fileGroups.forEach((group) => {
|
|
60
|
+
let visibleTests = 0;
|
|
61
|
+
group.querySelectorAll('.test-tree-item').forEach((item) => {
|
|
62
|
+
const title = item.textContent.toLowerCase();
|
|
63
|
+
const match = !query || title.includes(query);
|
|
64
|
+
item.style.display = match ? '' : 'none';
|
|
65
|
+
if (match) visibleTests += 1;
|
|
66
|
+
});
|
|
67
|
+
const fileName = group.querySelector('.file-title').textContent.toLowerCase();
|
|
68
|
+
const showGroup = visibleTests > 0 || fileName.includes(query);
|
|
69
|
+
group.style.display = showGroup ? '' : 'none';
|
|
70
|
+
if (showGroup && query) group.classList.add('expanded');
|
|
71
|
+
});
|
|
72
|
+
});
|
|
73
|
+
|
|
74
|
+
})();`;
|
|
75
|
+
//# sourceMappingURL=script.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"script.js","sourceRoot":"","sources":["../../src/report-html/script.ts"],"names":[],"mappings":";;;AAAa,QAAA,aAAa,GAAG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;MAsEvB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"status.d.ts","sourceRoot":"","sources":["../../src/report-html/status.ts"],"names":[],"mappings":"AAAA,wBAAgB,WAAW,CAAC,MAAM,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,GAAG,MAAM,CAUxE"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.statusLabel = statusLabel;
|
|
4
|
+
function statusLabel(status, failureCount) {
|
|
5
|
+
if (failureCount > 0 ||
|
|
6
|
+
status === 'failed' ||
|
|
7
|
+
status === 'timedout' ||
|
|
8
|
+
status === 'interrupted') {
|
|
9
|
+
return 'failed';
|
|
10
|
+
}
|
|
11
|
+
return 'passed';
|
|
12
|
+
}
|
|
13
|
+
//# sourceMappingURL=status.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"status.js","sourceRoot":"","sources":["../../src/report-html/status.ts"],"names":[],"mappings":";;AAAA,kCAUC;AAVD,SAAgB,WAAW,CAAC,MAAc,EAAE,YAAoB;IAC9D,IACE,YAAY,GAAG,CAAC;QAChB,MAAM,KAAK,QAAQ;QACnB,MAAM,KAAK,UAAU;QACrB,MAAM,KAAK,aAAa,EACxB,CAAC;QACD,OAAO,QAAQ,CAAC;IAClB,CAAC;IACD,OAAO,QAAQ,CAAC;AAClB,CAAC"}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export declare const REPORT_STYLES = "\n:root {\n --color-canvas-default: #ffffff;\n --color-canvas-subtle: #f6f8fa;\n --color-fg-default: #24292f;\n --color-fg-muted: #57606a;\n --color-border-default: #d0d7de;\n --color-success-fg: #1a7f37;\n --color-success-subtle: #dafbe1;\n --color-danger-fg: #cf222e;\n --color-danger-subtle: #ffebe9;\n --color-attention-fg: #9a6700;\n --color-attention-subtle: #fff8c5;\n --color-accent-fg: #0969da;\n --color-accent-subtle: #ddf4ff;\n --color-heal-fg: #0550ae;\n --color-heal-subtle: #ddf4ff;\n --sidebar-width: 320px;\n --font-stack: -apple-system, BlinkMacSystemFont, \"Segoe UI\", \"Noto Sans\", Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\";\n --mono-stack: ui-monospace, SFMono-Regular, SF Mono, Menlo, Consolas, Liberation Mono, monospace;\n}\n\n* { box-sizing: border-box; }\nhtml, body { height: 100%; }\nbody {\n margin: 0;\n font-family: var(--font-stack);\n font-size: 14px;\n line-height: 1.5;\n color: var(--color-fg-default);\n background: var(--color-canvas-default);\n}\n\nbutton, input { font: inherit; }\n\n.app { display: flex; flex-direction: column; min-height: 100vh; }\n\n.header-view {\n display: flex;\n align-items: center;\n gap: 16px;\n padding: 12px 20px;\n border-bottom: 1px solid var(--color-border-default);\n background: var(--color-canvas-default);\n flex-wrap: wrap;\n}\n\n.header-brand {\n display: flex;\n align-items: center;\n gap: 10px;\n min-width: 0;\n}\n\n.header-logo {\n width: 28px;\n height: 28px;\n border-radius: 6px;\n background: linear-gradient(135deg, #2da44e, #0969da);\n color: #fff;\n display: flex;\n align-items: center;\n justify-content: center;\n font-weight: 700;\n font-size: 13px;\n}\n\n.header-title {\n font-size: 18px;\n font-weight: 600;\n letter-spacing: -0.2px;\n}\n\n.header-subtitle {\n color: var(--color-fg-muted);\n font-size: 12px;\n}\n\n.header-view-status-container {\n display: flex;\n align-items: center;\n gap: 8px;\n flex-wrap: wrap;\n margin-left: auto;\n}\n\n.summary-chip {\n display: inline-flex;\n align-items: center;\n gap: 6px;\n padding: 4px 10px;\n border-radius: 2em;\n border: 1px solid var(--color-border-default);\n background: var(--color-canvas-subtle);\n font-size: 13px;\n font-weight: 500;\n white-space: nowrap;\n}\n\n.summary-chip.passed { color: var(--color-success-fg); background: var(--color-success-subtle); border-color: #82d8a5; }\n.summary-chip.failed { color: var(--color-danger-fg); background: var(--color-danger-subtle); border-color: #ffbbb9; }\n.summary-chip.healed { color: var(--color-heal-fg); background: var(--color-heal-subtle); border-color: #9cd7ff; }\n.summary-chip.neutral { color: var(--color-fg-muted); }\n\n.main-layout {\n display: flex;\n flex: 1;\n min-height: 0;\n}\n\n.sidebar {\n width: var(--sidebar-width);\n flex-shrink: 0;\n border-right: 1px solid var(--color-border-default);\n background: var(--color-canvas-subtle);\n display: flex;\n flex-direction: column;\n min-height: calc(100vh - 57px);\n}\n\n.sidebar-toolbar {\n padding: 12px;\n border-bottom: 1px solid var(--color-border-default);\n background: var(--color-canvas-default);\n}\n\n.search-input {\n width: 100%;\n padding: 6px 10px;\n border: 1px solid var(--color-border-default);\n border-radius: 6px;\n background: var(--color-canvas-default);\n color: var(--color-fg-default);\n}\n\n.search-input:focus {\n outline: 2px solid var(--color-accent-fg);\n outline-offset: -1px;\n}\n\n.tree-panel {\n flex: 1;\n overflow: auto;\n padding: 8px 0 24px;\n}\n\n.tree-empty {\n padding: 16px;\n color: var(--color-fg-muted);\n}\n\n.file-group { margin-bottom: 4px; }\n\n.tree-item {\n display: flex;\n align-items: center;\n gap: 8px;\n padding: 6px 12px;\n line-height: 20px;\n overflow: hidden;\n white-space: nowrap;\n text-overflow: ellipsis;\n}\n\n.file-tree-item {\n color: var(--color-fg-default);\n font-weight: 600;\n cursor: pointer;\n user-select: none;\n}\n\n.test-tree-item {\n padding-left: 28px;\n cursor: pointer;\n border-left: 3px solid transparent;\n}\n\n.test-tree-item:hover,\n.test-tree-item:focus-visible {\n background: rgba(9, 105, 218, 0.08);\n outline: none;\n}\n\n.test-tree-item.selected {\n background: #fff;\n border-left-color: var(--color-accent-fg);\n}\n\n.overview-tree-item {\n padding-left: 12px;\n border-bottom: 1px solid var(--color-border-default);\n margin-bottom: 8px;\n}\n\n.file-chevron {\n width: 12px;\n color: var(--color-fg-muted);\n transition: transform 0.15s ease;\n}\n\n.file-group.expanded .file-chevron { transform: rotate(90deg); }\n\n.file-tests { display: none; }\n.file-group.expanded .file-tests { display: block; }\n\n.tree-item-title {\n overflow: hidden;\n text-overflow: ellipsis;\n}\n\n.file-title { flex: 1; }\n\n.file-heal-count {\n font-size: 11px;\n font-weight: 600;\n color: var(--color-heal-fg);\n background: var(--color-heal-subtle);\n border-radius: 10px;\n padding: 1px 7px;\n}\n\n.status-icon {\n display: inline-flex;\n flex-shrink: 0;\n align-items: center;\n justify-content: center;\n}\n\n.content {\n flex: 1;\n overflow: auto;\n padding: 20px 24px 40px;\n background: var(--color-canvas-default);\n}\n\n.overview-panel { max-width: 960px; }\n\n.overview-grid {\n display: grid;\n grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));\n gap: 12px;\n margin: 16px 0 24px;\n}\n\n.meta-card {\n border: 1px solid var(--color-border-default);\n border-radius: 6px;\n padding: 14px 16px;\n background: var(--color-canvas-subtle);\n}\n\n.meta-card .label {\n font-size: 12px;\n color: var(--color-fg-muted);\n margin-bottom: 4px;\n}\n\n.meta-card .value {\n font-size: 16px;\n font-weight: 600;\n}\n\n.muted { color: var(--color-fg-muted); }\n\n.chip-header {\n border: 1px solid var(--color-border-default);\n border-top-left-radius: 6px;\n border-top-right-radius: 6px;\n background: var(--color-canvas-subtle);\n padding: 0 12px;\n font-weight: 600;\n line-height: 38px;\n}\n\n.chip-body {\n border: 1px solid var(--color-border-default);\n border-top: none;\n border-bottom-left-radius: 6px;\n border-bottom-right-radius: 6px;\n padding: 12px;\n margin-bottom: 16px;\n}\n\n.detail-section { margin-bottom: 16px; }\n\n.test-file-header {\n margin-bottom: 20px;\n padding-bottom: 16px;\n border-bottom: 1px solid var(--color-border-default);\n}\n\n.test-file-title-row {\n display: flex;\n align-items: center;\n gap: 10px;\n}\n\n.test-file-title {\n margin: 0;\n font-size: 20px;\n font-weight: 600;\n}\n\n.test-file-path {\n margin-top: 6px;\n color: var(--color-fg-muted);\n font-family: var(--mono-stack);\n font-size: 12px;\n word-break: break-all;\n}\n\n.heal-cards { display: grid; gap: 12px; }\n\n.heal-card {\n border: 1px solid var(--color-border-default);\n border-radius: 6px;\n padding: 12px 14px;\n background: var(--color-canvas-default);\n}\n\n.heal-card-header {\n display: flex;\n align-items: center;\n gap: 8px;\n margin-bottom: 8px;\n flex-wrap: wrap;\n}\n\n.heal-description {\n margin: 0 0 12px;\n color: var(--color-fg-default);\n}\n\n.detail-grid { display: grid; gap: 8px; }\n\n.detail-row {\n display: grid;\n grid-template-columns: 120px 1fr;\n gap: 12px;\n align-items: start;\n}\n\n.detail-label {\n color: var(--color-fg-muted);\n font-size: 12px;\n font-weight: 600;\n}\n\n.detail-value { word-break: break-word; }\n.detail-value.mono { font-family: var(--mono-stack); font-size: 12px; }\n\n.selector-change {\n display: flex;\n align-items: center;\n gap: 8px;\n flex-wrap: wrap;\n}\n\n.selector-change code {\n font-family: var(--mono-stack);\n font-size: 12px;\n background: var(--color-canvas-subtle);\n border: 1px solid var(--color-border-default);\n border-radius: 4px;\n padding: 2px 6px;\n}\n\n.arrow { color: var(--color-fg-muted); }\n\n.category-badge {\n display: inline-flex;\n align-items: center;\n padding: 2px 8px;\n border-radius: 2em;\n font-size: 11px;\n font-weight: 700;\n letter-spacing: 0.3px;\n}\n\n.category-timing { background: var(--color-attention-subtle); color: var(--color-attention-fg); }\n.category-overlay { background: var(--color-danger-subtle); color: var(--color-danger-fg); }\n.category-selector { background: var(--color-success-subtle); color: var(--color-success-fg); }\n.category-iframe, .category-shadow_dom, .category-auth, .category-session, .category-network {\n background: var(--color-accent-subtle);\n color: var(--color-accent-fg);\n}\n\n.confidence-badge {\n font-size: 12px;\n color: var(--color-fg-muted);\n}\n\n.category-summary {\n display: flex;\n flex-wrap: wrap;\n gap: 10px;\n}\n\n.category-stat {\n display: inline-flex;\n align-items: center;\n gap: 8px;\n border: 1px solid var(--color-border-default);\n border-radius: 6px;\n padding: 8px 10px;\n background: var(--color-canvas-subtle);\n}\n\n.category-count {\n font-weight: 700;\n min-width: 1.5em;\n text-align: right;\n}\n\n.run-status {\n display: inline-flex;\n align-items: center;\n gap: 6px;\n font-weight: 600;\n text-transform: capitalize;\n}\n\n.run-status.passed { color: var(--color-success-fg); }\n.run-status.failed { color: var(--color-danger-fg); }\n\n@media (max-width: 900px) {\n .main-layout { flex-direction: column; }\n .sidebar {\n width: 100%;\n min-height: auto;\n max-height: 40vh;\n border-right: none;\n border-bottom: 1px solid var(--color-border-default);\n }\n .detail-row { grid-template-columns: 1fr; gap: 2px; }\n}\n";
|
|
2
|
+
//# sourceMappingURL=styles.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"styles.d.ts","sourceRoot":"","sources":["../../src/report-html/styles.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,aAAa,81SAobzB,CAAC"}
|