Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/lost-pixel/lost-pixel
Open source alternative to Percy, Chromatic, Applitools.
https://github.com/lost-pixel/lost-pixel
cd ci developer-tools development-tools github-actions histoire ladle platform quality-assurance saas storybook test-automation testing-tools tools typescript visual-regression-testing visual-regressions vue3
Last synced: 4 days ago
JSON representation
Open source alternative to Percy, Chromatic, Applitools.
- Host: GitHub
- URL: https://github.com/lost-pixel/lost-pixel
- Owner: lost-pixel
- License: mit
- Created: 2021-12-20T21:29:32.000Z (about 3 years ago)
- Default Branch: main
- Last Pushed: 2024-10-29T09:05:00.000Z (2 months ago)
- Last Synced: 2024-10-29T10:57:12.756Z (2 months ago)
- Topics: cd, ci, developer-tools, development-tools, github-actions, histoire, ladle, platform, quality-assurance, saas, storybook, test-automation, testing-tools, tools, typescript, visual-regression-testing, visual-regressions, vue3
- Language: TypeScript
- Homepage: https://lost-pixel.com/
- Size: 35.9 MB
- Stars: 1,342
- Watchers: 7
- Forks: 44
- Open Issues: 48
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
- awesome-python-testing - Lost Pixel - is an open source visual regression testing tool. Run visual regression tests on your Storybook and Ladle stories and on your application pages. (UI Testing)
- awesome-regression-testing - Lost Pixel - Holistic visual regression testing for full pages, components (via Storybook and Ladle integration), and custom shots (e.g. via Cypress). (Tools and frameworks (a-z↓))
README
Lost Pixel
Open source alternative to Percy, Chromatic, Applitools
Documentation
•
Quickstart
•
Examples
Quick start video
## What is Lost Pixel ❓
**Lost Pixel** is an open-source visual regression testing tool. Run visual regression tests on your **Storybook** and **Ladle** stories and your application pages.
| Provider | Status | Description |
| ---------------- | :----: | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
| **Storybook** | ✅ | `First class integration`. Provide your storybook build - Lost Pixel does the rest. |
| **Ladle** | ✅ | `First class integration`. Provide your ladle build - Lost Pixel does the rest. |
| **Histoire** | ✅ | `First class integration`. Provide your histoire build - Lost Pixel does the rest. |
| **Pages** | ✅ | Visual tests for modern frontend apps like **Next**, **Gatsby**, **Remix**. Run your app - provide Lost Pixel with paths to test. |
| **Custom shots** | ✅ | Take care of taking screenshots on your side - provide Lost Pixel with a path to the directory with images. Best suitable for custom **Cypress**/**Playwright** integrations |**Lost Pixel** consists of two products:
- **lost-pixel** - the core engine driving the visual regression test runs. It could be used standalone, and the main use cases are outlined in the documentation
| What machine sees 🤖 | What human sees 👀 |
| ---------------------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------------------------------------------------- |
| ![ezgif-5-e71eb0773d](https://user-images.githubusercontent.com/29632358/185067771-03467437-badd-466b-ad6c-60d7183d99ae.gif) | ![ezgif-5-43091ece5d](https://user-images.githubusercontent.com/29632358/185067989-3f2d818b-c01f-4304-97f6-77295b1970d9.gif) |- **Lost Pixel Platform** - the **UI and CI helpers** that allow you to use lost-pixel's managed version. This includes specified regression UI, collaboration with team members, and an easy approval/rejection process for the snapshots. You can configure it once and enjoy hassle-free visual regression tests integrated into your GitHub actions pipeline. `lost-pixel` repository is **core** to the SaaS offering and is being actively improved & maintained.
https://user-images.githubusercontent.com/29632358/222420960-57924da4-d0bf-4478-9322-fc68686485b6.mp4
## Features
- 🌐 Visual regression testing in a browser of your choice (chrome, firefox, safari)
- 📱 Responsive tests running with [different breakpoints and viewports](https://docs.lost-pixel.com/user-docs/recipes/general-recipes/viewport-tests)
- 🖥️ Multiple browser execution (Chrome, Mozilla, Safari)
- 🔀 Parallel execution (limited in OSS version)
- 🎚️ Flexible sensitivity [thresholds](https://docs.lost-pixel.com/user-docs/recipes/general-recipes/thresholds)
- 🔄 Flaky test retries. [Utilities to reduce flakiness](https://docs.lost-pixel.com/user-docs/recipes/general-recipes/flakiness).
- 🚫 [Masking of parts of the UI](https://docs.lost-pixel.com/user-docs/recipes/general-recipes/masking-page-elements) that should be excluded from tests
- ✅ Seamless approval flow (**Lost Pixel Platform only**)
- 🤖 [Executing arbitrary code](https://docs.lost-pixel.com/user-docs/recipes/general-recipes/executing-arbitrary-code-before-tests-runs) before tests to reduce flakiness
- 🖼️ Review UI that makes comparing images an effortless task (**Lost Pixel Platform only**)
- 📦 [Monorepo execution ](https://docs.lost-pixel.com/user-docs/recipes/lost-pixel-platform/monorepo)(**Lost Pixel Platform only**)## Quick start ⚡
Storybook 🖼
Assuming you are using [basic example of Storybook](<[https://github.com/tajo/ladle](https://github.com/snipcart/nextjs-storybook-example)>). This setup will run visual regression tests against all the storybook stories on every push.
You can find more examples in the [examples repository](https://github.com/lost-pixel/lost-pixel-examples). You can learn more about Lost Pixel workflow and get more useful recipes in [documentation](https://docs.lost-pixel.com/user-docs).
Add `lostpixel.config.ts` at the root of the project:
```typescript
import { CustomProjectConfig } from 'lost-pixel';export const config: CustomProjectConfig = {
storybookShots: {
storybookUrl: './storybook-static',
},
// OSS mode
generateOnly: true,
failOnDifference: true
// Lost Pixel Platform (to use in Platform mode, comment out the OSS mode and uncomment this part )
// lostPixelProjectId: "xxxx",
// process.env.LOST_PIXEL_API_KEY,
};
```Add GitHub action `.github/workflows/lost-pixel-run.yml`
```yml
on: [push]jobs:
build:
runs-on: ubuntu-lateststeps:
- name: Checkout
uses: actions/checkout@v3- name: Setup Node
uses: actions/setup-node@v3
with:
node-version: 18.x
cache: 'npm'- name: Install dependencies
run: npm ci- name: Build Storybook
run: npm run build-storybook- name: Lost Pixel
uses: lost-pixel/[email protected]
```Ladle example 🥄
Assuming you are using [basic example of Ladle](https://github.com/tajo/ladle). This setup will run visual regression tests against all the ladle stories on every push.
You can find more examples in the [examples repository](https://github.com/lost-pixel/lost-pixel-examples). You can learn more about Lost Pixel workflow and get more useful recipes in [documentation](https://docs.lost-pixel.com/user-docs).
Add `lostpixel.config.ts` at the root of the project:
```typescript
import { CustomProjectConfig } from 'lost-pixel';export const config: CustomProjectConfig = {
ladleShots: {
//ip should be localhost when running locally & 172.17.0.1 when running in GitHub action
ladleUrl: 'http://172.17.0.1:61000',
},
// OSS mode
generateOnly: true,
failOnDifference: true
// Lost Pixel Platform (to use in Platform mode, comment out the OSS mode and uncomment this part )
// lostPixelProjectId: "xxxx",
// process.env.LOST_PIXEL_API_KEY,
};
```Update `package.json` with following scripts:
```json
"scripts": {
"serve": "npx serve build -p 61000",
"build": "ladle build"
},
```Add GitHub action `.github/workflows/lost-pixel-run.yml`
```yml
on: [push]jobs:
build:
runs-on: ubuntu-lateststeps:
- name: Checkout
uses: actions/checkout@v3- name: Setup Node
uses: actions/setup-node@v3
with:
node-version: 18.x
cache: 'npm'- name: Install dependencies
run: npm install- name: Build ladle
run: npm run build- name: Serve ladle
run: npm run serve &- name: Lost Pixel
uses: lost-pixel/[email protected]
```Histoire example 📖
Assuming you are using [basic example of Histoire](https://github.com/histoire-dev/histoire/tree/main/examples/vue3). This setup will run visual regression tests against all the histoire stories on every push.
You can find more examples in the [examples repository](https://github.com/lost-pixel/lost-pixel-examples). You can learn more about Lost Pixel workflow and get more useful recipes in [documentation](https://docs.lost-pixel.com/user-docs).
Add `lostpixel.config.ts` at the root of the project:
```typescript
import { CustomProjectConfig } from 'lost-pixel';export const config: CustomProjectConfig = {
histoireShots: {
//ip should be localhost when running locally & 172.17.0.1 when running in GitHub action
histoireUrl: './.histoire/dist',
},
// OSS mode
generateOnly: true,
failOnDifference: true
// Lost Pixel Platform (to use in Platform mode, comment out the OSS mode and uncomment this part )
// lostPixelProjectId: "xxxx",
// process.env.LOST_PIXEL_API_KEY,
};
```Add GitHub action `.github/workflows/lost-pixel-run.yml`
```yml
on: [push]jobs:
build:
runs-on: ubuntu-lateststeps:
- name: Checkout
uses: actions/checkout@v3- name: Setup Node
uses: actions/setup-node@v3
with:
node-version: 18.x
cache: 'npm'- name: Install dependencies
run: npm install- name: Build histoire
run: npm run story:build- name: Lost Pixel
uses: lost-pixel/[email protected]
```Pages example(next.js) ⚛️
Assuming you are using [basic example of Next.js](https://nextjs.org/docs). This setup will run visual regression tests against **selected pages** on every push.
You can find more examples in the [examples repository](https://github.com/lost-pixel/lost-pixel-examples). You can learn more about Lost Pixel workflow and get more useful recipes in [documentation](https://docs.lost-pixel.com/user-docs).
Add `lostpixel.config.ts` at the root of the project:
```typescript
import { CustomProjectConfig } from 'lost-pixel';export const config: CustomProjectConfig = {
pageShots: {
pages: [{ path: '/app', name: 'app' }],
// IP should be localhost when running locally & 172.17.0.1 when running in GitHub action
baseUrl: 'http://172.17.0.1:3000',
},
// OSS mode
generateOnly: true,
failOnDifference: true
// Lost Pixel Platform (to use in Platform mode, comment out the OSS mode and uncomment this part )
// lostPixelProjectId: "xxxx",
// process.env.LOST_PIXEL_API_KEY,
};
```Add GitHub action `.github/workflows/lost-pixel-run.yml`
```yml
on: [push]jobs:
build:
runs-on: ubuntu-lateststeps:
- name: Checkout
uses: actions/checkout@v3- name: Setup Node
uses: actions/setup-node@v3
with:
node-version: 18.x
cache: 'npm'- name: Install dependencies
run: npm ci- name: Build Next app
run: npm run build- name: Run Next app
run: npm run start &- name: Lost Pixel
uses: lost-pixel/[email protected]
```Custom shots (Playwright example)🎭
Assuming you are running some playwright tests, where you want to add visual tests at any step. This setup will run visual regression tests against all the tests, where you've generated lost-pixel screenshots, on every push.
You can find more examples in the [examples repository](https://github.com/lost-pixel/lost-pixel-examples). You can learn more about Lost Pixel workflow and get more useful recipes in [documentation](https://docs.lost-pixel.com/user-docs).
Add `lostpixel.config.ts` at the root of the project:
```typescript
import { CustomProjectConfig } from 'lost-pixel';export const config: CustomProjectConfig = {
customShots: {
currentShotsPath: "./lost-pixel",
},
// OSS mode
generateOnly: true,
failOnDifference: true
// Lost Pixel Platform (to use in Platform mode, comment out the OSS mode and uncomment this part )
// lostPixelProjectId: "xxxx",
// process.env.LOST_PIXEL_API_KEY,
};
```Update your Playwright tests with following line(note, that there is no external dependency needed here):
```javascript
import { test } from '@playwright/test';test('lost-pixel e2e', async ({ page }) => {
// Start from the index page (the baseURL is set via the webServer in the playwright.config.ts)
await page.goto('http://172.17.0.1:3000/context');
await page.click('data-test-id=context-click-counter');
await page.click('data-test-id=context-click-counter');
await page.click('data-test-id=context-click-counter');
await page.click('data-test-id=context-click-counter');
// Run lost-pixel visual regression test after doing some functional testing on the page
await page.screenshot({ path: 'lost-pixel/a.png', fullPage: true });
});
```Add GitHub action `.github/workflows/lost-pixel-run.yml`
```yml
on: [push]jobs:
build:
runs-on: ubuntu-latest
name: Lost Pixelsteps:
- name: Checkout
uses: actions/checkout@v3- name: Setup Node
uses: actions/setup-node@v3
with:
node-version: 16.x- name: Install dependencies
run: npm install --legacy-peer-deps- name: Build Next app
run: npm run build- name: Run Next app
run: npm run start &- name: Playwright tests
run: npx playwright install --with-deps && npm run test:e2e- name: Lost Pixel
uses: lost-pixel/[email protected]
env:
LOST_PIXEL_API_KEY: ${{ secrets.LOST_PIXEL_API_KEY }}
```---
## Support 👨🏼💻
### Ask a question about Lost Pixel
You can ask questions and initiate [discussions](https://github.com/lost-pixel/lost-pixel/discussions/) about Lost Pixel.
❓ [**Ask a question**](https://github.com/lost-pixel/lost-pixel/discussions/new)
### Create a bug report for Lost Pixel
If you see an error message or run into an issue, help us with creating a bug report!
🐛 [**Create bug report**](https://github.com/lost-pixel/lost-pixel/issues/new?assignees=&labels=kind%2Fbug&template=bug.yml)
### Submit a feature request
If Lost Pixel at the moment doesn't support some mode or does not have a feature we would appreciate your thoughts!
🆕 [**Submit feature request**](https://github.com/lost-pixel/lost-pixel/issues/new?assignees=&labels=kind%2Ffeature&template=feature.yml)
### Community
Want to chat about visual regression testing with likeminded people? We've started a community! Discuss your pipelines, tools, testing strategy, get faster support!
Join our Discord
---
### Using Lost Pixel Platform in non-commercial Open Source projectsWe are excited to offer you free usage of Lost Pixel Platform(SaaS) for your Open Source repositories, feel free to reach out to [email protected] to get started!
If you are already using Lost Pixel it would mean a lot to us if you give us a shoutout by including our badge in your OSS project readme!
---
## Contributing 🏗️
**Lost Pixel** is open source in it's heart and welcomes any external contribution. You can refer to [CONTRIBUTING.md](https://github.com/lost-pixel/lost-pixel/blob/main/CONTRIBUTING.md) to get going with the project locally in couple of minutes.
## Lost Pixel Usage Insights 📈
[![lost-pixel npminsights](https://npminsights.vercel.app/api/package/readme-image/lost-pixel)](https://npminsights.vercel.app/package/lost-pixel)