Eyes Utilities is a Java based CLI tool to extend Applitools capabilities by communicating directly to Applitools API. Using EyesUtilities it is possible to generate customized offline reports, perform administration operations, generate playback and diff animations, download test diffs and original images and perform operations between branches.
- Applitools account. If you still don't have your Applitools account,
you can start your trial by going to the Applitools website.
- To quickly get on-board go to the getting started tutorial.
- If you already have Applitools account but can't find proper tool, try the Webtester here.
- For many listed operations, an additional set of keys will be required. To get your keys please reach out to applitools support via this link or at support@applitools.com.
The general syntax is derived from the fact that the EyesUtilities is built in Java.
As a result every cli call should start with:
Java -jar EyesUtilities.jar [command] [command specific parameters...]
- Generate steps animation
- Generate test playback
- Download test diffs
- Download test images
- Generating batch reports
- Administration
- Merge branch
- Copy baselines
- Delete baselines
- Proxy server settings
- Resources
This command will generate a set of animated gifs for each failing step inside the provided test.
The animation will iterate between three states: (a) The expected from the baseline, (b) The actual and (c) The actual with purple diff marks.
After the execution, the results will be saved, the default location is: {workdir_root}/Artifacts/{batch_id}/{test_id}/
Syntax:
java -jar EyesUtilities.jar anidiffs -k [EntKey] <[optional params]> [ResultUrl]
- Required parameters:
-k [EntKey]
- API key with read permissions.[ResultUrl]
- Applitools test result url to be analyzed.
- Optional parameters:
-i [mSecs]
- Transition interval between the images in milliseconds. default: 1000-d [pathTmpl]
- Specify destination path template.-dv
- Disable SSL certificate check and ignore possible errors. Note that using this flag is unsecured and dangerous. default:{workdir_root}/Artifacts/{batch_id}/{test_id}/file:{step_index}{step_tag}{artifact_type}.{file_ext}
- Available path template parameters: user_root, workdir_root, batch_id, test_id, test_name, batch_name, app_name, os, hostapp, viewport, branch_name, step_index, step_tag, artifact_type, file_ext
Generates one unified animated gif with all the actual steps of a test.
Syntax:
java -jar EyesUtilities.jar playback -k [EntKey] <[optional params]> [ResultUrl]
-
Required parameters:
-k [EntKey]
- API key with read permissions.[ResultUrl]
- Applitools test result url to be analyzed.
-
Optional parameters:
-i [mSecs]
- Transition interval between the images in milliseconds. default: 1000-d [pathTmpl]
- Specify destination path template.-dv
- Disable SSL certificate check and ignore possible errors. Note that using this flag is unsecured and dangerous.
default:
{workdir_root}/Artifacts/{batch_id}/{test_id}/file:{step_index}{step_tag}{artifact_type}.{file_ext}
- Available path template parameters: user_root, workdir_root, batch_id, test_id, test_name, batch_name, app_name, os, hostapp, viewport, branch_name, step_index, step_tag, artifact_type, file_ext
-m
- A Flag, Sets 'on' diff marks if a step is different from it's expected baseline.
Downloads the images of the failed steps with diff marks on them.
Syntax:
java -jar EyesUtilities.jar diffs -k [EntKey] <[optional params]> [ResultUrl]
-
Required parameters:
-k [EntKey]
- API key with read permissions.[ResultUrl]
- Applitools test result url to be analyzed.
-
Optional parameters:
-i [mSecs]
- Transition interval between the images in milliseconds. default: 1000-d [pathTmpl]
- Specify destination path template.-dv
- Disable SSL certificate check and ignore possible errors. Note that using this flag is unsecured and dangerous.
default:
{workdir_root}/Artifacts/{batch_id}/{test_id}/file:{step_index}{step_tag}{artifact_type}.{file_ext}
- Available path template parameters: user_root, workdir_root, batch_id, test_id, test_name, batch_name, app_name, os, hostapp, viewport, branch_name, step_index, step_tag, artifact_type, file_ext
Downloads the baseline and the actual images of a test.
Syntax:
java -jar EyesUtilities.jar images -k [EntKey] <[optional params]> [ResultUrl]
-
Required parameters:
-k [EntKey]
- API key with read permissions.[ResultUrl]
- Applitools test result url to be analyzed.
-
Optional parameters:
-a
- Flag to download only actuals-b
- Flag to download only baselines-d [pathTmpl]
- Specify destination path template.-dv
- Disable SSL certificate check and ignore possible errors. Note that using this flag is unsecured and dangerous.
default:
{workdir_root}/Artifacts/{batch_id}/{test_id}/file:{step_index}{step_tag}{artifact_type}.{file_ext}
- Available path template parameters: user_root, workdir_root, batch_id, test_id, test_name, batch_name, app_name, os, hostapp, viewport, branch_name, step_index, step_tag, artifact_type, file_ext
This command will generate an offline report for one or more Applitools' results urls,
based on a provided template.
The default name and the location of the template is ./report.teml
.
Syntax:
java -jar EyesUtilities.jar report -k [EntKey] <[optional params]> [ResultUrls]
- Required parameters:
-k [EntKey]
- API key with read permissions.[results]
- Any combination of full result urls and/or batch id's. If only batch-id's provided, a server url must appear once in the list.
- Optional parameters:
-d [FolderPath]
- Set custom report output destination. Default:'.'
-t [FilePath]
- Set report template file. Default./report.templ
-rt [title]
- Set the title of the report-dv
- Disable SSL certificate check and ignore possible errors. Note that using this flag is unsecured and dangerous.-dr
- Generate a test report for all batches that executed in a specified time interval. Example-dr [12-5-2022,12-10-2022]
The engine lies beneath this report generation is based on Velocity framework which widely used in MVC frameworks to implement web-apps. A template can be constructed with parameters and simple logic using VTL(Velocity Template Language), which's full syntax reference can be found here.
Here is the partial list of parameters that are exposed for usage in template construction:
$title
- The title that (if) passed in the command to be contained.$batches
- The main object that stores the batches and overall metrics$batches.BatchesPassed
- Overall passed batches count$batches.BatchesFailed
- Overall failed batches count$batches.BatchesUnresolved
- Overall unresolved batches count$batches.BatchesRunning
- Overall running batches count$batches.BatchesPassedRate
- Overall passed batches rate(%)$batches.BatchesFailedRate
- Overall failed batches rate(%)$batches.BatchesUnresolvedRate
- Overall unresolved batches rate(%)$batches.BatchesRunningRate
- Overall running batches rate(%)$batches.BatchesBatchesMatched
- Overall matched batches count$batches.BatchesBatchesMismatched
- Overall mismatched batches count$batches.BatchesNew
- Overall new batches count$batches.TestsPassed
- Overall batches tests passed count$batches.TestsFailed
- Overall batches failed passed count$batches.TestsUnresolved
- Overall batches tests unresolved count$batches.TestsRunning
- Overall batches tests running count$batches.TestsPassedRate
- Overall batches tests passed rate(%)$batches.TestsFailedRate
- Overall batches tests failed rate(%)$batches.TestsUnresolvedRate
- Overall batches tests unresolved rate(%)$batches.TestsRunningRate
- Overall batches tests running count$batches.TestsTotal
- Overall batches tests total$batches.TestsMismatched
- Overall batches tests mismatched count$batches.TestsMatched
- Overall batches tests matched count$batches.TestsNew
- Overall batches tests new count$batches.TestsAborted
- Overall batches tests aborted count$batches.StepsTotal
- Overall batches steps total$batches.StepsMatched
- Overall batches steps matched count$batches.StepsMismatched
- Overall batches steps mismatched count$batches.StepsNew
- Overall batches steps new count$batches.StepsMissing
- Overall batches steps missing count$batches.StepsMatchedRate
- Overall batches steps matched rate(%)$batches.StepsMismatchedRate
- Overall batches steps mismatched rate(%)$batches.StepsNewRate
- Overall batches steps new rate(%)$batches.StepsMissingRate
- Overall batches steps missing rate(%)#foreach($batch in $batches)
- Iterate over each batch in $batches$batch
- The object that contains all the tests and batch level data and metrics.$batch.Status
- The status of the entire batch$batch.Name
- The name of the batch$batch.id
- The id of the batch$batch.startedAt
- The started date of the batch$batch.TestsPassed
- Batch overall passed tests count.$batch.TestsFailed
- Batch overall failed tests count.$batch.TestsRunning
- Batch overall running tests count.$batch.TestsNew
- Batch overall new tests count.$batch.TestsMatched
- Batch overall matched tests count.$batch.TestsMismatched
- Batch overall mismatched tests count.$batch.TestsUnresolved
- Batch overall unresolved tests count.$batch.TestsAborted
- Batch overall aborted tests count.$batch.TotalTests
- Batch overall total tests count.$batch.TotalActualSteps
- Batch overall actual total steps.$batch.TotalBaselineSteps
- Batch overall baseline total steps.$batch.StepsMatched
- Batch overall matched total steps.$batch.testsMismatched
- Batch overall mismatched total steps.$batch.StepsMissing
- Batch overall missing total steps.$batch.StepsNew
- Batch overall new total steps.$batch.MatchedRate
- Batch overall matched steps rate(%).$batch.MismatchedRate
- Batch overall mismatched steps rate(%).$batch.NewRate
- Batch overall new steps rate(%).$batch.MissingRate
- Batch overall missing steps rate(%).#foreach($test in $batch.tests)
- Iterate over each test in $batch.tests-
$test.ScenarioName
- The test name -
$test.AppName
- Application name -
$test.url
- Test result url -
$test.BranchName
- Actual branch name (Destination branch) -
$test.BaselineBranchName
- Baseline branch name (Source branch) -
$test.Id
- Test id -
$test.RunBy
- Total mismatching steps in test -
$test.AssignedTo
- What user is this test assigned to? -
$test.StartedAt
- Started date/time -
$test.Duration
- Test duration in seconds -
$test.Status
- Current test status -
$test.State
- Is test completed? -
$test.Result
- Test execution result -
$test.BaselineEnvId
- Baseline Env-Id -
$test.IsAborted
- Is Aborted? -
$test.IsDifferent
- Is test has differences? -
$test.IsDefaultStatus
- Is the current status default or overridden? -
$test.IsNew
- Is the baseline new? -
$test.IsStarred
- Is test starred in the dashboard? -
$test.TotalBaselineSteps
- Total baseline steps in test -
$test.TotalActualSteps
- Total actual steps in test -
$test.MissingCount
- Total missing steps in test -
$test.NewCount
- Total new steps in test -
$test.MatchedCount
- Total matching steps in test -
$test.MismatchedCount
- Total mismatching steps in test -
$test.EnvironmentName
- The environment name defined for the test -
$test.getPlaybackAnimation
- Download & Generate the test flow as an animated gif and returns it's relative path. -
$test.getAccessibilityResult()
- Accessibility status results for test, blank string if no accessibility testing performed -
$test.Env.hostingApp
- Browser used for test -
$test.Env.os
- OS used for test -
$test.Env.getDisplaySizeStr()
- Viewport size for test -
$test.Env.deviceInfo
- Device name (Desktop or unique mobile device name) -
$test.Env.inferred
- Environment user agent string -
#foreach($step in $test.FailedSteps)
- Iterate over each step in $test.FailedSteps$step.Diff
- Download & Generate step diff image and returns file's relative path.$step.AnimatedThumbprints
- Download & Generate step animated thumbprint and returns file's relative path.$step.AnimatedDiff
- Download & Generate step fully sized animation and returns file's relative path.$step.ExpectedImage
- Downloads step baseline (expected) image and returns file's relative path.$step.ActualImage
- Downloads step actual image and returns file's relative path.
-
#foreach($step in $test.Steps)
- Iterate over each step in $test.Steps$step.ExpectedImage
- Downloads step baseline (expected) image and returns file's relative path.$step.ActualImage
- Downloads step actual image and returns file's relative path.
-
A complete example of a template can be found here
This example generates html report but the same idea can be applied on any textual format.
Perform Admin operations on teams and users in organization. Before starting, make sure you have Server/Org admin account.
General syntax:
java -jar EyesUtilities.jar admin <[Subcommand params]>
- getTeams - List all teams in organization's account
- Syntax:
java -jar EyesUtilities.jar admin getTeams -k [api-key] -or [org-id] <[optional params]>
- Required parameters:
-k [api-key]
- API key with read permissions.-or [org-id]
- Organization id*
- Optional parameters:
-as [url]
- Applitools alternative server, default: eyes.applitools.com-dv
- Disable SSL certificate check and ignore possible errors. Note that using this flag is unsecured and dangerous.
- getUsers - List all users in a team
- Syntax:
java -jar EyesUtilities.jar admin getUsers -k [api-key] -or [org-id] -ti [team-id] <[optional params]>
- Required parameters:
-k [api-key]
- API key with read permissions.-or [org-id]
- Organization id*-ti [team-id]
- Team id
- Optional parameters:
-as [url]
- Applitools alternative server, default: eyes.applitools.com-dv
- Disable SSL certificate check and ignore possible errors. Note that using this flag is unsecured and dangerous.
- addTeam - Add team to organization's account
- Syntax:
java -jar EyesUtilities.jar admin addTeam -k [api-key] -or [org-id] -tn [team-name] <[optional params]>
- Required parameters:
-k [api-key]
- API key with read permissions.-or [org-id]
- Organization id*-tn [team-name]
- The name of the new team
- Optional parameters:
-as [url]
- Applitools alternative server, default: eyes.applitools.com-dv
- Disable SSL certificate check and ignore possible errors. Note that using this flag is unsecured and dangerous.
- addUser - Add user to a team
- Syntax:
java -jar EyesUtilities.jar admin addUser -k [api-key] -or [org-id] -ti [team id] <[optional params]>
- Required parameters:
-k [api-key]
- API key with read permissions.-or [org-id]
- Organization id*-ti [team-id]
- Team id
- Optional parameters:
-as [url]
- Applitools alternative server, default: eyes.applitools.com-ne [newUserEmail]
- The email of the new user. Required if the user is new to the account.-ni [newUserId]
- The user-id of the new user, default: same as the newUserEmail.-nn [newUserName]
- The full name of the new user, default: extracted from the newUserEmail (the part before the '@').-ve
- Set permission to viewer, default: false-ad
- Set permission to team admin, default: false-dv
- Disable SSL certificate check and ignore possible errors. Note that using this flag is unsecured and dangerous.
- remUser - Remove user from a team or from organization
- Syntax:
java -jar EyesUtilities.jar admin remUser -k [api-key] -or [org-id] -ri [remove-user-id] <[optional params]>
-
Required parameters:
-k [api-key]
- API key with read AND write permissions.-or [org-id]
- Organization id*-ri [remove-user-id]
- The id of the user to be removed (this is most likely their email address)
-
Optional parameters:
-as [url]
- Applitools alternative server, default: eyes.applitools.com-ti [team-id]
- Team id, if set will only be omitted from the team-dv
- Disable SSL certificate check and ignore possible errors. Note that using this flag is unsecured and dangerous.
* Organization id (orgId) field can be found as one of the url parameters in the admin/manage panel.
Perform branch merging with additional options.
Syntax:
java -jar EyesUtilities.jar merge -k [apiKey] -s [sourceBranch] <[optional params]>
- Required parameters:
-k [apiKey]
- API key with merge permissions.-s [sourceBranch]
- Source branch name
- Optional parameters:
-as [url]
- Applitools alternative server, default: eyes.applitools.com-t [targetBranch]
- Target branch for merge-dv
- Disable SSL certificate check and ignore possible errors. Note that using this flag is unsecured and dangerous.-d
- Delete the source branch after a successful merge. The apiKey must have merge, read and write permissions.-db
- After successfully merging baselines from source branch to target branch, delete baselines from source branch.-gt
- Use timestamp to index new baseline revision. Timestamp must be valid. (ex:2023-05-25T05:18:34.956Z
)
Perform baselines copy with additional options. Unless filter applied, all baselines will be copied. If a baseline exists in target branch, it will be overwritten.
Syntax:
java -jar EyesUtilities.jar copyBaselines -k [apiKey] -t [targetBranch]
- Required parameters:
-k [apiKey]
- API key with read AND write permissions.-t [targetBranch]
- Target branch name
- Optional parameters:
-as [url]
- Applitools alternative server, default: eyes.applitools.com-s [sourceBranch]
- Source branch name default: 'default' branch-an [appName]
- Filter baselines by application name-li [limit]
- Maximum number of baselines to copy (default: no limit)-dv
- Disable SSL certificate check and ignore possible errors. Note that using this flag is unsecured and dangerous.
Delete baselines by id. Only the baseline with the specified id will be deleted.
Syntax:
java -jar EyesUtilities.jar deleteBaselines -k [apiKey] -bld [baselineId]
- Required parameters:
-k [apiKey]
- API key with read AND write permissions.-bld [baselineId]
- Delete the baseline with the corresponding id
- Optional parameters:
-as [url]
- Applitools alternative server, default: eyes.applitools.com
By default, EyesUtilities will use proxy defined on system level. No additional configuration is needed.