Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/bbc/wraith
Wraith — A responsive screenshot comparison tool
https://github.com/bbc/wraith
Last synced: about 20 hours ago
JSON representation
Wraith — A responsive screenshot comparison tool
- Host: GitHub
- URL: https://github.com/bbc/wraith
- Owner: bbc
- License: apache-2.0
- Created: 2013-01-23T15:26:31.000Z (about 12 years ago)
- Default Branch: master
- Last Pushed: 2023-01-15T21:10:16.000Z (about 2 years ago)
- Last Synced: 2024-10-29T15:35:04.872Z (4 months ago)
- Language: Ruby
- Homepage: http://bbc-news.github.io/wraith/
- Size: 9.03 MB
- Stars: 4,837
- Watchers: 162
- Forks: 358
- Open Issues: 124
-
Metadata Files:
- Readme: README.md
- Contributing: .github/CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
README
data:image/s3,"s3://crabby-images/5270d/5270d508d538fa0ea04e96c9893efc0cbd211f9e" alt="Wraith logo"
[data:image/s3,"s3://crabby-images/3e676/3e676e6e94a4cdaf2ff22ddf62197a9dd8c76e3e" alt="build status"](http://travis-ci.org/BBC-News/wraith)
[data:image/s3,"s3://crabby-images/a966f/a966fef12946809ab1128f06828944ae3c19ea45" alt="rubygems version"](https://rubygems.org/gems/wraith)
[data:image/s3,"s3://crabby-images/72739/72739e2ec40fb0ddffdc5b6dc7399693e2fa848b" alt="codeclimate report"](https://codeclimate.com/github/BBC-News/wraith)Wraith is a screenshot comparison tool, created by developers at BBC News.
[Documentation](http://bbc-news.github.io/wraith/) • [Source](http://github.com/bbc-news/wraith) • [Responsive News Website](http://responsivenews.co.uk)
## What is it?
Wraith uses a headless browser to create screenshots of webpages on different environments (or at different moments in time) and then creates a diff of the two images; the affected areas are highlighted in blue.
data:image/s3,"s3://crabby-images/11c5a/11c5af025eb65a39d9ada98da2b66585e517d553" alt="Photo of BBC News with a diff"
## Documentation
For instructions on how to install, set up and use Wraith and all of its features, [visit the Wraith documentation](http://bbc-news.github.io/wraith/index.html).
A brief overview of how Wraith works is provided below.
## Wraith modes
There are several ways in which Wraith can be used:
1. Comparison of 2 domains (`wraith capture`). There are also some specialist options within this mode:
* Spidering 2 domains for changes (`wraith capture` when no `paths` property is provided in the configuration file)
* Running several comparisons at once (`wraith multi_capture`)
2. Comparing the same domain over time (`wraith history`, then `wraith latest`)Whichever mode you decide to run Wraith in, the process it follows is generally the same:
* takes screenshots of your webpages
* runs a comparison task across them
* outputs a diff PNG file comparing the two images, and a data.txt file which contains the percentage of pixels that have changed
* packages all of this up into a gallery.html, ready for you to view
* if any screenshot's diff is above the threshold you specified in your configuration file, the task exits with a system error code (useful for CI)
* the failed screenshot will also be highlighted in the gallery## Requirements
[ImageMagick](http://www.imagemagick.org/) is required to compare the screenshots and crop images.
Wraith also requires at least one of these headless browsers:
* [PhantomJS](http://phantomjs.org)
* [CasperJS](http://casperjs.org/) (which can be used to target specific selectors)
* [SlimerJS](http://slimerjs.org)
* [Chrome](https://askubuntu.com/questions/510056/how-to-install-google-chrome/510063) (Currently using Selenium WebDriver + Chromedriver for Chrome; Can target specific selectors)## Contributing
Please read [how to contribute to Wraith](https://github.com/BBC-News/wraith/blob/master/.github/CONTRIBUTING.md).
## License
Wraith is available to everyone under the terms of the Apache 2.0 open source license. [Take a look at Wraith's LICENSE file](https://github.com/BBC-News/wraith/blob/master/LICENSE).
## Credits
* [Dave Blooman](https://twitter.com/dblooman)
* [John Cleveley](https://twitter.com/jcleveley)
* [Simon Thulbourn](https://twitter.com/sthulb)
* [Chris Ashton](https://twitter.com/chrisbashton)## Selenium-Wraith
Anyone interested in integrating selenium capability with Wraith should check out [Selenium-Wraith](https://github.com/mathew-hall/wraith-selenium) (maintained by Mathew Hall), which was forked from BBC's Wraith on 16/04/14 and adds the following capabilities:
1. Selenium integration, both running locally on a desktop or on a selenium grid
2. Browser to browser screenshot comparison
3. Page component-based comparison