summaryrefslogtreecommitdiff
path: root/client/src/test
diff options
context:
space:
mode:
Diffstat (limited to 'client/src/test')
-rw-r--r--client/src/test/completion.test.ts43
-rw-r--r--client/src/test/diagnostics.test.ts41
-rw-r--r--client/src/test/helper.ts47
-rw-r--r--client/src/test/index.ts43
-rw-r--r--client/src/test/runTest.ts27
5 files changed, 201 insertions, 0 deletions
diff --git a/client/src/test/completion.test.ts b/client/src/test/completion.test.ts
new file mode 100644
index 0000000..f355078
--- /dev/null
+++ b/client/src/test/completion.test.ts
@@ -0,0 +1,43 @@
+/* --------------------------------------------------------------------------------------------
+ * Copyright (c) Microsoft Corporation. All rights reserved.
+ * Licensed under the MIT License. See License.txt in the project root for license information.
+ * ------------------------------------------------------------------------------------------ */
+
+import * as vscode from 'vscode';
+import * as assert from 'assert';
+import { getDocUri, activate } from './helper';
+
+suite('Should do completion', () => {
+ const docUri = getDocUri('completion.txt');
+
+ test('Completes JS/TS in txt file', async () => {
+ await testCompletion(docUri, new vscode.Position(0, 0), {
+ items: [
+ { label: 'JavaScript', kind: vscode.CompletionItemKind.Text },
+ { label: 'TypeScript', kind: vscode.CompletionItemKind.Text }
+ ]
+ });
+ });
+});
+
+async function testCompletion(
+ docUri: vscode.Uri,
+ position: vscode.Position,
+ expectedCompletionList: vscode.CompletionList
+) {
+ await activate(docUri);
+
+ // Executing the command `vscode.executeCompletionItemProvider` to simulate triggering completion
+ const actualCompletionList = (await vscode.commands.executeCommand(
+ 'vscode.executeCompletionItemProvider',
+ docUri,
+ position
+ )) as vscode.CompletionList;
+
+ assert.ok(actualCompletionList.items.length >= 2);
+ expectedCompletionList.items.forEach((expectedItem, i) => {
+ const actualItem = actualCompletionList.items[i];
+ assert.equal(actualItem.label, expectedItem.label);
+ assert.equal(actualItem.kind, expectedItem.kind);
+ });
+}
diff --git a/client/src/test/diagnostics.test.ts b/client/src/test/diagnostics.test.ts
new file mode 100644
index 0000000..1aa8a36
--- /dev/null
+++ b/client/src/test/diagnostics.test.ts
@@ -0,0 +1,41 @@
+/* --------------------------------------------------------------------------------------------
+ * Copyright (c) Microsoft Corporation. All rights reserved.
+ * Licensed under the MIT License. See License.txt in the project root for license information.
+ * ------------------------------------------------------------------------------------------ */
+
+import * as vscode from 'vscode';
+import * as assert from 'assert';
+import { getDocUri, activate } from './helper';
+
+suite('Should get diagnostics', () => {
+ const docUri = getDocUri('diagnostics.txt');
+
+ test('Diagnoses uppercase texts', async () => {
+ await testDiagnostics(docUri, [
+ { message: 'ANY is all uppercase.', range: toRange(0, 0, 0, 3), severity: vscode.DiagnosticSeverity.Warning, source: 'ex' },
+ { message: 'ANY is all uppercase.', range: toRange(0, 14, 0, 17), severity: vscode.DiagnosticSeverity.Warning, source: 'ex' },
+ { message: 'OS is all uppercase.', range: toRange(0, 18, 0, 20), severity: vscode.DiagnosticSeverity.Warning, source: 'ex' }
+ ]);
+ });
+});
+
+function toRange(sLine: number, sChar: number, eLine: number, eChar: number) {
+ const start = new vscode.Position(sLine, sChar);
+ const end = new vscode.Position(eLine, eChar);
+ return new vscode.Range(start, end);
+}
+
+async function testDiagnostics(docUri: vscode.Uri, expectedDiagnostics: vscode.Diagnostic[]) {
+ await activate(docUri);
+
+ const actualDiagnostics = vscode.languages.getDiagnostics(docUri);
+
+ assert.equal(actualDiagnostics.length, expectedDiagnostics.length);
+
+ expectedDiagnostics.forEach((expectedDiagnostic, i) => {
+ const actualDiagnostic = actualDiagnostics[i];
+ assert.equal(actualDiagnostic.message, expectedDiagnostic.message);
+ assert.deepEqual(actualDiagnostic.range, expectedDiagnostic.range);
+ assert.equal(actualDiagnostic.severity, expectedDiagnostic.severity);
+ });
+} \ No newline at end of file
diff --git a/client/src/test/helper.ts b/client/src/test/helper.ts
new file mode 100644
index 0000000..6e6724d
--- /dev/null
+++ b/client/src/test/helper.ts
@@ -0,0 +1,47 @@
+/* --------------------------------------------------------------------------------------------
+ * Copyright (c) Microsoft Corporation. All rights reserved.
+ * Licensed under the MIT License. See License.txt in the project root for license information.
+ * ------------------------------------------------------------------------------------------ */
+
+import * as vscode from 'vscode';
+import * as path from 'path';
+
+export let doc: vscode.TextDocument;
+export let editor: vscode.TextEditor;
+export let documentEol: string;
+export let platformEol: string;
+
+/**
+ * Activates the vscode.lsp-sample extension
+ */
+export async function activate(docUri: vscode.Uri) {
+ // The extensionId is `publisher.name` from package.json
+ const ext = vscode.extensions.getExtension('vscode-samples.lsp-sample')!;
+ await ext.activate();
+ try {
+ doc = await vscode.workspace.openTextDocument(docUri);
+ editor = await vscode.window.showTextDocument(doc);
+ await sleep(2000); // Wait for server activation
+ } catch (e) {
+ console.error(e);
+ }
+}
+
+async function sleep(ms: number) {
+ return new Promise(resolve => setTimeout(resolve, ms));
+}
+
+export const getDocPath = (p: string) => {
+ return path.resolve(__dirname, '../../testFixture', p);
+};
+export const getDocUri = (p: string) => {
+ return vscode.Uri.file(getDocPath(p));
+};
+
+export async function setTestContent(content: string): Promise<boolean> {
+ const all = new vscode.Range(
+ doc.positionAt(0),
+ doc.positionAt(doc.getText().length)
+ );
+ return editor.edit(eb => eb.replace(all, content));
+}
diff --git a/client/src/test/index.ts b/client/src/test/index.ts
new file mode 100644
index 0000000..b9de4dc
--- /dev/null
+++ b/client/src/test/index.ts
@@ -0,0 +1,43 @@
+/* --------------------------------------------------------------------------------------------
+ * Copyright (c) Microsoft Corporation. All rights reserved.
+ * Licensed under the MIT License. See License.txt in the project root for license information.
+ * ------------------------------------------------------------------------------------------ */
+import * as path from 'path';
+import * as Mocha from 'mocha';
+import * as glob from 'glob';
+
+export function run(): Promise<void> {
+ // Create the mocha test
+ const mocha = new Mocha({
+ ui: 'tdd',
+ color: true
+ });
+ mocha.timeout(100000);
+
+ const testsRoot = __dirname;
+
+ return new Promise((resolve, reject) => {
+ glob('**.test.js', { cwd: testsRoot }, (err, files) => {
+ if (err) {
+ return reject(err);
+ }
+
+ // Add files to the test suite
+ files.forEach(f => mocha.addFile(path.resolve(testsRoot, f)));
+
+ try {
+ // Run the mocha test
+ mocha.run(failures => {
+ if (failures > 0) {
+ reject(new Error(`${failures} tests failed.`));
+ } else {
+ resolve();
+ }
+ });
+ } catch (err) {
+ console.error(err);
+ reject(err);
+ }
+ });
+ });
+} \ No newline at end of file
diff --git a/client/src/test/runTest.ts b/client/src/test/runTest.ts
new file mode 100644
index 0000000..aec71e3
--- /dev/null
+++ b/client/src/test/runTest.ts
@@ -0,0 +1,27 @@
+/*---------------------------------------------------------------------------------------------
+ * Copyright (c) Microsoft Corporation. All rights reserved.
+ * Licensed under the MIT License. See License.txt in the project root for license information.
+ *--------------------------------------------------------------------------------------------*/
+import * as path from 'path';
+
+import { runTests } from 'vscode-test';
+
+async function main() {
+ try {
+ // The folder containing the Extension Manifest package.json
+ // Passed to `--extensionDevelopmentPath`
+ const extensionDevelopmentPath = path.resolve(__dirname, '../../../');
+
+ // The path to test runner
+ // Passed to --extensionTestsPath
+ const extensionTestsPath = path.resolve(__dirname, './index');
+
+ // Download VS Code, unzip it and run the integration test
+ await runTests({ extensionDevelopmentPath, extensionTestsPath });
+ } catch (err) {
+ console.error('Failed to run tests');
+ process.exit(1);
+ }
+}
+
+main(); \ No newline at end of file