{"id":2524,"date":"2015-09-29T10:26:57","date_gmt":"2015-09-29T10:26:57","guid":{"rendered":"http:\/\/www.gallop.net\/blog\/?p=732"},"modified":"2018-10-03T14:33:39","modified_gmt":"2018-10-03T09:03:39","slug":"add-visual-testing-to-existing-selenium-tests","status":"publish","type":"post","link":"https:\/\/www.cigniti.com\/blog\/add-visual-testing-to-existing-selenium-tests\/","title":{"rendered":"How to Add Visual Testing to Existing Selenium Tests"},"content":{"rendered":"
Selenium is a free, open-source testing tool that is used to automate testing. It is mostly used to test software on their functional aspects and isn\u2019t optimized to include testing on their visual aspects. There exists a strong misconception within the industry on the ease of automating visual testing. These opinions are unfounded as the automation of visual testing isn\u2019t extremely challenging. Therefore, while almost every aspect of testing today is automated, a lot of enterprises still employ the use of manual testing when it comes to visuals. This forms a bottleneck for these organizations when it comes to achieving continuous deployment. Automating visual testing is rather simplistic. Automation is also possible for both new and existing Selenium tests.<\/p>\n
What is Visual Testing?<\/strong><\/p>\n It is defined as the act of inspecting an application\u2019s graphical user interface [GUI] and ensuring it is displayed as intended. It is also occasionally labelled as visual checking or visual regression testing. As the name suggests, the objective of visual testing is to find visual errors. Errors like misalignment of objects, font, layout, rendering issues, etc. It can also be implemented to verify the content on a page, which makes it lucrative for websites with high graphical functionality [charts, graphs, dashboards, etc.].<\/p>\n Visual Testing and Selenium:<\/strong><\/p>\n Since Selenium isn\u2019t designed to test visual appearance and\/or the CSS-Code directly, other approaches have to be considered:<\/p>\n The comparison using the screenshot method is the easiest to implement. With the use of a third-party software, such as Applitools Eyes, one can add testing checks even into existing Selenium tests. Add another program like Sauce Labs to the mix, and one can test across almost every browser, device, platform, and configured in any combination. The many variables involved magnify the operational complexity, but implementing the other existing open source\/commercial solutions makes Visual Testing feasible. It adds tremendous value and is also becoming easier to implement with every passing day.<\/p>\n How does it work?<\/strong><\/p>\n Let\u2019s consider a single automated visual test. During the test a single page is looked at and every distinct element displayed on it is verified to render correctly. Therefore, even on a single page, hundreds of objects are checked for various characteristics [position, overlaps, incorrect rendering, etc.]. A single visual test directly translates into a hundred different verifications. This process repeats itself with each distinct visual test. It can then be scaled to each browser, operating system, device, screen resolution, etc. taking one a few steps closer to continuous delivery.<\/p>\n There are several tools that can be used along with Selenium to perform Visual Tests (for example, Applitools Eyes). Though they might be different from each other, all of them follow variations of the following workflow:<\/p>\n Every time a script is run, a screenshot is taken. A screenshot taken initially becomes the baseline image used for comparisons in the future. Every subsequent run, the newer screenshot is verified to be within the mismatch tolerance limit specified for the baseline image. If the mismatch exceeds the tolerance limits, the script fails. Once the script fails enough times, the baseline image can be updated automatically to ensure it represents the newest version of the GUI, but only when instructed to do so. With this method, Visual Test automation can be easily incorporated into existing Selenium tests as well, and the shortened development cycle makes continuous development much easier.<\/p>\n On 1st<\/sup> June, 2015, SeleniumHQ labeled Gallop Solutions as an Aluminum Level Sponsor on their official website, www.seleniumhq.org. This recognition confirms Gallop\u2019s position as a specialized software testing service provider, committed to making sure clients get value from their QA investments.<\/p>\n\n
\n