From 37d33d8265d19dc71b7c3f16f77a850a56a02e66 Mon Sep 17 00:00:00 2001 From: Denis Moslavac <44575706+Den1552@users.noreply.github.com> Date: Thu, 29 Aug 2024 16:46:20 +0200 Subject: [PATCH] Added E2E for #114 (#183) ## Summary Added E2E for #114. Creating new TST that imports an coded test. Check in E2E if we can edit the coded test with `// vmock` autocompletion. ## Added `vcast_coded_tests_relative_path.test.ts` E2E test. Added `import_coded_tests` spec group. --- .../vcast_coded_tests_relative_path.test.ts | 183 ++++++++++++++++++ tests/internal/e2e/test/specs_config.ts | 6 + tests/internal/e2e/test/wdio.conf.ts | 9 +- 3 files changed, 192 insertions(+), 6 deletions(-) create mode 100644 tests/internal/e2e/test/specs/vcast_coded_tests_relative_path.test.ts diff --git a/tests/internal/e2e/test/specs/vcast_coded_tests_relative_path.test.ts b/tests/internal/e2e/test/specs/vcast_coded_tests_relative_path.test.ts new file mode 100644 index 00000000..6aa460f9 --- /dev/null +++ b/tests/internal/e2e/test/specs/vcast_coded_tests_relative_path.test.ts @@ -0,0 +1,183 @@ +// Test/specs/vcast.test.ts +import { + type BottomBarPanel, + type TextEditor, + type Workbench, + type TreeItem, +} from "wdio-vscode-service"; +import { Key } from "webdriverio"; +import { + getViewContent, + findSubprogram, + updateTestID, + expandWorkspaceFolderSectionInExplorer, + getTestHandle, +} from "../test_utils/vcast_utils"; + +describe("vTypeCheck VS Code Extension", () => { + let bottomBar: BottomBarPanel; + let workbench: Workbench; + const TIMEOUT = 20_000; + before(async () => { + workbench = await browser.getWorkbench(); + // Opening bottom bar and problems view before running any tests + bottomBar = workbench.getBottomBar(); + await bottomBar.toggle(true); + process.env.E2E_TEST_ID = "0"; + }); + + it("test 1: should be able to load VS Code", async () => { + await updateTestID(); + expect(await workbench.getTitleBar().getTitle()).toBe( + "[Extension Development Host] vcastTutorial - Visual Studio Code" + ); + }); + + it("should activate vcastAdapter", async () => { + await updateTestID(); + + await browser.keys([Key.Control, Key.Shift, "p"]); + // Typing Vector in the quick input box + // This brings up VectorCAST Test Explorer: Configure + // so just need to hit Enter to activate + for (const character of "vector") { + await browser.keys(character); + } + + await browser.keys(Key.Enter); + + const activityBar = workbench.getActivityBar(); + const viewControls = await activityBar.getViewControls(); + for (const viewControl of viewControls) { + console.log(await viewControl.getTitle()); + } + + await bottomBar.toggle(true); + const outputView = await bottomBar.openOutputView(); + + console.log("Waiting for VectorCAST activation"); + await $("aria/VectorCAST Test Pane Initialization"); + console.log("WAITING FOR TESTING"); + await browser.waitUntil( + async () => (await activityBar.getViewControl("Testing")) !== undefined, + { timeout: TIMEOUT } + ); + console.log("WAITING FOR TEST EXPLORER"); + await browser.waitUntil(async () => + (await outputView.getChannelNames()) + .toString() + .includes("VectorCAST Test Explorer") + ); + await outputView.selectChannel("VectorCAST Test Explorer"); + console.log("Channel selected"); + console.log("WAITING FOR LANGUAGE SERVER"); + await browser.waitUntil( + async () => + (await outputView.getText()) + .toString() + .includes("Starting the language server"), + { timeout: TIMEOUT } + ); + + const testingView = await activityBar.getViewControl("Testing"); + await testingView?.openView(); + }); + + it("should set default config file", async () => { + await updateTestID(); + + const workbench = await browser.getWorkbench(); + const activityBar = workbench.getActivityBar(); + const explorerView = await activityBar.getViewControl("Explorer"); + await explorerView?.openView(); + + const workspaceFolderSection = + await expandWorkspaceFolderSectionInExplorer("vcastTutorial"); + + const configFile = await workspaceFolderSection.findItem("CCAST_.CFG"); + await configFile.openContextMenu(); + await (await $("aria/Set as VectorCAST Configuration File")).click(); + }); + + it("should enable coded test", async () => { + await updateTestID(); + + const workbench = await browser.getWorkbench(); + const settingsEditor = await workbench.openSettings(); + console.log("Looking for coded tests settings"); + await settingsEditor.findSetting( + "vectorcastTestExplorer.enableCodedTesting" + ); + // Only one setting in search results, so the current way of clicking is correct + console.log("Enabling coded tests"); + await (await settingsEditor.checkboxSetting$).click(); + await workbench.getEditorView().closeAllEditors(); + }); + + it("should check for vmock code completion", async () => { + await updateTestID(); + + console.log("Opening Testing View"); + const vcastTestingViewContent = await getViewContent("Testing"); + + let subprogram: TreeItem; + let testHandle: TreeItem; + + // Iterate over sections to find the "moo" subprogram and expand it + for (const section of await vcastTestingViewContent.getSections()) { + subprogram = await findSubprogram("moo", section); + if (subprogram) { + // Expand the subprogram if it's not already expanded + if (!(await subprogram.isExpanded())) await subprogram.expand(); + console.log("Getting test handle"); + + testHandle = await getTestHandle( + subprogram, + "Coded Tests", + "mooTests.ExampleTestCase", + 1 + ); + + if (testHandle) break; + throw new Error("Test handle not found for mooTests.ExampleTestCase"); + } + } + + expect(testHandle).not.toBe(undefined); + + let contextMenu = await testHandle.openContextMenu(); + await contextMenu.select("VectorCAST"); + + let menuElement = await $("aria/Edit Coded Test"); + await menuElement.click(); + + // Wait until the "tests.cpp" tab is active in the editor view + const editorView = workbench.getEditorView(); + await browser.waitUntil( + async () => + (await (await editorView.getActiveTab()).getTitle()) === "tests.cpp" + ); + + // Open the "tests.cpp" file in the editor and trigger code completion + const tab = (await editorView.openEditor("tests.cpp")) as TextEditor; + await browser.keys([Key.Ctrl, Key.Space]); + + const contentAssist = await tab.toggleContentAssist(true); + + // Just do some autocompletion to see if we can edit the Coded Test + await tab.setTextAtLine(14, "// vmock"); + let currentLine = await tab.getLineOfText("// vmock"); + await tab.typeTextAt(currentLine, "// vmock".length + 1, " "); + await tab.save(); + await browser.waitUntil( + async () => (await contentAssist.getItems()).length > 0 + ); + + // Validating content assist for '// vmock' + const expectedItems = ["moo", "Prototype-Stubs"]; + + for (const item of expectedItems) { + expect(await contentAssist.hasItem(item)).toBe(true); + } + }); +}); diff --git a/tests/internal/e2e/test/specs_config.ts b/tests/internal/e2e/test/specs_config.ts index a6711fd4..d418ba28 100755 --- a/tests/internal/e2e/test/specs_config.ts +++ b/tests/internal/e2e/test/specs_config.ts @@ -119,6 +119,12 @@ export function getSpecGroups(useVcast24: boolean) { env: {}, params: {}, }; + + specGroups["import_coded_test"] = { + specs: ["./**/**/vcast_coded_tests_relative_path.test.ts"], + env: { IMPORT_CODED_TEST_IN_TST: "True" }, + params: {}, + }; } return specGroups; diff --git a/tests/internal/e2e/test/wdio.conf.ts b/tests/internal/e2e/test/wdio.conf.ts index 9de1bbb2..de567d2c 100755 --- a/tests/internal/e2e/test/wdio.conf.ts +++ b/tests/internal/e2e/test/wdio.conf.ts @@ -335,7 +335,7 @@ export const config: Options.Testrunner = { if (envKey) { // Execute the corresponding function if an environment variable is found - await envActions.get(envKey)!(); + await envActions.get(envKey)(); } else { // Default case if no matching environment variable is found await setupSingleEnvironment(initialWorkdir); @@ -426,7 +426,7 @@ export const config: Options.Testrunner = { } /** - * Builds one env with 2024sp3 and switches to vc24__101394_store_mock_info at the end. + * Builds one env with 2024sp3 and switches to vc24 at the end. * TARGET SPEC GROUP: coded_mock_different_env */ async function setupSingleEnvAndImportCT(initialWorkdir: string) { @@ -444,7 +444,7 @@ export const config: Options.Testrunner = { ); let vcastRoot = await getVcastRoot(); - const newVersion = "vc24__101394_store_mock_info"; + const newVersion = "release24"; // Set up environment directory process.env.VECTORCAST_DIR = path.join(vcastRoot, newVersion); @@ -457,9 +457,6 @@ export const config: Options.Testrunner = { await executeRGWCommands(testInputVcastTutorial); await copyPathsToTestLocation(testInputVcastTutorial); - // Log that SWITCH_ENV_AT_THE_END is being defined - console.log("SWITCH_ENV_AT_THE_END IS DEFINED"); - // Define paths and content for the necessary test files const unitFileContent = `void foo (void){}`; const unitFile = path.join(workspacePath, "moo.cpp");