VRTs – Visual Regression Tests

Description

VRTs – Visual Regression Tests is a plugin to test your website for unwanted visual changes. The plugin runs automatic daily tests for chosen pages and posts. The tool creates daily comparison screenshots and compares them with a reference snapshot. If there is a difference between the screenshots, you’ll be automatically notified via email. Use three comparison modes to spot the differences easily.

Please note: The website must be publicly accessible in order to set up and run the tests. Password protection or any kind of firewall might prevent the plugin from working correctly.

YOUR STRATEGY TO SPOT UNWANTED CHANGES

How do you usually check your website after updates and code changes? Do you go manually through all pages or do you just hope everything will run ok? Visual regression testing provides you a method that helps you find errors and visual abnormalities. The VRTs plugin gives you an environment to automate your process.

  1. Activate daily tests for any page or post: Upon activation, a reference screenshot is taken. This will be renewed when a post is saved or updated.
  2. Receive instant alerts: If a change is detected between the snapshot and the comparison screenshot, the plugin will create an alert and notify you via email. The daily test will be paused, until the alert is resolved.
  3. Compare two screenshots: Detect differences between the two snapshots with the difference, split screen or side-by-side view.
  4. Exclude elements: Prevent false positives by excluding dynamic elements, ads and animations from snapshots.
  5. Resolve tests: After fixing an issue, mark the alert as resolved. A new snapshot will be generated and the test will start running again.

USE CASES

In which cases can visual regression testing help you spot issues?

  • Plugin and core software updates
  • Manual code changes
  • External software and API issues
  • Server issues
  • Malware and other malicious code
  • Missing quality assurance

FEATURES

  • Instant first test: After plugin activation, the homepage is immediately monitored and alerts are sent to the stored admin email.
  • Daily Tests: The plugin automatically scans selected posts and pages daily. It validates the visual content by comparing two screenshots.
  • 3 comparison modi: Choose between three ways to compare snapshots – Difference, Split, Side-by-Side view.
  • Instant alerts: As soon as a change is detected between the snapshot and the comparison screenshot, you will be notified via email.
  • GDPR compliant: Snapshots are stored on European servers. We do not collect any personal data.
  • Cross-team: Team members with admin rights can create and view tests and work together on the immediate solution.

FREE FOREVER

  • test up to 3 pages
  • on one domain
  • automatic daily tests

GO PRO

Do you like VRTs and want to run more tests?
Unlock more features with our paid plans:

  • test up to 500 pages in total
  • on multiple domains
  • with automatic daily test
  • and unlimited manual tests
  • run tests programmatically with do_action( ‘vrts_run_tests’ )
  • add multiple alert recipients
  • get e-mail support
  • and access to new features

See all pricing plans

BUG-REPORT

You found a bug? Please report it by creating an issue on the support forum.

READ MORE

You want to learn more about VRTs?

Official product page:

VRTs – Visual Regression Tests

Resources:

How does visual regression testing work?

Screenshots

  • Start a test by toggling on Run Tests in the sidebar of your WordPress page or post.
  • Get an overview of all running and paused tests.
  • Get an overview of your alerts. Review and resolve them one by one.
  • The difference view merges the reference snapshot and the newly created screenshot. Differences between them are highlighted in red.
  • In the split view you can compare two snapshots with a vertical slider.
  • The side by side view displays two snapshots next to each other.
  • Run unlimited manual tests.

Installation

INSTALL VRTS WITHIN WORDPRESS

(recommended)

  1. Open Plugins > Add new
  2. Search for Visual Regression Tests
  3. Click install and activate the plugin

INSTALL VRTS MANUALLY THROUGH FTP

  1. Download the plugin on the WordPress plugin page
  2. Upload the ‘visual-regression-tests’ folder to the /wp-content/plugins/ directory
  3. Activate the VRTs plugin through the ‘Plugins’ menu in WordPress

AFTER ACTIVATION

  • By default: The homepage is immediately monitored and alerts are sent to the stored admin email.
  • Open the settings to configure who should receive alerts.
  • Open a page or post to activate more tests.

UPGRADE TO VRTS PRO

  1. Open VRTs > Upgrade
  2. Click Buy Pro
  3. Enter license key you have received after purchasing the plugin

