Skip to content
This repository has been archived by the owner on Jul 15, 2023. It is now read-only.

Commit

Permalink
Fix "gotests" when generates test for current function
Browse files Browse the repository at this point in the history
Issue:
"Generate unit tests for current function" fails with recent
vscode-go version. This due to the fact that the GoDocumentSymbolProvider
returns now also the receiverType in the name function.
example: before "DecodeJSON", after (*Volume).DecodeJSON
gotests bin is not able to understand this string with the option -only
since it is not a valid regular expression.

Fixes: #656
check is the function name contains a ".", if yes: returns only the
second part of the name that is corresponding to the function name
without the receiverType.
  • Loading branch information
clamoriniere committed Nov 28, 2016
1 parent 88dfe84 commit 1287b1f
Show file tree
Hide file tree
Showing 4 changed files with 76 additions and 27 deletions.
51 changes: 29 additions & 22 deletions src/goGenerateTests.ts
Original file line number Diff line number Diff line change
Expand Up @@ -76,7 +76,6 @@ export function generateTestCurrentPackage(): Thenable<boolean> {
return;
}
let dir = path.dirname(editor.document.uri.fsPath);
let message = 'Unit tests generated for package: ' + path.basename(dir);
return generateTests({ dir: dir });
}

Expand All @@ -86,33 +85,41 @@ export function generateTestCurrentFile(): Thenable<boolean> {
return;
}
let file = editor.document.uri.fsPath;
let message = 'Unit tests generated for file: ' + path.basename(file);
return generateTests({ dir: file });
}

