Skip to content

Commit

Permalink
fix #1298 remove vscode.startDebug command (#1300)
Browse files Browse the repository at this point in the history
* fix #1298 remove vscode.startDebug command

* fix code review comments

* added period as per code review comments
  • Loading branch information
DonJayamanne committed Oct 11, 2017
1 parent 9de9f70 commit e1ea437
Show file tree
Hide file tree
Showing 4 changed files with 73 additions and 165 deletions.
63 changes: 63 additions & 0 deletions src/client/unittests/common/debugLauncher.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,63 @@
import * as os from 'os';
import { CancellationToken, debug, OutputChannel, workspace, Uri } from 'vscode';
import { PythonSettings } from '../../common/configSettings';
import { execPythonFile } from './../../common/utils';
import { createDeferred } from './../../common/helpers';

const pythonSettings = PythonSettings.getInstance();
export function launchDebugger(rootDirectory: string, testArgs: string[], token?: CancellationToken, outChannel?: OutputChannel) {
const def = createDeferred<any>();
const launchDef = createDeferred<any>();
let outputChannelShown = false;
execPythonFile(pythonSettings.pythonPath, testArgs, rootDirectory, true, (data: string) => {
if (data.startsWith('READY' + os.EOL)) {
// debug socket server has started.
launchDef.resolve();
data = data.substring(('READY' + os.EOL).length);
}

if (!outputChannelShown) {
outputChannelShown = true;
outChannel.show();
}
outChannel.append(data);
}, token).catch(reason => {
if (!def.rejected && !def.resolved) {
def.reject(reason);
}
}).then(() => {
if (!def.rejected && !def.resolved) {
def.resolve();
}
}).catch(reason => {
if (!def.rejected && !def.resolved) {
def.reject(reason);
}
});

launchDef.promise.then(() => {
if (!Array.isArray(workspace.workspaceFolders) || workspace.workspaceFolders.length === 0) {
throw new Error('Please open a workspace');
}
let workspaceFolder = workspace.getWorkspaceFolder(Uri.file(rootDirectory));
if (!workspaceFolder) {
workspaceFolder = workspace.workspaceFolders[0];
}
return debug.startDebugging(workspaceFolder, {
"name": "Debug Unit Test",
"type": "python",
"request": "attach",
"localRoot": rootDirectory,
"remoteRoot": rootDirectory,
"port": pythonSettings.unitTest.debugPort,
"secret": "my_secret",
"host": "localhost"
});
}).catch(reason => {
if (!def.rejected && !def.resolved) {
def.reject(reason);
}
});

return def.promise;
}
57 changes: 3 additions & 54 deletions src/client/unittests/nosetest/runner.ts
Original file line number Diff line number Diff line change
Expand Up @@ -6,11 +6,8 @@ import { updateResults } from '../common/testUtils';
import { updateResultsFromXmlLogFile, PassCalculationFormulae } from '../common/xUnitParser';
import { run } from '../common/runner';
import { PythonSettings } from '../../common/configSettings';
import * as vscode from 'vscode';
import { execPythonFile } from './../../common/utils';
import { createDeferred } from './../../common/helpers';
import * as os from 'os';
import * as path from 'path';
import { launchDebugger } from '../common/debugLauncher';

