/$$$$$$$ /$$$$$$$$ /$$$$$$$ /$$$$$$ /$$ /$$ /$$$$$$$ /$$$$$$$ /$$$$$$$$ /$$$$$$ /$$$$$$
| $$__ $$| $$_____/| $$__ $$ /$$__ $$| $$ /$$/| $$__ $$| $$__ $$| $$_____/ /$$__ $$ /$$__ $$
| $$ \ $$| $$ | $$ \ $$| $$ \__/ \ $$ /$$/ | $$ \ $$| $$ \ $$| $$ | $$ \__/| $$ \__/
| $$$$$$$/| $$$$$ | $$$$$$$/| $$ \ $$$$/ | $$$$$$$/| $$$$$$$/| $$$$$ | $$$$$$ | $$$$$$
| $$____/ | $$__/ | $$__ $$| $$ \ $$/ | $$____/ | $$__ $$| $$__/ \____ $$ \____ $$
| $$ | $$ | $$ \ $$| $$ $$ | $$ | $$ | $$ \ $$| $$ /$$ \ $$ /$$ \ $$
| $$ | $$$$$$$$| $$ | $$| $$$$$$/ | $$ | $$ | $$ | $$| $$$$$$$$| $$$$$$/| $$$$$$/
|__/ |________/|__/ |__/ \______/ |__/ |__/ |__/ |__/|________/ \______/ \______/
An example project that demonstrates the very bare-bones capabilities of using Percy within Cypress tests to take snapshots of web pages, for visual regression testing. The snapshots are then uploaded to Percy's dashboard, where they can be reviewed.
- NVM: 0.39.3
- Node: 20.4.0
- NPM: 9.7.2
git clone git@github.com:ryanaltvater/percypress.git
Install Node Version Manager (NVM)
curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.3/install.sh
nvm
allows the installation and use of different versions of Node, via the command line.
Install Node
First, navigate to the repo's root directory.
cd path/to/repo
Then, install Node.
nvm install
- Uses the version of Node that's specified in the
.nvmrc
file.
Install dependencies
npm ci
ci
stands for clean install, and is used to install exact versions of all dependencies from apackage-lock.json
file.npm i
(ornpm install
) is used to install all dependencies from apackage.json
file.
npm run open
- Develop new tests, or test/debug existing ones.
- Percy will be disabled in this mode, and not take snapshots.
- Testing happens within the Cypress GUI, and not the command line.
npm run tests -- project-name
- Run all tests that are associated with the specified project.
- Percy will be enabled in this mode, and take snapshots.
- Testing happens within the command line, and not the Cypress GUI.
- A collection of environment variables that are used by Percy.
- When setting up a new project of tests, add a corresponding Percy token to this file.
- Ensure that the token name matches the project name, to avoid errors.
- If the project name is
project-name
, then the token name should bePROJECT_NAME
. - The difference between hyphens and underscores, for spacing, is handled dynamically.
- The project name can use hyphens, underscores, or no spacing.
- The token name can use underscores, or no spacing.
- Refer to the chart below, for examples.
- If the project name is
Project | Token | |
---|---|---|
Correct | project-name |
PROJECT_NAME |
Correct | project_name |
PROJECT_NAME |
Correct | projectname |
PROJECTNAME |
Correct | pn |
PN |
Incorrect | projectname |
PROJECT_NAME |
Incorrect | projectname |
PROJECT_NAME |
Incorrect | project |
NAME |
Incorrect | pn |
PROJECTNAME |
- The configuration file allows you to customize various settings and behaviors for your test suite.
- For more information, refer to the configuration documentation.
- The file that dynamically sets the environment variables and executes tests, based on the provided project name.