Getting started with Smart UI using K6
This documentation will act as your step-by-step guide in to perform K6 test with SmartUI.
Prerequisites for running SmartUI with K6
- Basic understanding of K6 is required.
- Go to SmartUI and login along with your credentials.
- Copy
LT_USERNAME
andLT_ACCESS_KEY
credentials fromAccess Key
button on the top right of the dashboard.
- MacOS/Linux
- Windows
export LT_USERNAME="YOUR_USERNAME"
export LT_ACCESS_KEY="YOUR ACCESS KEY"
set LT_USERNAME="YOUR_USERNAME"
set LT_ACCESS_KEY="YOUR ACCESS KEY"
The following steps will guide you in running your first Visual Regression test on LambdaTest platform -
Step 1: Create a SmartUI Project
The first step is to create a project with the application in which we will combine all your builds run on the project. To create a SmartUI Project, follow these steps:
- Go to Projects page
- Click on the
new project
button - Select the platform as Web for executing your
K6
tests. - Add name of the project, approvers for the changes found, tags for any filter or easy navigation.
- Click on the Submit.
Step 2: Configure your test with K6 Desired Capabilities
Once you have created a SmartUI Project, you can generate screenshots by running automation scripts. Follow the below steps to successfully generate screenshots -
- Please clone the following sample Github repo (
https://github.com/LambdaTest/smartui-k6-sample
).
git clone https://github.com/LambdaTest/smartui-k6-sample.git
- Install k6 by referring to the installation guide
https://k6.io/docs/get-started/installation/
:
- MacOS
- Windows
brew install k6
winget install k6
- Set up the LambdaTest credentials by using the commands below in the terminal.The account details are available on your LambdaTest Profile page.
For macOS:
export LT_USERNAME=LT_USERNAME
export LT_ACCESS_KEY=LT_ACCESS_KEY
For Linux:
export LT_USERNAME=LT_USERNAME
export LT_ACCESS_KEY=LT_ACCESS_KEY
For Windows:
set LT_USERNAME=LT_USERNAME
set LT_ACCESS_KEY=LT_ACCESS_KEY
- Edit the required capabilities in your test file
k6-smartui.js
.
import { chromium } from 'k6/experimental/browser';
import { expect } from 'https://jslib.k6.io/k6chaijs/4.3.4.3/index.js';
export default async function () {
const capabilities = {
"browserName": "Chrome",
"browserVersion": "latest",
"LT:Options": {
"platform": "MacOS Ventura",
"build": "K6 Build",
"name": "K6 SmartUI test",
"user": __ENV.LT_USERNAME,
"accessKey": __ENV.LT_ACCESS_KEY,
"network": true,
"video": true,
"console": true,
'tunnel': false, // Add tunnel configuration if testing locally hosted webpage
'tunnelName': '', // Optional
'geoLocation': '', // country code can be fetched from https://www.lambdatest.com/capabilities-generator/
'smartUIProjectName': 'K6_Test_Sample', // Add the required Smart UI Project name
},
};
const wsURL = `wss://cdp.lambdatest.com/k6?capabilities=${encodeURIComponent(JSON.stringify(capabilities))}`
const browser = chromium.connect(wsURL);
const page = browser.newPage();
try {
await page.goto("https://duckduckgo.com");
// Add the following command in order to take screenshot in SmartUI
await captureSmartUIScreenshot(page, "Homepage")
let element = await page.$("[name=\"q\"]");
await element.click();
await element.type("K6");
await element.press("Enter");
let title = await page.title();
expect(title).to.equal("K6 at DuckDuckGo");
// Pass the `page` object. Add `screennshotName` if you want to fetch response for a specific screenshot
await validateSmartUIScreenshots(page)
// Mark the test as passed or failed
await page.evaluate(_ => {}, `lambdatest_action: ${JSON.stringify({ action: "setTestStatus", arguments: { status: "passed", remark: "Assertions passed" },})}`);
await teardown(page, browser)
} catch (e) {
console.log('Error:: ', JSON.stringify(e))
await page.evaluate(_ => {}, `lambdatest_action: ${JSON.stringify({ action: 'setTestStatus', arguments: { status: 'failed', remark: JSON.stringify(e) } })}`)
await teardown(page, browser)
throw e
}
};
async function captureSmartUIScreenshot(page, screenshotName) {
await page.evaluate(_ => {}, `lambdatest_action: ${JSON.stringify({ action: "smartui.takeScreenshot", arguments: { screenshotName: screenshotName } })}`);
}
async function teardown(page, browser) {
await page.close();
await browser.close();
}
const validateSmartUIScreenshots = async (page, screenshotName) => {
try {
await page.waitForTimeout(10000) // Added delay to get reports of all screenshots captured
let screenshotResponse = JSON.parse(await page.evaluate(_ => {}, `lambdatest_action: ${JSON.stringify({ action: 'smartui.fetchScreenshotStatus', arguments: { screenshotName }})}`))
console.log('screenshotStatus response: ', screenshotResponse)
if (screenshotResponse.screenshotsData && Array.isArray(screenshotResponse.screenshotsData)) {
for (let i = 0; i < screenshotResponse.screenshotsData.length; i++) {
let screenshot = screenshotResponse.screenshotsData[i];
if (screenshot.screenshotStatus !== "Approved") {
throw new Error(`Screenshot status is not approved for the screenshot ${screenshot.screenshotName}`);
}
}
}
} catch (error) {
throw new Error(error);
}
}
Step 3: Executing the SmartUI Test Suite on Cloud
Execute the test using the following command to run the test suite using K6
- MacOS/Linux
- Windows
K6_BROWSER_ENABLED=true k6 run k6-smartui.js
set K6_BROWSER_ENABLED=true
k6 run k6-smartui.js
- You can check the executed builds over at LambdaTest SmartUI.
For additional information about K6 framework please explore the documentation here
Advanced Options for Screenshot Comparison
Build Configuration - If you have multiple screenshots running the same test suite and want to run the comparison for the same test suite, want to add a build as a baseline from your test suite or need to access more SmartUI Build Config Options, click here.