mirror of
https://git.sfja.dk/Mikkel/slige.git
synced 2025-01-18 10:36:31 +00:00
test view
This commit is contained in:
parent
fcec80a029
commit
e1416bd0e5
19
examples/test_mul.slg
Normal file
19
examples/test_mul.slg
Normal file
@ -0,0 +1,19 @@
|
||||
fn print(msg: string) #[builtin(Print)] {}
|
||||
fn println(msg: string) { print(msg + "\n") }
|
||||
|
||||
fn mul(left: int, right: int) -> int {
|
||||
if left == 0 or right == 0 {
|
||||
0
|
||||
} else {
|
||||
left * right
|
||||
}
|
||||
}
|
||||
|
||||
fn main() {
|
||||
if mul(10,2) == 20 {
|
||||
print("test 1 passed")
|
||||
}
|
||||
if mul(3,2) == 6 {
|
||||
print("test 2 passed")
|
||||
}
|
||||
}
|
@ -1,6 +1,6 @@
|
||||
{
|
||||
"tasks": {
|
||||
"bundle": "deno run --allow-read --allow-write --allow-env --allow-run bundle.ts"
|
||||
"bundle": "deno run --check --allow-read --allow-write --allow-env --allow-run bundle.ts"
|
||||
},
|
||||
"compilerOptions": {
|
||||
"checkJs": false,
|
||||
|
@ -24,14 +24,34 @@ function colorLerp(
|
||||
};
|
||||
}
|
||||
|
||||
function colorToString(color: Color): string {
|
||||
return `rgb(${color.r}, ${color.g}, ${color.b})`;
|
||||
}
|
||||
|
||||
const GREEN = { r: 42, g: 121, b: 82 };
|
||||
const YELLOW = {
|
||||
r: 247,
|
||||
g: 203,
|
||||
b: 21,
|
||||
};
|
||||
const RED = {
|
||||
r: 167,
|
||||
g: 29,
|
||||
b: 49,
|
||||
};
|
||||
|
||||
export type CodeCovRender = "performance" | "test-coverage";
|
||||
|
||||
export function loadCodeCoverage(
|
||||
text: string,
|
||||
input: data.CodeCovEntry[],
|
||||
container: HTMLPreElement,
|
||||
tooltip: HTMLElement,
|
||||
) {
|
||||
mode: CodeCovRender,
|
||||
): HTMLPreElement {
|
||||
const container = document.createElement("pre");
|
||||
container.classList.add("code-source");
|
||||
if (input.length === 0) {
|
||||
return;
|
||||
return container;
|
||||
}
|
||||
const entries = input.toSorted((
|
||||
a: data.CodeCovEntry,
|
||||
@ -41,7 +61,7 @@ export function loadCodeCoverage(
|
||||
const elements: HTMLElement[] = [];
|
||||
let line = 1;
|
||||
let col = 1;
|
||||
const maxCovers = entries.map((v) => v.covers).reduce((acc, v) =>
|
||||
const maxPerfCovers = entries.map((v) => v.covers).reduce((acc, v) =>
|
||||
acc > Math.log10(v) ? acc : Math.log10(v)
|
||||
);
|
||||
for (let index = 0; index < text.length; ++index) {
|
||||
@ -59,23 +79,19 @@ export function loadCodeCoverage(
|
||||
}
|
||||
charEntries[`${line}-${col}`] = entry;
|
||||
|
||||
const backgroundColor = (ratio: number) => {
|
||||
const clr = colorLerp(ratio, { r: 42, g: 121, b: 82 }, {
|
||||
r: 247,
|
||||
g: 203,
|
||||
b: 21,
|
||||
}, {
|
||||
r: 167,
|
||||
g: 29,
|
||||
b: 49,
|
||||
});
|
||||
return `rgb(${clr.r}, ${clr.g}, ${clr.b})`;
|
||||
const perfColor = (ratio: number) => {
|
||||
const clr = colorLerp(ratio, GREEN, YELLOW, RED);
|
||||
return colorToString(clr);
|
||||
};
|
||||
|
||||
const span = document.createElement("span");
|
||||
span.style.backgroundColor = backgroundColor(
|
||||
Math.log10(entry.covers) / maxCovers,
|
||||
);
|
||||
span.style.backgroundColor = mode === "performance"
|
||||
? perfColor(
|
||||
Math.log10(entry.covers) / maxPerfCovers,
|
||||
)
|
||||
: entry.covers > 0
|
||||
? colorToString(GREEN)
|
||||
: colorToString(RED);
|
||||
span.innerText = text[index];
|
||||
span.dataset.covers = entry.covers.toString();
|
||||
elements.push(span);
|
||||
@ -128,4 +144,5 @@ export function loadCodeCoverage(
|
||||
tooltip.style.top = `${event.clientY + 20}px`;
|
||||
tooltip.innerText = `Ran ${covers} time${covers !== 1 ? "s" : ""}`;
|
||||
});
|
||||
return container;
|
||||
}
|
||||
|
@ -1,4 +1,4 @@
|
||||
import { loadCodeCoverage } from "./code_coverage.ts";
|
||||
import { CodeCovRender, loadCodeCoverage } from "./code_coverage.ts";
|
||||
import * as data from "./data.ts";
|
||||
import { loadFlameGraph } from "./flamegraph.ts";
|
||||
|
||||
@ -69,6 +69,7 @@ async function codeCoverage(view: Element, codeData: string) {
|
||||
function createRadio(
|
||||
id: string,
|
||||
content: string,
|
||||
checked: boolean,
|
||||
): [HTMLDivElement, HTMLInputElement] {
|
||||
const label = document.createElement("label");
|
||||
label.htmlFor = id;
|
||||
@ -78,6 +79,7 @@ async function codeCoverage(view: Element, codeData: string) {
|
||||
input.name = "coverage-radio";
|
||||
input.type = "radio";
|
||||
input.hidden = true;
|
||||
input.checked = checked;
|
||||
const container = document.createElement("div");
|
||||
container.classList.add("coverage-radio-group");
|
||||
container.append(input, label);
|
||||
@ -85,29 +87,43 @@ async function codeCoverage(view: Element, codeData: string) {
|
||||
}
|
||||
const [perfGroup, perfInput] = createRadio(
|
||||
"performance-coverage",
|
||||
"Performance",
|
||||
"Performance view",
|
||||
true,
|
||||
);
|
||||
const [testGroup, testRadio] = createRadio("test-coverage", "Test");
|
||||
const [testGroup, testInput] = createRadio(
|
||||
"test-coverage",
|
||||
"Test view",
|
||||
false,
|
||||
);
|
||||
|
||||
function load(mode: CodeCovRender, tooltip: HTMLDivElement) {
|
||||
const lines = createLineElement(codeData);
|
||||
const code = loadCodeCoverage(
|
||||
codeData,
|
||||
codeCoverageData,
|
||||
tooltip,
|
||||
mode,
|
||||
);
|
||||
innerContainer.replaceChildren(lines, code);
|
||||
}
|
||||
|
||||
const radios = document.createElement("div");
|
||||
radios.append(perfGroup, testGroup);
|
||||
radios.classList.add("coverage-radio");
|
||||
|
||||
const tooltip = document.createElement("div");
|
||||
tooltip.id = "covers-tooltip";
|
||||
tooltip.hidden = true;
|
||||
const code = document.createElement("pre");
|
||||
code.classList.add("code-source");
|
||||
loadCodeCoverage(
|
||||
codeData,
|
||||
codeCoverageData,
|
||||
code,
|
||||
tooltip,
|
||||
);
|
||||
const lines = createLineElement(codeData);
|
||||
innerContainer.append(lines, code);
|
||||
outerContainer.append(innerContainer);
|
||||
view.replaceChildren(outerContainer, tooltip, radios);
|
||||
|
||||
if (perfInput.checked) {
|
||||
load("performance", tooltip);
|
||||
} else if (testInput.checked) {
|
||||
load("test-coverage", tooltip);
|
||||
}
|
||||
|
||||
perfInput.addEventListener("input", () => load("performance", tooltip));
|
||||
testInput.addEventListener("input", () => load("test-coverage", tooltip));
|
||||
}
|
||||
|
||||
async function main() {
|
||||
|
@ -131,6 +131,7 @@ main #cover {
|
||||
#views-nav input:checked + label {
|
||||
background-color: var(--code-status);
|
||||
color: var(--black);
|
||||
font-weight: bold;
|
||||
}
|
||||
|
||||
#views-layout {
|
||||
@ -176,6 +177,8 @@ main #cover {
|
||||
|
||||
.coverage-radio-group input:checked ~ label {
|
||||
background-color: var(--code-status);
|
||||
color: var(--black);
|
||||
font-weight: bold;
|
||||
}
|
||||
|
||||
#flame-graph {
|
||||
|
Loading…
Reference in New Issue
Block a user