diff --git a/src/cli.ts b/src/cli.ts index a1f2e1dfc..6fb4af89c 100644 --- a/src/cli.ts +++ b/src/cli.ts @@ -35,9 +35,10 @@ program.command('install-vsix') .option('-f, --vsix_file ', 'path/URL to vsix file containing the extension') .option('-y, --yarn', 'Use yarn to build the extension via vsce instead of npm', false) .option('-t, --type ', 'Type of VSCode release (stable/insider)') + .option('-i, --install_dependencies', 'Automatically install extensions your extension depends on', false) .action(withErrors(async (cmd) => { const extest = new ExTester(cmd.storage, codeStream(cmd.type), cmd.extensions_dir); - await extest.installVsix({vsixFile: cmd.vsix_file, useYarn: cmd.yarn}); + await extest.installVsix({vsixFile: cmd.vsix_file, useYarn: cmd.yarn, installDependencies: cmd.install_dependencies}); })); program.command('install-from-marketplace [ids...]') diff --git a/src/extester.ts b/src/extester.ts index 40b52d6ca..066e0898b 100644 --- a/src/extester.ts +++ b/src/extester.ts @@ -54,7 +54,7 @@ export class ExTester { * @param vsixFile path to extension .vsix file. If not set, default vsce path will be used * @param useYarn when true run `vsce package` with the `--yarn` flag */ - async installVsix({vsixFile, useYarn}: {vsixFile?: string, useYarn?: boolean} = {}): Promise { + async installVsix({vsixFile, useYarn, installDependencies}: {vsixFile?: string, useYarn?: boolean, installDependencies?: boolean} = {}): Promise { let target = vsixFile; if (vsixFile) { try { @@ -73,7 +73,10 @@ export class ExTester { } else { await this.code.packageExtension(useYarn); } - return this.code.installExtension(target); + this.code.installExtension(target); + if (installDependencies) { + this.code.installDependencies(); + } } /** diff --git a/src/util/codeUtil.ts b/src/util/codeUtil.ts index 9a7495629..0b8933532 100644 --- a/src/util/codeUtil.ts +++ b/src/util/codeUtil.ts @@ -247,7 +247,7 @@ export class CodeUtil { process.env.TEST_RESOURCES = this.downloadFolder; process.env.EXTENSIONS_FOLDER = this.extensionsFolder; const runner = new VSRunner(this.executablePath, literalVersion, this.parseSettings(runOptions.settings ?? DEFAULT_RUN_OPTIONS.settings), runOptions.cleanup, this.releaseType, runOptions.config); - return runner.runTests(testFilesPattern, this, runOptions.logLevel, runOptions.resources); + return await runner.runTests(testFilesPattern, this, runOptions.logLevel, runOptions.resources); } /**