FAQ

What is Visual Regression Testing?

With visual regression testing, you can detect errors and unwanted changes on your website by comparing a previous state of the website with a more recent one. For example, errors in the frontend can be caused by plugin updates and changes. For small websites, you may be able to find them right away, but for complex websites, it becomes difficult. A tool can help by taking pictures of pages and posts to detect visual changes and inform you automatically.

How does visual regression testing work?

Tests can be done manually, pixel-by-pixel, DOM-based or AI-based. In all cases you compare an earlier website state with a newer website state. Our Visual Regression Tests Plugin takes periodical screenshots and compares them on a split screen.

Why should I use a tool for visual regression tests?

You can do visual testing either manually or with automated tools. Checking your website for errors manually is time-consuming and less accurate. Automated tests may find errors that are minimal and irrelevant. But the chance of finding critical errors is much higher with a tool. As soon as you discover an error, you’ll receive a warning so that you can fix the problem as soon as possible.

Is the testing done on my server?

Screenshots and comparisons are performed on an external server and sent to your WordPress website. Only required meta data is stored in your database.

Why are email notifications not working properly?

If our external screenshot service can not access your WordPress installation directly, test status updates and sending emails will be handled by the WP-Cron system. In order to be notified by the plugin about new alerts, please make sure that your WordPress instance can send emails and that the WordPress cron system is set up correctly. The default configuration of the WordPress cron system does not work reliably if you cache your site heavily, do not have frequent visitors or do not use wp-admin regularly. In this case, you should hook the WP-Cron into the system task scheduler, or use an external cron job scheduling service.

Does the plugin work with cookie consent banners?

Yes, cookie banners are not an issue. Before taking a snapshot, the tool can automatically trigger the Accept button to hide the banner. This option can be configured with CSS selectors in the plugin settings.

Can I test custom post type archives with VRTs?

The VRTs plugin primarily supports WordPress pages and posts. Automated visual testing of pages with dynamically changing content can lead to false positives. However, you can test such pages by following these steps:

  • Create a new blank page or post in WordPress.
  • Set up a redirect from this page to your desired URL.
  • Configure a test for this page. The screenshotter will follow the redirect.

How do I prevent screenshots from getting blocked?

If your firewall is blocking our screenshot service, whitelist our IP address to resolve this: 49.13.14.240.

For Cloudflare, follow these steps:

  1. Log in to your Cloudflare account.
  2. Navigate to Security WAF.
  3. Click on Tools.
  4. In the IP Access Rules box, enter 49.13.14.240.
  5. Select Allow from the action dropdown.
  6. Add “VRTs” as the note.
  7. Click Add.

Reviews

22. Februar 2024
Being able to monitor all my sites for those strange visual changes that sometimes happen after a theme or plugin update is priceless. I’ve worked a bit with support to streamline/exclude some elements of my pages that move, like a video header or carousel or animated button, and I now have this very trustworthy tool to alert me if a site gets wonky. Beyond that, the team working on this plugin is kind and super responsive and open to feedback, which is definitely a big plus. I do have Pro, but the Free works equally as well if you don’t need to trigger manual tests (which I find useful to do after doing updates I know will cause an alert so I don’t have to wait for it the next day). Other VRT solutions I found want a bunch of money per site and that just isn’t realistic for us freelance web folks. This plugin is GREAT!!!
23. Abrëll 2023
I absolutely love this tool and highly recommend it to any freelancers updating multiple sites on a regular basis. It provides a level of comfort because it will catch changes and errors automatically rather than waiting to hear from a client or scrolling way too many pages to assure no errors after updates.
15. Dezember 2022
DISCLAIMER: Yes I work for the company, but I have worked for many companies and I never recommended a product which I was not convinced of. And because I still have 30+ years until retirement, the time for me to move on will come and I don’t want to undermine my credibility and come in a situation where they tell me in my new company “So, you recommended this tool, it was horrible!”And I also work in support, so the last thing I want is to have for example our clients install a tool that brings me headache. Considering all this, I can only recommend this tool. It makes monitoring a website so much easier and I already don’t want to work without it anymore.But don’t believe my words, test it yourself and you will see what I mean. 
6. Dezember 2022
It’s very convenient to track visual bugs or editor’s errors and prevent them from getting to the production site. Disclaimer: I work at the company that built this plugin and we use it for our clients websites, it does its job well.
5. Dezember 2022 2 replies
tja. right now we can’t do anything with the plugin : the “add new” test button is disabled. i have tested and verified this on several wordpress installs with various sets of install plugins – including a fresh clean install. the only published version of this plugin right now is 1.0.0 which leads me to think that the four previous reviews are probably fake. one of them even has the author company name in its nickname (mykolableech) another one has only one other plugin review, and that is on another bleech plugin (skil3e) the other two reviews are by very recent accounts : both created just before posting the review. come on guys, this plugin has very promising features and huge potential. the product page on your website is very exciting. i have been waiting for the release for a long time… i even had a pagescreen monitor on your website to make sure i didn’t miss it ! (such irony) you can do better than this ! i’ll edit this review if anything changes.
Read all 9 reviews

