diff --git a/.github/workflows/build-and-test.yml b/.github/workflows/build-and-test.yml index 87bb891cd..50a3e0205 100644 --- a/.github/workflows/build-and-test.yml +++ b/.github/workflows/build-and-test.yml @@ -45,7 +45,7 @@ jobs: matrix: node-version: [12.16.2] java-version: ['8', '11'] - os: [ubuntu-latest, windows-latest] # unable to test on macos-latest, see https://github.com/microsoft/vscode/issues/98080 + os: [ubuntu-latest, windows-latest, macos-latest] steps: - uses: actions/checkout@v1 - name: Use Node ${{ matrix.node-version }} diff --git a/extension/src/test/runTests.ts b/extension/src/test/runTests.ts index 303a53e4d..5909c82e3 100644 --- a/extension/src/test/runTests.ts +++ b/extension/src/test/runTests.ts @@ -1,11 +1,12 @@ /* eslint-disable sonarjs/no-duplicate-string */ import * as path from 'path'; -import { runTests } from 'vscode-test'; +import { runTests, downloadAndUnzipVSCode } from 'vscode-test'; const extensionDevelopmentPath = path.resolve(__dirname, '../../'); +const VSCODE_VERSION = '1.45.0'; -async function runTestsWithGradle(): Promise { +async function runTestsWithGradle(vscodeExecutablePath: string): Promise { const fixtures = [ 'gradle-groovy-default-build-file', 'gradle-kotlin-default-build-file', @@ -13,6 +14,7 @@ async function runTestsWithGradle(): Promise { ]; for (const fixture of fixtures) { await runTests({ + vscodeExecutablePath, extensionDevelopmentPath, extensionTestsPath: path.resolve(__dirname, 'gradle'), launchArgs: [ @@ -27,8 +29,9 @@ async function runTestsWithGradle(): Promise { } } -async function runTestsWithoutGradle(): Promise { - await runTests({ +function runTestsWithoutGradle(vscodeExecutablePath: string): Promise { + return runTests({ + vscodeExecutablePath, extensionDevelopmentPath, extensionTestsPath: path.resolve(__dirname, 'no-gradle'), launchArgs: [ @@ -41,8 +44,9 @@ async function runTestsWithoutGradle(): Promise { }); } -async function runTestsWithMultiRoot(): Promise { - await runTests({ +function runTestsWithMultiRoot(vscodeExecutablePath: string): Promise { + return runTests({ + vscodeExecutablePath, extensionDevelopmentPath, extensionTestsPath: path.resolve(__dirname, 'multi-root'), launchArgs: [ @@ -59,8 +63,11 @@ async function runTestsWithMultiRoot(): Promise { }); } -async function runTestsWithMultiProject(): Promise { - await runTests({ +async function runTestsWithMultiProject( + vscodeExecutablePath: string +): Promise { + return runTests({ + vscodeExecutablePath, extensionDevelopmentPath, extensionTestsPath: path.resolve(__dirname, 'multi-project'), launchArgs: [ @@ -76,11 +83,14 @@ async function runTestsWithMultiProject(): Promise { async function main(): Promise { try { - await runTestsWithGradle(); - await runTestsWithMultiRoot(); - await runTestsWithMultiProject(); - await runTestsWithoutGradle(); + const vscodeExecutablePath = await downloadAndUnzipVSCode(VSCODE_VERSION); + + await runTestsWithGradle(vscodeExecutablePath); + await runTestsWithMultiRoot(vscodeExecutablePath); + await runTestsWithMultiProject(vscodeExecutablePath); + await runTestsWithoutGradle(vscodeExecutablePath); } catch (err) { + console.error('Error running tests:', err.message); process.exit(1); } } diff --git a/extension/test-fixtures/gradle-groovy-custom-build-file/.vscode/settings.json b/extension/test-fixtures/gradle-groovy-custom-build-file/.vscode/settings.json new file mode 100644 index 000000000..756721312 --- /dev/null +++ b/extension/test-fixtures/gradle-groovy-custom-build-file/.vscode/settings.json @@ -0,0 +1,3 @@ +{ + "update.mode": "none" +} diff --git a/extension/test-fixtures/gradle-groovy-default-build-file/.gitignore b/extension/test-fixtures/gradle-groovy-default-build-file/.gitignore index 406e5d275..1b6985c00 100644 --- a/extension/test-fixtures/gradle-groovy-default-build-file/.gitignore +++ b/extension/test-fixtures/gradle-groovy-default-build-file/.gitignore @@ -3,6 +3,3 @@ # Ignore Gradle build output directory build - -# Ignore .vscode settings -.vscode diff --git a/extension/test-fixtures/gradle-groovy-default-build-file/.vscode/settings.json b/extension/test-fixtures/gradle-groovy-default-build-file/.vscode/settings.json new file mode 100644 index 000000000..756721312 --- /dev/null +++ b/extension/test-fixtures/gradle-groovy-default-build-file/.vscode/settings.json @@ -0,0 +1,3 @@ +{ + "update.mode": "none" +} diff --git a/extension/test-fixtures/gradle-kotlin-default-build-file/.vscode/settings.json b/extension/test-fixtures/gradle-kotlin-default-build-file/.vscode/settings.json new file mode 100644 index 000000000..756721312 --- /dev/null +++ b/extension/test-fixtures/gradle-kotlin-default-build-file/.vscode/settings.json @@ -0,0 +1,3 @@ +{ + "update.mode": "none" +} diff --git a/extension/test-fixtures/multi-project/.vscode/settings.json b/extension/test-fixtures/multi-project/.vscode/settings.json new file mode 100644 index 000000000..756721312 --- /dev/null +++ b/extension/test-fixtures/multi-project/.vscode/settings.json @@ -0,0 +1,3 @@ +{ + "update.mode": "none" +}