diff --git a/e2e/pages/vscode.pages.ts b/e2e/pages/vscode.pages.ts index 9e4420a..dfc1bee 100644 --- a/e2e/pages/vscode.pages.ts +++ b/e2e/pages/vscode.pages.ts @@ -1,13 +1,13 @@ import { _electron as electron, ElectronApplication, - Frame, FrameLocator, Page, } from 'playwright'; import { execSync } from 'child_process'; import { downloadLatestKAIPlugin } from '../utilities/download.utils'; import { getKAIPluginName } from '../utilities/utils'; +import * as path from 'path'; class VSCode { private readonly vscodeApp?: ElectronApplication; @@ -19,10 +19,22 @@ class VSCode { } /** - * launches VSCode with KAI plugin installed. + * launches VSCode with KAI plugin installed and coolstore app opened. * @param executablePath path to the vscode binary + * @param repoUrl coolstore app to be cloned + * @param cloneDir path to repo */ - public static async init(executablePath: string): Promise { + public static async init( + executablePath: string, + repoUrl: string, + cloneDir: string + ): Promise { + try { + execSync(`git clone ${repoUrl}`); + } catch (error) { + throw new Error('Failed to clone the repository'); + } + try { const vsixFilePath = getKAIPluginName(); if (vsixFilePath) { @@ -37,10 +49,10 @@ class VSCode { // Launch VSCode as an Electron app const vscodeApp = await electron.launch({ executablePath: executablePath, + args: [path.resolve(cloneDir)], }); const window = await vscodeApp.firstWindow(); - return new VSCode(vscodeApp, window); } catch (error) { console.error('Error launching VSCode:', error); diff --git a/e2e/tests/vscode.test.ts b/e2e/tests/vscode.test.ts index 37f04f6..85280aa 100644 --- a/e2e/tests/vscode.test.ts +++ b/e2e/tests/vscode.test.ts @@ -1,5 +1,9 @@ import { test, expect } from '@playwright/test'; import { VSCode } from '../pages/vscode.pages'; +import { cleanupRepo } from '../utilities/utils'; + +// TODO : Get repo URL from fixtures +const repoUrl = 'https://github.com/konveyor-ecosystem/coolstore'; test.describe('VSCode Tests', () => { let vscodeApp: VSCode; @@ -8,7 +12,7 @@ test.describe('VSCode Tests', () => { test.setTimeout(60000); const executablePath = process.env.VSCODE_EXECUTABLE_PATH || '/usr/share/code/code'; - vscodeApp = await VSCode.init(executablePath); + vscodeApp = await VSCode.init(executablePath, repoUrl, 'coolstore'); }); test('Should launch VSCode and check window title', async () => { @@ -28,4 +32,8 @@ test.describe('VSCode Tests', () => { } await window.screenshot({ path: 'kai-installed-screenshot.png' }); }); + + test.afterAll(async () => { + await cleanupRepo(); + }); }); diff --git a/e2e/utilities/utils.ts b/e2e/utilities/utils.ts index 4e07181..5a0b940 100644 --- a/e2e/utilities/utils.ts +++ b/e2e/utilities/utils.ts @@ -1,4 +1,11 @@ import * as os from 'os'; +import * as fs from 'fs'; +import * as util from 'util'; +import { exec } from 'child_process'; +import * as path from 'path'; + +const execPromise = util.promisify(exec); +const repoDir = path.resolve('coolstore'); // Function to get OS information export function getOSInfo(): string { @@ -21,3 +28,15 @@ export function getKAIPluginName(): string { process.env.VSIX_FILE_NAME || 'konveyor-linux-0.0.1.vsix'; return vsixFileName.replace(/(konveyor-)(\w+)(-.*)/, `$1${getOSInfo()}$3`); } + +export async function cleanupRepo() { + if (fs.existsSync(repoDir)) { + try { + await execPromise(`rm -rf "${repoDir}"`); + } catch (error) { + console.error('Error while cleaning up cloned repository:', error); + } + } else { + console.warn(`Directory ${repoDir} does not exist, skipping cleanup.`); + } +} diff --git a/kai-client-ci/report/index.css b/kai-client-ci/report/index.css new file mode 100644 index 0000000..e69de29 diff --git a/kai-client-ci/report/index.html b/kai-client-ci/report/index.html new file mode 100644 index 0000000..e69de29 diff --git a/kai-client-ci/report/visualizer.js b/kai-client-ci/report/visualizer.js new file mode 100644 index 0000000..e69de29