Contributors & Developers

“VRTs – Visual Regression Tests” is open source software. The following people have contributed to this plugin.

Contributors

“VRTs – Visual Regression Tests” has been translated into 1 locale. Thank you to the translators for their contributions.

Translate “VRTs – Visual Regression Tests” into your language.

Interested in development?

Browse the code, check out the SVN repository, or subscribe to the development log by RSS.

Changelog

1.9.1

  • Fixed alerts pagination SQL query compatibility with MySQL 5.7 and lower.

1.9.0

  • Test now run continuously and do not pause upon alerts.
  • Added onboarding for tests and alerts.
  • Fixed character encoding in alert emails.
  • Improved test status display inside the Gutenberg editor and classic metaboxes.
  • Removed pagination for tests.
  • Minor wording and styling changes.

1.8.0

  • Added option to mark alerts as false positive.
  • Improved tests order by status.
  • Minor wording and styling changes.

1.7.1

  • Fixed issue with uninstalling the plugin.

1.7.0

  • Fixed issue with formatted entities for page title inside email notifications.
  • Added bulk action “Add to VRTs” for all public post types.
  • Improved test status display flow.

1.6.0

  • Fixed WordPress 6.4 deprecated notices for list tables.
  • Added hook allowing developers to run tests by calling do_action( 'vrts_run_tests' ).
  • Added test page title and url to email notifications.

1.5.2

  • Changed internal option name.

1.5.1

  • Fixed issues with empty rest data on post update

1.5.0

  • Fixed test status display
  • Fixed url display in alerts list table
  • Added ability to trigger tests manually in specific plans

1.4.0

  • Fixed text domains for translation usage.
  • Added ability to hide elements on the page during screenshot with a css selector. Editable per test via quick edit or on the post’s edit page.
  • Improved outdated base screenshots are removed after fixing an alert or changing a posts content.

1.3.1

  • Improved functionality to create alerts only if pixel difference is > 1
  • Show the current plan on the update page

1.3.0

  • Changed initial validation logic
  • Made functionality work with protected websites
  • Added cron job to fetch test results
  • Allowed adding of tests for unpublished posts
  • Improved code structure
  • Improved communication with external service
  • Improved block editor compatibility and functionality with rest api

1.2.4

  • Fixed an issue that crashes the Gutenberg editor after upgrading to WordPress 6.2
  • Improved metabox behaviour inside the Gutenberg editor

1.2.3

  • Fixed tests and alerts search

1.2.2

  • Fixed url verification for sites using the WPML plugin

1.2.1

  • Fixed url validation on plugin update

1.2

  • Fixed license validations and notifications
  • Fixed alert pixel count
  • Fixed alert view metabox pixel count
  • Fixed status codes for admin ajax
  • Added notification messages if site is moved
  • Added notification inside metabox when service is not available
  • Improved license handling when license is added / removed
  • Improved data removal on plugin uninstall
  • Improved notifications logic inside metabox
  • Minor UI/UX adjustments and improvements

1.1

  • Fixed an issue with the add new test modal in specific cases
  • Fixed notification email site url
  • Added admin-ajax fallback functionality
  • Added messages for error when connecting to external service
  • Improved plugin deactivation & activation
  • Improved test deletion
  • General UI/UX adjustments and improvements

1.0

  • Initial Release