Skip to content

Latest commit

 

History

History
133 lines (102 loc) · 6.75 KB

README.md

File metadata and controls

133 lines (102 loc) · 6.75 KB

Lomse visual regression tests

The Lomse library has an extensive set of unit tests to make sure each core component of Lomse works properly. But they do not check that Lomse code, as a unit, works properly. So, Lomse also includes a visual regression test system for ensuring that Lomse works properly, that visual appearance of rendered scores doesn't change in unexpected ways from one Lomse build to the next one and, in general, to improve the quality assurance (QA) of the Lomse library.

The goal of this system is to detect regressions in the rendered output without having to rely on human visual review. There are two visual tests:

  • Rendition visual tests, and
  • MusicXML exporter visual tests.

The Rendition visual tests go as follows:

  • First, Lomse loads a test score and renders it.
  • Then the generated image is compared with the expected blessed image that is in folder lomse/vregress/target.
  • If there are differences, the test script generates a GIF image, which flips between the two images, so that any differences are easily spotted.
  • Finally, an html page is automatically created with the results, in lomse/zz_regression/results.html.

And the MusicXML exporter visual tests go as follows:

  • First, Lomse loads a test score and is exported to MusicXML.
  • The exported file is now imported and Lomse renders it.
  • Then the generated image is compared with the expected blessed image that is in folder lomse/vregress/target.
  • If there are differences, the test script generates a GIF image, which flips between the two images, so that any differences are easily spotted.
  • Finally, an html page is automatically created with the results, in lomse/zz_musicxml/musicxml.html. Any failure means than the exported file does not contain all the information imported by Lomse from the original file and, thus, the rendition has differences.

Running the visual tests

Prerequisites

For running the tests it is necessary to have installed the ImageMagick program. It is used to compare the generated image with the expected target image and, if differences found, to generate a GIF image to facilitate visual comparison of differences. To install ImageMagick program:

  • Linux, use the package manager (e.g. Ubuntu): $ sudo apt-get install imagemagick
  • macOS, with HomeBrew: $ brew install imagemagick.
  • Windows, I don't know how to do it. I don't use Windows. Feel free to fix this instructions and send a PR.

The test system also uses a small provided program (lclt) to open a test file, render it with Lomse and save the resulting images as JPG files. The lclt program is re-built as part of the visual regression test process, to ensure that the latest Lomse version is used. You only need to download the sources (they are rarely updated). It is required that lclt root and vregress root folders be placed in the same folder that Lomse root folder, e.g.:

   lomse-project
       │
       ├── lomse
       │     ├── src
       │     ├── scripts
       │     ┆
       │
       ├── vregress
       │     ├── target
       │     ┆
       │
       ├── lclt
       │     ├── src
       │     ┆
       ┆

To download the lclt sources just clone the lclt repo:

$ cd path-to-my-projects-folder
$ git clone https://github.com/lenmus/lclt.git

How to run the visual regression tests

⚠️ Warning I have only used and tested this in Linux, but it should work without problems in macOS. As to Windows, I don't use Windows and never tried this. The provided scripts are Linux bash scripts, so you will need to port the scripts or you could try the Linux facilities available in Windows 10. Feel free to fix this instructions and send a PR.

After you install ImageMagick and the lclt sources, you can run the test at any moment by doing:

$ cd path-to-my-projects-folder
$ cd lomse/scripts
$ ./build-lomse.sh              #builds Lomse and runs the unit tests
$ ./install-lomse.sh            #install the new Lomse build. Asks for the root password to install lomse
$ ./build-lclt.sh               #builds the test program and links it with the new version of Lomse. Install it.
$ ./regression.sh               #runs the visual regression tests
$ ./musicxml-export-tests.sh    #runs the visual regression tests for the MusicXML exporter

The scripts regression.sh and musicxml-export-tests.sh will generate a lot of error messages. It is normal!. They create, respectively, folders zz_regression and zz_musicxmlat the same level than the lomse root folder, with the following content:

   lomse-project
       │
       ├── lomse
       │     ├── src
       │     ├── scripts
       │     ├── zz_build_area
       │     ┆
       │
       ├── vregress
       │     ├── target
       │     ┆
       │
       ├── lclt
       │     ├── src
       │     ┆
       ┆
       ├── zz_musicxml
       │     ├── generated/
       │     ├── failures/
       │     ├── musicxml.htm
       │     └── musicxml.css
       │
       └── zz_regression
             ├── generated/
             ├── failures/
             ├── regression.htm
             └── regression.css
  • Folder zz_musicxml is created by musicxml-export-tests.sh script and contains results:

    • Subfolder generated contains the images for the exported scores
    • Subfolder failures contains the GIF images for the test failures
    • File musicxml.htm is an HTML page the test report.
    • File musicxml.css is a style sheet for the report.
  • Folder zz_regression is created by regression.sh script and contains results:

    • Subfolder generated contains the images for the rendered scores
    • Subfolder failures contains the GIF images for the test failures
    • File regression.htm is an HTML page the test report.
    • File regression.css is a style sheet for the report.

Important Please add a line to your .gitignore file:

zz_*

to avoid inadvertently uploading the build folders to the repo in a commit. Thank you!

Now, open the results page, in zz_regression/regression.html, with your favorite browser. And visually inspect the failures (there are links at page top). If you're happy with the new output you should copy the new blessed image from zz_regression/generated to vregress/target and commit it.

Also open the results page, in zz_musicxml/musicxml.html and visually inspect the failures. Any failure means than the exported file does not contain all the information imported by Lomse from the original file and, thus, the rendition has differences. You should open an issue to inverstigate and fix the MusicXML exporter.