Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Categorise test cases into test suite(s) #247

Closed
wants to merge 3 commits into from
Closed
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
86 changes: 76 additions & 10 deletions src/tests.ts
Original file line number Diff line number Diff line change
Expand Up @@ -4,18 +4,73 @@ import { Tests, DebugEnvironmentConfiguration } from "./types";
import { getMesonTests, getMesonTargets } from "./introspection";
import { workspaceState } from "./extension";

export async function rebuildTests(controller: vscode.TestController) {
let tests = await getMesonTests(workspaceState.get<string>("mesonbuild.buildDir")!);
function addMesonTestsToController(
controller: vscode.TestController,
tests: Tests,
): WeakMap<vscode.TestItem, boolean> | null {
/* returns a WeakMap (value True) for TestItems with corresponding Meson
* tests. If a TestItem is not in the WeakMap, then the TestItem is outdated.
* If 0 existing TestItems, then there is nothing outdated, returns null.
*/
const testsVisited = new WeakMap<vscode.TestItem, boolean>();
const emptyController = controller.items.size == 0;
for (const test of tests) {
if (test.suite == undefined || test.suite.length == 0) {
const testItem = controller.createTestItem(test.name, test.name);
controller.items.add(testItem);
if (!emptyController) {
testsVisited.set(testItem, true);
}
} else {
/* if test suite(s) are defined, create TestItems as children */
for (const suiteLabel of test.suite) {
let suite = controller.items.get(suiteLabel);
if (suite == undefined) {
suite = controller.createTestItem(suiteLabel, suiteLabel);
controller.items.add(suite);
}
if (!emptyController) {
testsVisited.set(suite, true);
}
let testItem = suite.children.get(test.name);
if (testItem == undefined) {
testItem = controller.createTestItem(test.name, test.name);
suite.children.add(testItem);
}
if (!emptyController) {
testsVisited.set(testItem, true);
}
}
}
}
return emptyController ? null : testsVisited;
}

controller.items.forEach((item) => {
if (!tests.some((test) => item.id == test.name)) {
controller.items.delete(item.id);
function deleteTestsFromControllerNotVisited(
controller: vscode.TestController,
testsVisited: WeakMap<vscode.TestItem, boolean>,
) {
for (const [testId, test] of controller.items) {
if (testsVisited.get(test) == undefined) {
for (const [ChildId] of test.children) {
test.children.delete(ChildId);
}
controller.items.delete(testId);
} else {
for (const [ChildId, child] of test.children) {
if (testsVisited.get(child) == undefined) {
test.children.delete(ChildId);
}
}
}
});
}
}

for (let testDescr of tests) {
let testItem = controller.createTestItem(testDescr.name, testDescr.name);
controller.items.add(testItem);
export async function rebuildTests(controller: vscode.TestController) {
const tests = await getMesonTests(workspaceState.get<string>("mesonbuild.buildDir")!);
const testsVisited = addMesonTestsToController(controller, tests);
if (testsVisited != null) {
deleteTestsFromControllerNotVisited(controller, testsVisited);
}
}

Expand All @@ -38,10 +93,21 @@ export async function testRunHandler(
for (let test of queue) {
run.started(test);
let starttime = Date.now();
let suite = "";
let testCase = "";
if (test.children.size > 0) {
suite = `--suite="${test.id}"`;
} else if (test.parent != undefined) {
suite = `--suite="${test.parent.id}"`;
testCase = `"${test.id}"`;
} else {
testCase = `"${test.id}"`;
}

try {
await exec(
extensionConfiguration("mesonPath"),
["test", "-C", buildDir, "--print-errorlog", `"${test.id}"`],
["test", "-C", buildDir, "--print-errorlog", suite, testCase],
extensionConfiguration("testEnvironment"),
);
let duration = Date.now() - starttime;
Expand Down
Loading