/WatchUI

Visual testing library for Robot Framework

Primary LanguageRobotFrameworkMIT LicenseMIT

WatchUI

Code style: black

Basic Info

Custom library for works with image, pdf and tesseract with RF.

Folder structure

WatchUI
└── .github/workflows           # Folder with CI for github actions
└── assets                      # Folder with images used for documantation as well as test data
└── test                        # Folder with example how to write rf test.
│    └── unit_tests             # Pytest unit test cases
│    └── test.robot             # File with simeple Robot Framework TCs
└── WatchUI                     # Folder with WatchUI library
│    └── WatchUI.py             # Main library file
│    └── IBasics                # Basic utilities and error handling
│    └── Keywords               # Keywords for working with images, PDFs and text(tesseract)
└── README.MD                   # Here you are :-)
└── setup.py                    # File for easy setup use with pip install .

Install

You can find detail in Documentation but basically use pip:

pip install WatchUI

or some python dependencies management tools, like pipenv or poetry and their respective methods of libraries installation.

Sample results

Image where the differences are stored + You can see two black box in left corner. These black box are ignored during comparison.

The red rectangles outlining missing elements on compared screens

Important notice for users

For users with Windows

The scikit image library is used for image matching. Unfortunately, this is a scientific library. You need to have these libraries for installed to use them properly on windows:

  • Windows 10 SDK
  • C++ x64/x86 build tools

These libraries can be downloaded by using VS studio (not vscode) and installing the msbuild tool from VS studio. Alternatively, this library should also work.

WatchUI 1.0 vs 2.x.x

WatchUI 2.0 brings breaking changes. Dev team decided to streamline the library and focus it solely on the image and text comparison. This allows us to remove the implicit dependency on browser automation libraries - namely SeleniumLibrary, which was implicit part of the library via RF BuiltIn() import of the SeleniumLibrary instance.

This is no longer the case - user of the WatchUI therefore can and have to choose, what UI automation library will use and provide screenshots to the WatchUI keywords to be compared. It could be now used with SeleniumLibrary, Browser library, Sikuli, Appium or any other UI library where visual validation is required.

Version 1.x.x is no longer supported, but it is still available on [Pypi](pip install WatchUI==1.0.11).