Percy: Automating Visual Testing for Seamless UI Quality
This article, created in partnership with Percy, explores how to implement automated visual testing to ensure your user interface (UI) remains consistent across different browsers and screen sizes. While unit and integration tests verify application logic, they often miss visual defects. Percy provides a solution by automating the process of capturing and comparing visual snapshots, highlighting discrepancies and streamlining the review process.
This tutorial uses an API-driven single-page application as a practical example. You'll learn how Percy handles dynamic data and integrates with your workflow for efficient visual reviews and approvals.
Key Benefits of Percy:
- Early Detection of UI Issues: Catches visual bugs missed by traditional testing, ensuring consistent UI across browsers and screen sizes.
- Automated Snapshot Comparison: Automates the capture and comparison of visual snapshots, highlighting differences for easy review.
- Simple Integration: Installation and integration are straightforward, similar to setting up standard testing frameworks.
- Dynamic Data Handling: Effectively manages UIs displaying dynamic data, preventing false positives from data changes.
- Streamlined Approval Workflow: Facilitates team review and approval of visual changes, ensuring only intended modifications are deployed.
- Versatile SDKs: Offers SDKs for various testing frameworks, enhancing compatibility with existing development environments.
Prerequisites:
This tutorial targets intermediate to advanced JavaScript developers familiar with ES6 syntax, Express.js (for RESTful APIs), jQuery, Axios, CSS frameworks, Git branching strategies, and ideally, experience with testing frameworks. A GitHub account is required. We'll use a sample currency application available on GitHub.
Understanding Percy:
Percy offers a platform and workflow for visual testing of web apps, static sites, and component libraries. Its free plan includes unlimited team members, 5,000 snapshots monthly (with a one-month history), and unlimited projects. The process involves installing an SDK, creating a project dashboard, and integrating with your codebase. Percy renders snapshots in Chrome and Firefox, supporting up to ten screen resolutions.
Implementation Steps:
-
Setting up the Demo Project: Fork the provided GitHub repository and follow the README instructions to set up the sample currency application.
-
Setting up the Percy Project Dashboard: Sign up for a free Percy account, create a project ("Percy-Tutorial"), and link it to your GitHub repository. Obtain your
PERCY_TOKEN
. -
Generating Percy Snapshots: Install the
@percy/script
package (npm install -D @percy/script
). Createsnapshots.js
(see the original article for the code). This script uses Puppeteer to interact with the application and generate snapshots for each page. Remember to runnpm start
in a separate terminal to start the application before running the Percy script. Execute the script usingexport PERCY_TOKEN=<your_token> && npx percy exec -- node snapshots.js</your_token>
. -
Handling Dynamic Data: Modify
snapshots.js
to intercept API requests and replace responses with mock data to ensure consistent snapshots. (See the original article for the updated code). -
Approval Workflow: Create a feature branch, make visual changes, commit, push, create a pull request on GitHub, run Percy tests, approve the build in the Percy dashboard, and merge the branch. Finally, update the master branch and run Percy tests again to establish a new baseline.
Continuous Integration (CI) and SDK Integration:
Percy integrates with various CI/CD platforms (AppVeyor, Azure Pipelines, etc.) for automated testing. It also supports various SDKs for integration with different testing frameworks (e.g., Cypress). The original article provides an example of Cypress integration.
Conclusion:
Percy significantly enhances UI testing by automating the process and providing a streamlined workflow for reviewing and approving visual changes. By integrating Percy into your development process, you can significantly reduce the risk of releasing products with visual defects. The FAQs in the original article provide further details on visual testing concepts and Percy's capabilities.
The above is the detailed content of A Guide to Visual Testing with Percy. For more information, please follow other related articles on the PHP Chinese website!

Yes, the engine core of JavaScript is written in C. 1) The C language provides efficient performance and underlying control, which is suitable for the development of JavaScript engine. 2) Taking the V8 engine as an example, its core is written in C, combining the efficiency and object-oriented characteristics of C. 3) The working principle of the JavaScript engine includes parsing, compiling and execution, and the C language plays a key role in these processes.

JavaScript is at the heart of modern websites because it enhances the interactivity and dynamicity of web pages. 1) It allows to change content without refreshing the page, 2) manipulate web pages through DOMAPI, 3) support complex interactive effects such as animation and drag-and-drop, 4) optimize performance and best practices to improve user experience.

C and JavaScript achieve interoperability through WebAssembly. 1) C code is compiled into WebAssembly module and introduced into JavaScript environment to enhance computing power. 2) In game development, C handles physics engines and graphics rendering, and JavaScript is responsible for game logic and user interface.

JavaScript is widely used in websites, mobile applications, desktop applications and server-side programming. 1) In website development, JavaScript operates DOM together with HTML and CSS to achieve dynamic effects and supports frameworks such as jQuery and React. 2) Through ReactNative and Ionic, JavaScript is used to develop cross-platform mobile applications. 3) The Electron framework enables JavaScript to build desktop applications. 4) Node.js allows JavaScript to run on the server side and supports high concurrent requests.

Python is more suitable for data science and automation, while JavaScript is more suitable for front-end and full-stack development. 1. Python performs well in data science and machine learning, using libraries such as NumPy and Pandas for data processing and modeling. 2. Python is concise and efficient in automation and scripting. 3. JavaScript is indispensable in front-end development and is used to build dynamic web pages and single-page applications. 4. JavaScript plays a role in back-end development through Node.js and supports full-stack development.

C and C play a vital role in the JavaScript engine, mainly used to implement interpreters and JIT compilers. 1) C is used to parse JavaScript source code and generate an abstract syntax tree. 2) C is responsible for generating and executing bytecode. 3) C implements the JIT compiler, optimizes and compiles hot-spot code at runtime, and significantly improves the execution efficiency of JavaScript.

JavaScript's application in the real world includes front-end and back-end development. 1) Display front-end applications by building a TODO list application, involving DOM operations and event processing. 2) Build RESTfulAPI through Node.js and Express to demonstrate back-end applications.

The main uses of JavaScript in web development include client interaction, form verification and asynchronous communication. 1) Dynamic content update and user interaction through DOM operations; 2) Client verification is carried out before the user submits data to improve the user experience; 3) Refreshless communication with the server is achieved through AJAX technology.


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Dreamweaver Mac version
Visual web development tools

VSCode Windows 64-bit Download
A free and powerful IDE editor launched by Microsoft

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Safe Exam Browser
Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.

Dreamweaver CS6
Visual web development tools
