Skip to content

Commit

Permalink
chore: use upstream treeTree
Browse files Browse the repository at this point in the history
  • Loading branch information
pavelfeldman committed Mar 9, 2024
1 parent ffde759 commit aecbeb6
Show file tree
Hide file tree
Showing 10 changed files with 505 additions and 187 deletions.
25 changes: 15 additions & 10 deletions src/extension.ts
Original file line number Diff line number Diff line change
Expand Up @@ -319,8 +319,13 @@ export class Extension implements RunHooks {
}
}

this._settingsView.updateActions();
// VS Code has a bug, single profile is not marked as default.
if (this._models.length === 1 && this._models[0].allProjects().size === 1) {
const project = this._models[0].allProjects().values().next().value as TestProject;
project.isEnabled = true;
}

this._settingsView.updateActions();
this._testTree.finishedLoading();
await this._updateVisibleEditorItems();

Expand Down Expand Up @@ -372,11 +377,11 @@ export class Extension implements RunHooks {
const isDefault = false;
const supportsContinuousRun = this._settingsModel.allowWatchingFiles.get();
if (!runProfile)
runProfile = this._testController.createRunProfile(`${projectPrefix}${folderName}${path.sep}${configName}`, this._vscode.TestRunProfileKind.Run, this._scheduleTestRunRequest.bind(this, configFile, project.name, false), isDefault, undefined, supportsContinuousRun);
runProfile = this._testController.createRunProfile(`${projectPrefix}${folderName}${path.sep}${configName}`, this._vscode.TestRunProfileKind.Run, this._scheduleTestRunRequest.bind(this, configFile, project.name, false), isDefault, project.tag, supportsContinuousRun);
this._runProfiles.set(keyPrefix + ':run', runProfile);
let debugProfile = existingProfiles.get(keyPrefix + ':debug');
if (!debugProfile)
debugProfile = this._testController.createRunProfile(`${projectPrefix}${folderName}${path.sep}${configName}`, this._vscode.TestRunProfileKind.Debug, this._scheduleTestRunRequest.bind(this, configFile, project.name, true), isDefault, undefined, supportsContinuousRun);
debugProfile = this._testController.createRunProfile(`${projectPrefix}${folderName}${path.sep}${configName}`, this._vscode.TestRunProfileKind.Debug, this._scheduleTestRunRequest.bind(this, configFile, project.name, true), isDefault, project.tag, supportsContinuousRun);
this._runProfiles.set(keyPrefix + ':debug', debugProfile);

// Run profile has the current isEnabled value as per vscode.
Expand Down Expand Up @@ -471,7 +476,8 @@ export class Extension implements RunHooks {
const enqueuedTests: vscodeTypes.TestItem[] = [];

// Provisionally mark tests (not files and not suits) as enqueued to provide immediate feedback.
for (const item of include) {
const toEnqueue = include.length ? include : rootItems;
for (const item of toEnqueue) {
for (const test of this._testTree.collectTestsInside(item)) {
this._testRun.enqueued(test);
enqueuedTests.push(test);
Expand Down Expand Up @@ -586,16 +592,15 @@ located next to Run / Debug Tests toolbar buttons.`);
const testListener: reporterTypes.ReporterV2 = {
onBegin: (rootSuite: reporterTypes.Suite) => {
model.updateFromRunningProjects(rootSuite.suites);
const visitTest = (test: reporterTypes.TestCase) => {
const testItem = this._testTree.testItemForLocation(test.location, test.titlePath().slice(3));
for (const test of rootSuite.allTests()) {
const testItem = this._testTree.testItemForTest(test);
if (testItem)
testRun.enqueued(testItem);
};
rootSuite.allTests().forEach(visitTest);
}
},

onTestBegin: (test: reporterTypes.TestCase, result: reporterTypes.TestResult) => {
const testItem = this._testTree.testItemForLocation(test.location, test.titlePath().slice(3));
const testItem = this._testTree.testItemForTest(test);
if (testItem) {
testRun.started(testItem);
const fullProject = ancestorProject(test);
Expand All @@ -616,7 +621,7 @@ located next to Run / Debug Tests toolbar buttons.`);
this._activeSteps.clear();
this._executionLinesChanged();

const testItem = this._testTree.testItemForLocation(test.location, test.titlePath().slice(3));
const testItem = this._testTree.testItemForTest(test);
if (!testItem)
return;

Expand Down
2 changes: 1 addition & 1 deletion src/playwrightTest.ts
Original file line number Diff line number Diff line change
Expand Up @@ -210,7 +210,7 @@ export class PlaywrightTest {

{
// For tests.
const relativeLocations = escapedLocations.map(f => path.relative(configFolder, f));
const relativeLocations = locations.map(f => path.relative(configFolder, f)).map(escapeRegex).sort();
this._log(`${escapeRegex(path.relative(config.workspaceFolder, configFolder))}> playwright test -c ${configFile}${args.length ? ' ' + args.join(' ') : ''}${relativeLocations.length ? ' ' + relativeLocations.join(' ') : ''}`);
}
const allArgs = [config.cli, 'test',
Expand Down
5 changes: 4 additions & 1 deletion src/testModel.ts
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@ import { resolveSourceMap } from './utils';
import { ProjectConfigWithFiles } from './listTests';
import * as reporterTypes from './reporter';
import { TeleSuite } from './upstream/teleReceiver';
import path from 'path';

export type TestEntry = reporterTypes.TestCase | reporterTypes.Suite;

Expand All @@ -30,6 +31,7 @@ export type TestProject = {
suite: reporterTypes.Suite;
project: reporterTypes.FullProject;
isEnabled: boolean;
tag: vscodeTypes.TestTag;
};

export class TestModel {
Expand Down Expand Up @@ -130,6 +132,7 @@ export class TestModel {
suite: projectSuite,
project: projectSuite._project,
isEnabled: false,
tag: new this._vscode.TestTag(this.config.configFile + ':' + projectReport.name),
};
this._projects.set(project.name, project);
return project;
Expand Down Expand Up @@ -231,7 +234,7 @@ export class TestModel {
private _mapFilesToSources(testDirs: string[], files: Set<string>): string[] {
const result = new Set<string>();
for (const file of files) {
if (!testDirs.some(t => file.startsWith(t + '/')))
if (!testDirs.some(t => file.startsWith(t + path.sep)))
continue;
const sources = this._fileToSources.get(file);
if (sources)
Expand Down
Loading

0 comments on commit aecbeb6

Please sign in to comment.