Source code

Revision control

Copy as Markdown

Other Tools

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<title>Results - Web Platform Test</title>
<link rel="stylesheet" href="css/bulma.min.css" />
<link rel="stylesheet" href="css/result.css" />
<script src="lib/utils.js"></script>
<script src="lib/ui.js"></script>
<script src="results.json.js"></script>
<script src="details.json.js"></script>
</head>
<body>
<script>
window.onload = () => {
resultUi.render();
resultUi.loadData();
};
const resultUi = {
state: { details: null, results: null },
loadData: () => {
resultUi.loadSessionDetails();
resultUi.loadSessionResults();
},
loadSessionDetails(callback = () => {}) {
resultUi.state.details = details;
resultUi.renderSessionDetails();
callback(details);
},
loadSessionResults(callback = () => {}) {
const { details } = resultUi.state;
Object.keys(details.test_files_count).forEach(api =>
!results[api] ? (results[api] = {}) : null
);
for (let api in results) {
let { pass, fail, timeout, not_run } = results[api];
let complete = 0;
if (pass) complete += pass;
if (fail) complete += fail;
if (timeout) complete += timeout;
if (not_run) complete += not_run;
results[api].complete = complete;
const { test_files_count, test_files_completed } = details;
results[api].isDone =
test_files_count[api] === test_files_completed[api];
results[api].testFilesCount = test_files_count[api];
results[api].testFilesCompleted = test_files_completed[api];
}
resultUi.state.results = results;
resultUi.renderApiResults();
callback(results);
},
render() {
const resultView = UI.createElement({
className: "content",
style: "margin-bottom: 40px;",
children: [
{
className: "header",
children: [
{
children: [
{
element: "img",
src: "res/wavelogo_2016.jpg",
className: "site-logo"
}
]
}
]
},
{
id: "header",
children: [
{ className: "title", text: "Result" },
{ id: "controls" }
]
},
{ id: "session-details" },
{ id: "api-results" },
{ id: "timeout-files" },
{ id: "export" }
]
});
const root = UI.getRoot();
root.innerHTML = "";
root.appendChild(resultView);
resultUi.renderSessionDetails();
resultUi.renderApiResults();
},
renderSessionDetails() {
const { state } = resultUi;
const { details } = state;
if (!details) return;
const sessionDetailsView = UI.createElement({
style: "margin-bottom: 20px"
});
const heading = UI.createElement({
text: "Session details",
className: "title is-4"
});
sessionDetailsView.appendChild(heading);
const getTagStyle = status => {
switch (status) {
case "completed":
return "is-success";
case "running":
return "is-info";
case "aborted":
return "is-danger";
case "paused":
return "is-warning";
}
};
const { test_files_count, token } = details;
const detailsTable = UI.createElement({
element: "table",
children: {
element: "tbody",
children: [
{
element: "tr",
children: [
{ element: "td", text: "Token:", style: "width: 140px;" },
{
element: "td",
text: token,
className: "is-family-monospace"
}
]
},
{
element: "tr",
children: [
{ element: "td", text: "User Agent:" },
{ element: "td", text: details.user_agent || "" }
]
},
{
element: "tr",
children: [
{ element: "td", text: "Test Path:" },
{ element: "td", text: details.path || "" }
]
},
{
element: "tr",
children: [
{ element: "td", text: "Total Test Files:" },
{
element: "td",
text: Object.keys(test_files_count).reduce(
(sum, api) => (sum += test_files_count[api]),
0
)
}
]
},
{
element: "tr",
children: [
{ element: "td", text: "Test Timeout:" },
{ element: "td", text: details.test_timeout || "" }
]
},
{
element: "tr",
children: [
{ element: "td", text: "Started:" },
{
element: "td",
text: new Date(details.date_started).toLocaleString()
}
]
},
details.date_finished
? {
element: "tr",
children: [
{ element: "td", text: "Finished:" },
{
element: "td",
text: new Date(details.date_finished).toLocaleString()
}
]
}
: null,
details.date_finished
? {
element: "tr",
children: [
{ element: "td", text: "Duration:" },
{
element: "td",
id: "duration",
text: utils.millisToTimeString(
details.date_finished
? parseInt(details.date_finished) -
parseInt(details.date_started)
: Date.now() - parseInt(details.date_started)
)
}
]
}
: null
]
}
});
sessionDetailsView.appendChild(detailsTable);
const sessionDetails = UI.getElement("session-details");
sessionDetails.innerHTML = "";
sessionDetails.appendChild(sessionDetailsView);
},
renderApiResults() {
const { results } = resultUi.state;
if (!results) return;
const apiResultsView = UI.createElement({
style: "margin-bottom: 20px"
});
const heading = UI.createElement({
text: "API Results",
className: "title is-4"
});
apiResultsView.appendChild(heading);
const header = UI.createElement({
element: "thead",
children: [
{
element: "tr",
children: [
{ element: "th", text: "API" },
{ element: "th", text: "Pass" },
{ element: "th", text: "Fail" },
{ element: "th", text: "Timeout" },
{ element: "th", text: "Not Run" },
{ element: "th", text: "Test Files Run" }
]
}
]
});
const apis = Object.keys(results).sort((apiA, apiB) =>
apiA.toLowerCase() > apiB.toLowerCase() ? 1 : -1
);
const rows = apis.map(api => {
const {
complete = 0,
pass = 0,
fail = 0,
timeout = 0,
timeoutfiles = [],
not_run: notRun = 0,
isDone = false,
testFilesCount,
testFilesCompleted = 0
} = results[api];
return UI.createElement({
element: "tr",
children: [
{ element: "td", text: api },
{
element: "td",
style: "color: hsl(141, 71%, 38%)",
text: `${pass} (${utils.percent(pass, complete)}%)`
},
{
element: "td",
className: "has-text-danger",
text: `${fail} (${utils.percent(fail, complete)}%)`
},
{
element: "td",
style: "color: hsl(48, 100%, 40%)",
text: `${timeout} (${utils.percent(timeout, complete)}%)`
},
{
element: "td",
className: "has-text-info",
text: `${notRun} (${utils.percent(notRun, complete)}%)`
},
{
element: "td",
text: `${testFilesCompleted}/${testFilesCount} (${utils.percent(
testFilesCompleted,
testFilesCount
)}%)`
}
]
});
});
const { pass, fail, timeout, not_run, complete } = apis.reduce(
(sum, api) => {
Object.keys(sum).forEach(
key => (sum[key] += results[api][key] ? results[api][key] : 0)
);
return sum;
},
{ complete: 0, pass: 0, fail: 0, timeout: 0, not_run: 0 }
);
const testFilesCount = Object.keys(results).reduce(
(sum, api) => (sum += results[api].testFilesCount),
0
);
const testFilesCompleted = Object.keys(results).reduce(
(sum, api) => (sum += results[api].testFilesCompleted || 0),
0
);
const footer = UI.createElement({
element: "tfoot",
children: [
{
element: "tr",
children: [
{ element: "th", text: "Total" },
{
element: "th",
style: "color: hsl(141, 71%, 38%)",
text: `${pass} (${utils.percent(pass, complete)}%)`
},
{
element: "th",
className: "has-text-danger",
text: `${fail} (${utils.percent(fail, complete)}%)`
},
{
element: "th",
style: "color: hsl(48, 100%, 40%)",
text: `${timeout} (${utils.percent(timeout, complete)}%)`
},
{
element: "th",
className: "has-text-info",
text: `${not_run} (${utils.percent(not_run, complete)}%)`
},
{
element: "th",
text: `${testFilesCompleted}/${testFilesCount} (${utils.percent(
testFilesCompleted,
testFilesCount
)}%)`
}
]
}
]
});
const resultsTable = UI.createElement({
element: "table",
className: "table",
id: "results-table",
style: "border-radius: 3px; border: 2px solid hsl(0, 0%, 86%);",
children: [header, { element: "tbody", children: rows }, footer]
});
apiResultsView.appendChild(resultsTable);
const apiResults = UI.getElement("api-results");
apiResults.innerHTML = "";
apiResults.appendChild(apiResultsView);
}
};
</script>
</body>
</html>