Skip to main content

Capture Static URLs via CLI


With SmartUI CLI, you can seamlessly perform visual regression testing on the LambdaTest platform using your command line, identifying Visual UI Regression bugs effortlessly. This guide will walk you through the process of running successful Visual Regression tests using SmartUI CLI.

Prerequisites for running SmartUI CLI

  • Basic understanding of Command Line Interface is required.
  • Login to LambdaTest SmartUI with your credentials.

The following steps will guide you in running your first Visual Regression test on LambdaTest platform using SmartUI CLI.

Create a SmartUI Web-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:

  1. Go to Projects page
  2. Click on the new project button
  3. Select the platform as CLI for executing your CLI tests.
  4. Add name of the project, approvers for the changes found, tags for any filter or easy navigation.
  5. Click on the Submit.

Step 1: Install the Dependencies

Install required NPM modules for LambdaTest Smart UI CLI in your Frontend project.

npm install @lambdatest/smartui-cli

Step 2: Create URL file

smartui config:create-web-static urls.json

Once, the URLs file will be created, you will be seeing the sample pre-filled URLs in the urls.json file:

/smartui-cli-project/urls.json
[
{
"name": "lambdatest-home-page",
"url": "https://www.lambdatest.com",
"waitForTimeout": 1000 //Optional
},
{
"name": "example-page",
"url": "https://example.com/"
}
]

Step 3: Configure your Project Token

Setup your project token show in the SmartUI app after, creating your project.

export PROJECT_TOKEN="123456#1234abcd-****-****-****-************"
cmd

Step 4: Create and Configure SmartUI Config

You can now configure your project settings on using various available options to run your tests with the SmartUI integration. To generate the configuration file, please execute the following command:

npx smartui config:create .smartui.json

Once, the configuration file will be created, you will be seeing the default configuration pre-filled in the configuration file:

/smartui-sdk-project/.smartui.json
{
"web": {
"browsers": [
"chrome",
"firefox",
"safari",
"edge"
],
"viewports": [
[
1920
],
[
1366
],
[
1028
]
] // Full Page screenshots are captured by default for web viewports
},
"mobile": {
"devices": [
"iPhone 14", //iPhone 14 viewport
"Galaxy S24" //Galaxy S24 viewport
],
"fullPage": true, //Full Page is true by default for mobile viewports
"orientation": "portrait" //Change to "landscape" for landscape snapshot
}
}

For capturing viewport screenshots

To capture a screenshot of the content currently visible in your viewport, rather than the entire page, it's important to define the viewport's width and height in your configuration settings. Specify the desired width and height parameters as demonstrated in the following example to ensure that the screenshot encompasses only the viewport area.

    "viewports": [
[
1920,
1080
],
[
1366,
768
],
[
360,
640
]
],
note

You may use the smartui --help command in case you are facing issues during the execution of SmartUI commands in the CLI.

SmartUI CLI Config Options

Please read the following table for more information about the configuration file:

Config KeyDescriptionUsage
browsersYou can add all the supported browsers brands here to run your tests for SmartUI.
Ex: "chrome", "firefox", "safari", "edge", etc..
Mandatory
resolutionsYou can add all the supported browser viewpoints here to run your tests for SmartUI
Ex: [1920, 1080],[width, height] etc..
Mandatory

Step 5: Execute the Tests on SmartUI Cloud using CLI

You can now execute tests for Visual Regression Testing using the following options:.

npx smartui capture urls.json --config .smartui.json

Fetch results

You can fetch build results by adding the --fetch-results flag to your test execution command. Here are different ways to use this feature:

Default Usage

If no filename is specified, results will be stored in results.json:

npx smartui capture urls.json --config .smartui.json --fetch-results

Custom Filename

Specify a custom filename for your results:

npx smartui capture urls.json --config .smartui.json --fetch-results custom-results.json 

Adding a custom build name

You can add a custom build name by adding the --buildName flag to your test execution command. Here is how you can utilise this feature:

Specify a custom build name to group your screenshots in the following way:

npx smartui capture urls.json --buildName "Sample Build Name" --config .smartui.json

Note:

  • If no build name is provided, a random name will be automatically assigned to the build.
  • Specifying the name of an existing build within the project will append the screenshots to that build.
  • Existing screenshots with the same name and configuration in the build will be overwritten during a re-run.

Setup with Continuous Integration (CI)

If you are using the Continuous Integration (CI) pipeline for your application and want to integrate SmartUI CLI execution then the following are the steps needs to be added to your .yaml file:

steps:
- name: Running SmartUI CLI Tests
- run: |
npm install -g @lambdatest/smartui-cli
npx playwright install-deps
smartui capture urls.json --config smartui-web.json

SmartUI CLI Options and Keys

The following are supported CLI (Command Line Interface) options for Visual Regression Testing with SmartUI:

CLI Flag KeyDescriptionUsage
--configThis is the reference configuration file containing the SmartUI Cloud ConfigurationOptional
--helpThis will print all help information for the SmartUI CLI optionsOptional

View SmartUI Results

You can see the Smart UI dashboard to view the results. This will help you identify the Mismatches from the existing Baseline build and do the required visual testing.

cmd

Parallel execution of static URLs

You can reduce the build time by executing parallel URLs in the following way.

npx smartui capture urls.json --config .smartui.json --parallel <number-of-parallels> --fetch-results   
  • The --parallel flag determines how many URLs will be processed simultaneously
  • Each thread captures screenshots independently, maximizing throughput

Example:

npx smartui capture urls.json --config .smartui.json --parallel 3 --fetch-results   

Determining Optimal Thread Count

The maximum number of parallel threads is calculated using the formula: log2(N) where N is the total number of URLs.

For example:

  • For 100 URLs: Maximum parallel threads = log2(100) = 6 threads
  • For 50 URLs: Maximum parallel threads = log2(50) = 5 threads
  • For 25 URLs: Maximum parallel threads = log2(25) = 4 threads

Best Practices for parallel execution

  • Start with a lower thread count and gradually increase based on your system's performance
  • Monitor system resources during execution
  • Ensure stable internet connection for reliable parallel processing

For additional information about SmartUI APIs please explore the documentation here

Test across 3000+ combinations of browsers, real devices & OS.

Book Demo

Help and Support

Related Articles