From bc430fe721c539c4f145be0e0f76b87fac51190f Mon Sep 17 00:00:00 2001 From: Michael Weng Date: Wed, 4 Dec 2024 16:27:23 -0500 Subject: [PATCH] Make dependency integration test not flaky (#1245) --- .../commands/dependency.test.ts | 17 +++++++---------- 1 file changed, 7 insertions(+), 10 deletions(-) diff --git a/test/integration-tests/commands/dependency.test.ts b/test/integration-tests/commands/dependency.test.ts index cc4f9e26..b8e8d030 100644 --- a/test/integration-tests/commands/dependency.test.ts +++ b/test/integration-tests/commands/dependency.test.ts @@ -25,11 +25,7 @@ import { FolderContext } from "../../../src/FolderContext"; import { WorkspaceContext } from "../../../src/WorkspaceContext"; import * as sinon from "sinon"; import { Commands } from "../../../src/commands"; -import { - activateExtensionForSuite, - activateExtensionForTest, - folderInRootWorkspace, -} from "../utilities/testutilities"; +import { activateExtensionForSuite, folderInRootWorkspace } from "../utilities/testutilities"; suite("Dependency Commmands Test Suite", function () { // full workflow's interaction with spm is longer than the default timeout @@ -82,7 +78,7 @@ suite("Dependency Commmands Test Suite", function () { let treeProvider: PackageDependenciesProvider; let item: PackageNode; - activateExtensionForTest({ + activateExtensionForSuite({ async setup(ctx) { // Check before each test case start: // Expect to fail without setting up local version @@ -111,13 +107,14 @@ suite("Dependency Commmands Test Suite", function () { // Contract: spm edit with user supplied local version of dependency const windowMock = sinon.stub(vscode.window, "showOpenDialog"); windowMock.resolves([testAssetUri("Swift-Markdown")]); - const result = await vscode.commands.executeCommand( - Commands.USE_LOCAL_DEPENDENCY, - item - ); + let result = await vscode.commands.executeCommand(Commands.USE_LOCAL_DEPENDENCY, item); expect(result).to.be.true; windowMock.restore(); + // Make sure new dependencies resolve before building + result = await vscode.commands.executeCommand(Commands.RESOLVE_DEPENDENCIES); + expect(result).to.be.true; + // This will now pass as we have the required library const { exitCode, output } = await executeTaskAndWaitForResult(tasks); expect(exitCode, `${output}`).to.equal(0);