New Research: Supply Chain Attack on Axios Pulls Malicious Dependency from npm.Details →
Socket
Book a DemoSign in
Socket

visual-regression

Package Overview
Dependencies
Maintainers
1
Versions
11
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

visual-regression

Visual regression testing tool

latest
Source
npmnpm
Version
3.0.0
Version published
Maintainers
1
Created
Source

Visual Regression

Sponsored PRs Welcome license

Test websites for visual regressions on different viewport sizes using Puppeteer.

Inspired by this blog post by Monica Dinculescu.

This tool may be useful to be run right before and right after a deployment that is not supposed to change anything visually (refactoring etc.).

Usage

  • Install it: npm i -D visual-regression or yarn add -D visual-regression

After that, you can import it and test for visual regression.

The contents of your test file test/example.test.js could look something like this:

const visualRegression = require('visual-regression');

const viewportConfigs = [
  {
    width: 480,
    height: 800,
  },
  {
    width: 800,
    height: 600,
  },
  {
    width: 1024,
    height: 1024,
  },
];

describe('example.com looks ok', () => {
  const options: RegressionTestOptions = {
    // Let's use a page that is not very likely to change visually over time
    baseUrl: 'http://example.com',
    testPaths: ['/'],
    viewportConfigs,
    launchOptions: { headless: true },
    navigationOptions: { waitUntil: 'networkidle2' },
    screenshotOptions: { fullPage: true },
  };

  visualRegression.run(options);
});

And you would run it with jest:

 "test": "jest",

How it works

  • visual-regression uses puppeteer for opening a page and capturing a screenshot of the contents
  • It uses jest-image-snapshot for checking that the screenshots match the previous snapshots

Sample output

Sample output

Development

Install dependencies: yarn

Run tests: npm test

Publishing a new version:

//TODO: Automate this process

  • Make the changes and test them
  • Bump the version in package.json
  • Run the build: npm run build
  • Publish: npm publish

Supporters

This project is sponsored by Futurice's Open Source Sponsorship program

Supported by the Spice Program

Keywords

puppeteer

FAQs

Package last updated on 18 Jan 2021

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts