Skip to main content

A Library for visual diffs

Project description

dfrnt is a library for comparing PNG screenshots during automated testing and producing visual diffs.

dfrnt will compare images with identical names from automation and produce a result “diff” image that red-highlights regions in the image that differ.

dfrnt requires a minimum of 3 folders to be specified:

run_dir is the directory of screenshots from your run, aka ‘actual screenshots’ gold_dir directory of screenshots that are compared against, aka ‘expected screenshots’ diff_dir is the directory to output the visual diff images into

Invoking:

  1. You have a directory of images from your latest test run in “test/run” (test.png)

  2. You have a directory of the expected images in “test/gold” (test.png)

  3. You want the output of visual diffs to be placed in directory “test/diff”

from dfrnt import dfrnt

visual_diffs = dfrnt(run_dir=”test/run”, gold_dir=”test/gold”, diff_dir=”test/diff”)

visual_diffs.diff()

Output: Diff failed! test.png is not identical enough

A red-lined image showing the differences between run/test.png and gold/test.png is generated in diff/test.png

Optional Features: mask_dir is the directory to contain images with highlighted areas you wish to ignore in the diff. This is useful for ignoring portions of an image that always change, like date / time. These mask images should be transparent background PNGs

fuzzy is a “fuzziness” factor of how different images can be and still pass. If you experience jitter you should experimentally determine the lowest acceptable number you can use. Default is None, starting your binary search around ‘40’ is recommended

visual_diffs = visual_diffs = dfrnt(run_dir=”run”, gold_dir=”gold”, diff_dir=”diff”, mask_dir=”mask”, fuzzy=40)

Why is this project called ‘dfrnt’? To mock the modern practice of dropping vowels in software names to sound unique. Be glad I didn’t name it dfrntzlyr.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

dfrnt-0.2.tar.gz (3.1 kB view details)

Uploaded Source

File details

Details for the file dfrnt-0.2.tar.gz.

File metadata

  • Download URL: dfrnt-0.2.tar.gz
  • Upload date:
  • Size: 3.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for dfrnt-0.2.tar.gz
Algorithm Hash digest
SHA256 8c9eb53c3ef63794a324f4679e6ea1c6e961cfadeb619fa70fbd7794bc3b07e0
MD5 52642997a4123de9c4eed834f3eba97b
BLAKE2b-256 40f053587ec8fd46da4e0d94bdc05f6154abbbbd6ee163a2d2005269c3a60028

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page