diff --git a/.github/workflows/pr-verify.yml b/.github/workflows/pr-verify.yml index e816cb9..56da4ff 100644 --- a/.github/workflows/pr-verify.yml +++ b/.github/workflows/pr-verify.yml @@ -16,10 +16,21 @@ jobs: strategy: fail-fast: true matrix: - os: [macos-latest, ubuntu-latest] + os: [ubuntu-latest] node: - 20 steps: + - run: sudo apt-get install erlang + if: runner.os == 'Linux' + - run: | + brew install erlang@26 + if: runner.os =='macOS' + - run: | + VERSION=$(ls /opt/homebrew/Cellar/erlang/) + export PATH=$PATH:/opt/homebrew/Cellar/erlang/$VERSION/bin + erl -version + name: setup path + if: runner.os =='macOS' - name: Checkout Source uses: actions/checkout@v4 - name: Install Node ${{ matrix.node }} @@ -31,4 +42,7 @@ jobs: - run: xvfb-run -a npm test if: runner.os == 'Linux' - run: npm test - if: runner.os != 'Linux' + if: runner.os != 'Linux' + - run: | + ./rebar3 ct + diff --git a/.vscode-test.mjs b/.vscode-test.mjs index 3038345..691da53 100644 --- a/.vscode-test.mjs +++ b/.vscode-test.mjs @@ -2,4 +2,9 @@ import { defineConfig } from '@vscode/test-cli'; export default defineConfig({ files: 'out/test/**/*.test.js', + workspaceFolder: './test/test-fixtures', + mocha: { + ui: 'tdd', + timeout: 60000 + } }); \ No newline at end of file diff --git a/.vscode/launch.json b/.vscode/launch.json index 6f6cfc1..35fa8fa 100644 --- a/.vscode/launch.json +++ b/.vscode/launch.json @@ -36,14 +36,14 @@ "request": "launch", "runtimeExecutable": "${execPath}", "args": [ - "${workspaceFolder}/test-temp/", + "${workspaceFolder}/test/test-fixtures/", "--disable-extensions", "--extensionDevelopmentPath=${workspaceFolder}", "--extensionTestsPath=${workspaceRoot}/out/test/test-suite" ], "sourceMaps": true, "outFiles": ["${workspaceFolder}/out/**/*.js"], - // "preLaunchTask": "prepareTest", + "preLaunchTask": "prepareTest", // "postDebugTask": "cleanTestFolder" } ] diff --git a/.vscode/tasks.json b/.vscode/tasks.json index 4adcf2b..2481fa9 100644 --- a/.vscode/tasks.json +++ b/.vscode/tasks.json @@ -9,5 +9,12 @@ // A task runner that calls a custom npm script that compiles the extension. { "version": "2.0.0", - "tasks": [] + "tasks": [ + { + "label": "prepareTest", + "dependsOn": [ + "npm: pretest" + ] + }, + ] } diff --git a/.vscodeignore b/.vscodeignore index 0e11be5..ddaebe1 100644 --- a/.vscodeignore +++ b/.vscodeignore @@ -18,3 +18,5 @@ node_modules src/ tsconfig.json webpack.config.js +.vscode-test/** + diff --git a/lib/lsp/lsp-context.ts b/lib/lsp/lsp-context.ts index be62e1d..6803a15 100644 --- a/lib/lsp/lsp-context.ts +++ b/lib/lsp/lsp-context.ts @@ -22,7 +22,7 @@ export class ErlangLanguageClient extends LanguageClient { // // For user-interactive operations (e.g. applyFixIt, applyTweaks), we will // prompt up the failure to users. - outChannel: vscode.OutputChannel; + outChannel?: vscode.OutputChannel; handleFailedRequest(type: MessageSignature, error: any, defaultValue: T): T { @@ -43,7 +43,7 @@ export class ErlangLanguageClient extends LanguageClient { onReady(): Promise { - this.outChannel.appendLine("LanguageClient is ready"); + this.outChannel?.appendLine("LanguageClient is ready"); clientIsReady = true; return super.onReady(); } diff --git a/test/runTest.ts b/test/runTest.ts deleted file mode 100644 index 04e0e9a..0000000 --- a/test/runTest.ts +++ /dev/null @@ -1,23 +0,0 @@ -import * as path from 'path'; - -import { runTests } from '@vscode/test-electron'; - -async function main() { - try { - // The folder containing the Extension Manifest package.json - // Passed to `--extensionDevelopmentPath` - const extensionDevelopmentPath = path.resolve(__dirname, '../../'); - - // The path to the extension test script - // Passed to --extensionTestsPath - const extensionTestsPath = path.resolve(__dirname, './test-suite/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 diff --git a/test/test-fixtures/fixture-navigation/navigation_source.erl b/test/test-fixtures/fixture-navigation/navigation_source.erl new file mode 100644 index 0000000..ff5e053 --- /dev/null +++ b/test/test-fixtures/fixture-navigation/navigation_source.erl @@ -0,0 +1,12 @@ +-module(navigation_source). + +-export([start/0]). + +start() -> + L = [1,2,3,4,5,6,7,8], + lists:filter(fun myfilter1/1, L), + lists:filter(fun navigation_target:myexportedfilter/1, L). + + +myfilter1(_X) -> + true. \ No newline at end of file diff --git a/test/test-fixtures/fixture-navigation/navigation_target.erl b/test/test-fixtures/fixture-navigation/navigation_target.erl new file mode 100644 index 0000000..c852f82 --- /dev/null +++ b/test/test-fixtures/fixture-navigation/navigation_target.erl @@ -0,0 +1,7 @@ +-module(navigation_target). + + +-export([myexportedfilter/1]). + +myexportedfilter(_X) -> + ok. \ No newline at end of file diff --git a/test/test-fixtures/fixture1/fixture1.erl b/test/test-fixtures/fixture1/fixture1.erl new file mode 100644 index 0000000..aafc343 --- /dev/null +++ b/test/test-fixtures/fixture1/fixture1.erl @@ -0,0 +1,5 @@ +-module(fixture1). + + +start() -> ok. + diff --git a/test/test-suite/extension.test.ts b/test/test-suite/extension.test.ts index d9459df..d96aae1 100644 --- a/test/test-suite/extension.test.ts +++ b/test/test-suite/extension.test.ts @@ -4,12 +4,49 @@ import * as fs from 'fs'; import * as path from 'path'; import { env } from 'process'; import * as vscode from 'vscode'; +import * as vscodeclient from 'vscode-languageclient' +import * as erlExtension from '../../lib/extension'; + + + +function openTextDocument(fileRelativePath: string ) : Thenable +{ + const wk = vscode.workspace.workspaceFolders[0]; + if (!fileRelativePath.startsWith("/")) { + fileRelativePath = "/" + fileRelativePath; + } + const filepath = path.join(wk.uri.fsPath, fileRelativePath); + return vscode.workspace.openTextDocument(filepath); +} suite('Erlang Language Extension', () => { after(() => { vscode.window.showInformationMessage('All tests done!'); }); - test('Extension should be present', () => { - assert.ok(vscode.extensions.getExtension('pgourlain.erlang')); + test('Extension should be present', async () => { + const myExtension = vscode.extensions.getExtension('pgourlain.erlang'); + await myExtension.activate(); + assert.ok(myExtension); + }); + + test('Diagnostics should be generated', async () => { + //use console.info('...') to write on output during test + + const document = await openTextDocument("/fixture1/fixture1.erl"); + assert.ok(document != null); + assert.equal('erlang', document.languageId); + + const waitForDiags = new Promise((resolve, reject) => { + const disposeToken = vscode.languages.onDidChangeDiagnostics( + async (ev) => { + disposeToken.dispose(); + resolve(ev.uris); + } + ) + }); + const uris = await waitForDiags; + assert.equal(true, uris.length > 0); + const diags = vscode.languages.getDiagnostics(uris[0]); + assert.equal(1, diags.length); }); }); \ No newline at end of file