export function generateTestCurrentFunction(): Thenable<boolean> {
let editor = checkActiveEditor();
if (!editor) {
return;
}
let file = editor.document.uri.fsPath;
getFunctions(editor.document).then(functions => {
let currentFunction: vscode.SymbolInformation;
for (let func of functions) {
let selection = editor.selection;
if (selection && func.location.range.contains(selection.start)) {
currentFunction = func;
break;
}
};
if (!currentFunction) {
vscode.window.setStatusBarMessage('No function found at cursor.', 5000);
return new Promise<boolean>((resolve, reject) => {
let editor = checkActiveEditor();
if (!editor) {
return;
}
let message = 'Unit test generated for function: ' + currentFunction.name + ' in file: ' + path.basename(file);
return generateTests({ dir: file, func: currentFunction.name });
}).then(null, err => {
console.error(err);
let file = editor.document.uri.fsPath;
getFunctions(editor.document).then(functions => {
let currentFunction: vscode.SymbolInformation;
for (let func of functions) {
let selection = editor.selection;
if (selection && func.location.range.contains(selection.start)) {
currentFunction = func;
break;
}
};
if (!currentFunction) {
vscode.window.setStatusBarMessage('No function found at cursor.', 5000);
return;
}
let funcName = currentFunction.name;
if (funcName.includes('.')) {
funcName = funcName.split('.')[1];
}
generateTests({ dir: file, func: funcName }).then((success: boolean) => {
if (success) {
resolve(true);
} else {
reject('Cannot generate test due to errors');
}
});
});
});
}

Expand Down
11 changes: 11 additions & 0 deletions test/fixtures/generatetests/generatetests.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
package generatetests

type obj struct {}

func (o obj) String() string {
return ""
}

func main() {
fmt.Println("do nothing")
}
2 changes: 1 addition & 1 deletion test/fixtures/test.go
Original file line number Diff line number Diff line change
Expand Up @@ -9,4 +9,4 @@ func print(txt string) {
}
func main() {
print("Hello")
}
}
39 changes: 35 additions & 4 deletions test/go.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -19,19 +19,25 @@ import { testCurrentFile } from '../src/goTest';
import { getGoVersion, isVendorSupported } from '../src/util';
import { documentSymbols } from '../src/goOutline';
import { listPackages } from '../src/goImport';
import { generateTestCurrentFile, generateTestCurrentPackage } from '../src/goGenerateTests';
import { generateTestCurrentFile, generateTestCurrentPackage, generateTestCurrentFunction } from '../src/goGenerateTests';
import { getBinPath } from '../src/goPath';

suite('Go Extension Tests', () => {
let gopath = process.env['GOPATH'];
let repoPath = path.join(gopath, 'src', 'test');
let fixturePath = path.join(repoPath, 'testfixture');
let fixtureSourcePath = path.join(__dirname, '..', '..', 'test', 'fixtures');
let generateTestsSourcePath = path.join(repoPath, 'generatetests');
let generateFunctionTestSourcePath = path.join(repoPath, 'generatefunctiontest');
let generatePackageTestSourcePath = path.join(repoPath, 'generatePackagetest');

suiteSetup(() => {
assert.ok(gopath !== null, 'GOPATH is not defined');
fs.removeSync(repoPath);
fs.copySync(path.join(fixtureSourcePath, 'test.go'), path.join(fixturePath, 'test.go'));
fs.copySync(path.join(fixtureSourcePath, 'generatetests', 'generatetests.go'), path.join(generateTestsSourcePath, 'generatetests.go'));
fs.copySync(path.join(fixtureSourcePath, 'generatetests', 'generatetests.go'), path.join(generateFunctionTestSourcePath, 'generatetests.go'));
fs.copySync(path.join(fixtureSourcePath, 'generatetests', 'generatetests.go'), path.join(generatePackageTestSourcePath, 'generatetests.go'));
fs.copySync(path.join(fixtureSourcePath, 'errorsTest', 'errors.go'), path.join(fixturePath, 'errorsTest', 'errors.go'));
fs.copySync(path.join(fixtureSourcePath, 'sample_test.go'), path.join(fixturePath, 'sample_test.go'));
fs.copySync(path.join(fixtureSourcePath, 'gogetdocTestData', 'test.go'), path.join(fixturePath, 'gogetdocTestData', 'test.go'));
Expand Down Expand Up @@ -236,7 +242,7 @@ It returns the number of bytes written and any write error encountered.
provider.provideCompletionItemsInternal(editor.document, position, null, config).then(items => {
let labels = items.map(x => x.label);
for (let entry of expected) {
assert.equal(labels.indexOf(entry) > -1, true, `missing expected item in competion list: ${entry} Actual: ${labels}`);
assert.equal(labels.indexOf(entry) > -1, true, `missing expected item in completion list: ${entry} Actual: ${labels}`);
}
})
);
Expand Down Expand Up @@ -283,7 +289,7 @@ It returns the number of bytes written and any write error encountered.
return Promise.resolve();
}

let uri = vscode.Uri.file(path.join(fixturePath, 'test.go'));
let uri = vscode.Uri.file(path.join(generateTestsSourcePath, 'generatetests.go'));
return vscode.workspace.openTextDocument(uri).then(document => {
return vscode.window.showTextDocument(document).then(editor => {
return generateTestCurrentFile().then((result: boolean) => {
Expand All @@ -298,14 +304,39 @@ It returns the number of bytes written and any write error encountered.
}).then(() => done(), done);
});

test('Test Generate unit tests squeleton for a function', (done) => {
getGoVersion().then(version => {
if (version.major === 1 && version.minor < 6) {
// gotests is not supported in Go 1.5, so skip the test
return Promise.resolve();
}

let uri = vscode.Uri.file(path.join(generateFunctionTestSourcePath, 'generatetests.go'));
return vscode.workspace.openTextDocument(uri).then(document => {
return vscode.window.showTextDocument(document).then((editor: vscode.TextEditor) => {
assert(vscode.window.activeTextEditor, 'No active editor');
let selection = new vscode.Selection(5, 0, 6, 0);
editor.selection = selection;
return generateTestCurrentFunction().then((result: boolean) => {
assert.equal(result, true);
return Promise.resolve();
});
});
}).then(() => {
vscode.commands.executeCommand('workbench.action.closeActiveEditor');
return Promise.resolve();
});
}).then(() => done(), done);
});

test('Test Generate unit tests squeleton for package', (done) => {
getGoVersion().then(version => {
if (version.major === 1 && version.minor < 6) {
// gotests is not supported in Go 1.5, so skip the test
return Promise.resolve();
}

let uri = vscode.Uri.file(path.join(fixturePath, 'test.go'));
let uri = vscode.Uri.file(path.join(generatePackageTestSourcePath, 'generatetests.go'));
return vscode.workspace.openTextDocument(uri).then(document => {
return vscode.window.showTextDocument(document).then(editor => {
return generateTestCurrentPackage().then((result: boolean) => {
Expand Down

0 comments on commit 1287b1f

Please sign in to comment.