Socket
Book a DemoInstallSign in
Socket

creevey

Package Overview
Dependencies
Maintainers
2
Versions
297
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

creevey

Cross-browser screenshot testing tool for Storybook with fancy UI Runner

latest
npmnpm
Version
0.10.16
Version published
Maintainers
2
Created
Source

Creevey

Cross-browser screenshot testing tool for Storybook with fancy UI Runner.

Creevey downloads Commitizen friendly FOSSA Status

Creevey Demo

Core features

  • 📚 Integrates with Storybook
  • 📜 Uses stories as tests
  • ✏️ Allows write interaction tests
  • ✨ Has fancy UI Runner
  • 🐳 Supports Docker
  • ⚔️ Cross-browsers testing
  • 🔥 Tests hot-reloading
  • ⚙️ CI Ready

It named after Colin Creevey character from the Harry Potter universe.

Contents

Pre-requisites

  • Make sure you have installed Docker. If you are going to use Selenium Grid or run screenshot tests exclusively in CI you don't need Docker in that case.
  • Supported Storybook versions: >= 7.x.x
  • Supported Node.js versions: >= 18.x.x

How to start

  • Install creevey package
yarn add -D creevey
  • Start Creevey Web UI Runner. With -s flag Creevey will start Storybook automatically. (To run headless from CLI, omit the --ui flag)
yarn creevey test -s --ui

NOTE: In first run you may noticed, that all your tests are failing, it because you don't have source screenshot images yet. If you think, that all images are acceptable, you can approve them all from UI.

NOTE: Creevey captures screenshot of the #storybook-root element and sometimes you need to capture a whole browser viewport. To achieve this you could define captureElement Creevey parameter for story or kind. Or you may pass any different css selector. No Storybook addon is required — Creevey reads parameters directly from your stories/config.

// stories/MyModal.stories.tsx
export default {
  title: 'MyModal',
  component: MyModal,
};

export const MyModalStory = { creevey: { captureElement: null } };

Comparison with other tools

Features\ToolsCreeveyLokiStoryshotsHermioneBackstopJSPercy/HappoChromatic
Easy-to-Setup:heavy_check_mark::heavy_check_mark::warning::no_entry::no_entry::heavy_check_mark::heavy_check_mark:
Storybook Support:heavy_check_mark::heavy_check_mark::heavy_check_mark::no_entry::no_entry::heavy_check_mark::heavy_check_mark:
Run tests from Web UI:heavy_check_mark::no_entry::no_entry::no_entry::no_entry::no_entry::no_entry:
Cross-browser:heavy_check_mark::warning::no_entry::heavy_check_mark::no_entry::heavy_check_mark::heavy_check_mark:
Test Interaction:heavy_check_mark::no_entry::warning::heavy_check_mark::heavy_check_mark::no_entry::no_entry:
UI Test Runner:heavy_check_mark::no_entry::no_entry::heavy_check_mark::heavy_check_mark::heavy_check_mark::heavy_check_mark:
Built-in Docker:heavy_check_mark::heavy_check_mark::no_entry::no_entry::heavy_check_mark::warning::warning:
Tests hot-reload:heavy_check_mark::no_entry::no_entry::no_entry::no_entry::no_entry::no_entry:
OSS/SaaSOSSOSSOSSOSSOSSSaaSSaaS

Future plans

  • Allow to define different viewport sizes for specific stories or capture story with different args.
  • And more, check TODO for more details. Also feel free to ask about feature that you want

Known issues

Docker-in-Docker

Currently it's not possible to run Creevey in this configuration. I'll fix this in later versions. If you use CircleCI or another CI that use docker to run jobs. Try to configure to use virtual machine executor

Update I added support to use local browsers. So it should be possible run Creevey inside docker. The only issue, that you need to find or build docker image with node, browser and selenium-webdriver. I'll add special images for Creevey later.

Chrome webdriver + 1px border with border-radius.

This cause to flaky screenshots. Possible solutions:

  • Increase threshold ratio in Creevey config diffOptions: { threshold: 0.1 }
  • Replace border to box-shadow border: 1px solid red -> box-shadow: 0 0 0 1px red
  • Set max retries to more than 5

Used by

WhiskSKB KonturABBYY

License

FOSSA Status

Keywords

testing

FAQs

Package last updated on 05 Sep 2025

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