const pythonSettings = PythonSettings.getInstance();
const WITH_XUNIT = '--with-xunit';
Expand Down Expand Up @@ -65,58 +62,10 @@ export function runTest(rootDirectory: string, tests: Tests, args: string[], tes

return promiseToGetXmlLogFile.then(() => {
if (debug === true) {
const def = createDeferred<any>();
const launchDef = createDeferred<any>();
const testLauncherFile = path.join(__dirname, '..', '..', '..', '..', 'pythonFiles', 'PythonTools', 'testlauncher.py');

// start the debug adapter only once we have started the debug process
// pytestlauncherargs
const nosetestlauncherargs = [rootDirectory, 'my_secret', pythonSettings.unitTest.debugPort.toString(), 'nose'];
let outputChannelShown = false;
execPythonFile(pythonSettings.pythonPath, [testLauncherFile].concat(nosetestlauncherargs).concat(noseTestArgs.concat(testPaths)), rootDirectory, true, (data: string) => {
if (data.startsWith('READY' + os.EOL)) {
// debug socket server has started
launchDef.resolve();
data = data.substring(('READY' + os.EOL).length);
}

if (!outputChannelShown) {
outputChannelShown = true;
outChannel.show();
}
outChannel.append(data);
}, token).catch(reason => {
if (!def.rejected && !def.resolved) {
def.reject(reason);
}
}).then(() => {
if (!def.rejected && !def.resolved) {
def.resolve();
}
}).catch(reason => {
if (!def.rejected && !def.resolved) {
def.reject(reason);
}
});

launchDef.promise.then(() => {
return vscode.commands.executeCommand('vscode.startDebug', {
"name": "Debug Unit Test",
"type": "python",
"request": "attach",
"localRoot": rootDirectory,
"remoteRoot": rootDirectory,
"port": pythonSettings.unitTest.debugPort,
"secret": "my_secret",
"host": "localhost"
});
}).catch(reason => {
if (!def.rejected && !def.resolved) {
def.reject(reason);
}
});

return def.promise;
const args = [testLauncherFile].concat(nosetestlauncherargs).concat(noseTestArgs.concat(testPaths));
return launchDebugger(rootDirectory, args, token, outChannel);
}
else {
return run(pythonSettings.unitTest.nosetestPath, noseTestArgs.concat(testPaths), rootDirectory, token, outChannel);
Expand Down
59 changes: 4 additions & 55 deletions src/client/unittests/pytest/runner.ts
Original file line number Diff line number Diff line change
Expand Up @@ -8,11 +8,8 @@ import { CancellationToken, OutputChannel } from 'vscode';
import { updateResultsFromXmlLogFile, PassCalculationFormulae } from '../common/xUnitParser';
import { run } from '../common/runner';
import { PythonSettings } from '../../common/configSettings';
import * as vscode from 'vscode';
import { execPythonFile } from './../../common/utils';
import { createDeferred } from './../../common/helpers';
import * as os from 'os';
import * as path from 'path';
import { launchDebugger } from '../common/debugLauncher';

const pythonSettings = PythonSettings.getInstance();

Expand Down Expand Up @@ -43,58 +40,10 @@ export function runTest(rootDirectory: string, tests: Tests, args: string[], tes
}
const testArgs = testPaths.concat(args, [`--junitxml=${xmlLogFile}`]);
if (debug) {
const def = createDeferred<any>();
const launchDef = createDeferred<any>();
const testLauncherFile = path.join(__dirname, '..', '..', '..', '..', 'pythonFiles', 'PythonTools', 'testlauncher.py');

// start the debug adapter only once we have started the debug process
// pytestlauncherargs
const pytestlauncherargs = [rootDirectory, 'my_secret', pythonSettings.unitTest.debugPort.toString(), 'pytest'];
let outputChannelShown = false;
execPythonFile(pythonSettings.pythonPath, [testLauncherFile].concat(pytestlauncherargs).concat(testArgs), rootDirectory, true, (data: string) => {
if (data.startsWith('READY' + os.EOL)) {
// debug socket server has started
launchDef.resolve();
data = data.substring(('READY' + os.EOL).length);
}

if (!outputChannelShown) {
outputChannelShown = true;
outChannel.show();
}
outChannel.append(data);
}, token).catch(reason => {
if (!def.rejected && !def.resolved) {
def.reject(reason);
}
}).then(() => {
if (!def.rejected && !def.resolved) {
def.resolve();
}
}).catch(reason => {
if (!def.rejected && !def.resolved) {
def.reject(reason);
}
});

launchDef.promise.then(() => {
return vscode.commands.executeCommand('vscode.startDebug', {
"name": "Debug Unit Test",
"type": "python",
"request": "attach",
"localRoot": rootDirectory,
"remoteRoot": rootDirectory,
"port": pythonSettings.unitTest.debugPort,
"secret": "my_secret",
"host": "localhost"
});
}).catch(reason => {
if (!def.rejected && !def.resolved) {
def.reject(reason);
}
});

return def.promise;
const args = [testLauncherFile].concat(pytestlauncherargs).concat(testArgs);
return launchDebugger(rootDirectory, args, token, outChannel);
}
else {
return run(pythonSettings.unitTest.pyTestPath, testArgs, rootDirectory, token, outChannel);
Expand All @@ -115,4 +64,4 @@ export function updateResultsFromLogFiles(tests: Tests, outputXmlFile: string):
updateResults(tests);
return tests;
});
}
}
59 changes: 3 additions & 56 deletions src/client/unittests/unittest/runner.ts
Original file line number Diff line number Diff line change
Expand Up @@ -9,10 +9,7 @@ import { CancellationToken, OutputChannel } from 'vscode';
import { run } from '../common/runner';
import { Server } from './socketServer';
import { PythonSettings } from '../../common/configSettings';
import * as vscode from 'vscode';
import { execPythonFile } from './../../common/utils';
import { createDeferred } from './../../common/helpers';
import * as os from 'os';
import { launchDebugger } from '../common/debugLauncher';

const settings = PythonSettings.getInstance();
interface TestStatusMap {
Expand Down Expand Up @@ -96,57 +93,7 @@ export function runTest(testManager: BaseTestManager, rootDirectory: string, tes
testArgs.push(`--testFile=${testFile}`);
}
if (debug === true) {
const def = createDeferred<any>();
const launchDef = createDeferred<any>();
let outputChannelShown = false;

// start the debug adapter only once we have started the debug process
execPythonFile(settings.pythonPath, [testLauncherFile].concat(testArgs), rootDirectory, true, (data: string) => {
if (data.startsWith('READY' + os.EOL)) {
// debug socket server has started
launchDef.resolve();
data = data.substring(('READY' + os.EOL).length);
}

if (!outputChannelShown) {
outputChannelShown = true;
outChannel.show();
}
outChannel.append(data);
}, token).catch(reason => {
if (!def.rejected && !def.resolved) {
def.reject(reason);
}
}).then(() => {
if (!def.rejected && !def.resolved) {
def.resolve();
}
}).catch(reason => {
if (!def.rejected && !def.resolved) {
def.reject(reason);
}
});

launchDef.promise
.then(() => {
return vscode.commands.executeCommand('vscode.startDebug', {
"name": "Debug Unit Test",
"type": "python",
"request": "attach",
"localRoot": rootDirectory,
"remoteRoot": rootDirectory,
"port": settings.unitTest.debugPort,
"secret": "my_secret",
"host": "localhost"
});
})
.catch(reason => {
if (!def.rejected && !def.resolved) {
def.reject(reason);
}
});

return def.promise;
return launchDebugger(rootDirectory, [testLauncherFile].concat(testArgs), token, outChannel);
}
else {
return run(settings.pythonPath, [testLauncherFile].concat(testArgs), rootDirectory, token, outChannel);
Expand Down Expand Up @@ -253,4 +200,4 @@ function getIdsOfTestsToRun(tests: Tests, testsToRun: TestsToRun): string[] {
testIds.push(...testsToRun.testFunction.map(f => f.nameToRun));
}
return testIds;
}
}

0 comments on commit e1ea437

Please sign in to comment.