Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/antondomashnev/fbsnapshotsviewer

A mac os application that shows the failing snapshot tests from FBSnapshotTestCase
https://github.com/antondomashnev/fbsnapshotsviewer

snapshot-testing tool xcode

Last synced: 1 day ago
JSON representation

A mac os application that shows the failing snapshot tests from FBSnapshotTestCase

Awesome Lists containing this project

README

        

# FBSnapshotsViewer

[![Build Status](https://travis-ci.org/Antondomashnev/FBSnapshotsViewer.svg?branch=master)](https://travis-ci.org/Antondomashnev/FBSnapshotsViewer)
[![codebeat badge](https://codebeat.co/badges/f21f5fd8-5b7e-4cec-bc3e-8ce719300ed7)](https://codebeat.co/projects/github-com-antondomashnev-fbsnapshotsviewer)
[![codecov](https://codecov.io/gh/Antondomashnev/FBSnapshotsViewer/branch/master/graph/badge.svg)](https://codecov.io/gh/Antondomashnev/FBSnapshotsViewer)

A macOs application that shows the failing snapshot tests from [FBSnapshotTestCase](https://github.com/facebook/ios-snapshot-test-case) because it's a pain to parse the console logs by myself.

## Why FBSnapshotsViewer?

I've been using an amazing [plugin](https://github.com/orta/Snapshots) to check the failing test's snapshots, but unfortunately, with Xcode 8 the plugins are not officially supported anymore, so I've decided to build an app which will work regardless Apple's decisions about Xcode and plugins ecosystem.

There are some benefits using it:
* Real-time feedback about failed snapshot test.
* Real-time feedback about recorded snapshot test.
* Clear output with reference | diff | failed image
* Split and diff mode to see exact differences
* One click to use failed image as a recorded
* Xcode and AppCode support

![Example](Resources/Example.png)

## How it works?

The idea behind the job is quite tricky, but the overall concept is straightforward:
1. The app listens for the changes in Xcode DerivedData folder;
2. When the app finds new .log file generated by Xcode it starts parsing it;
3. Through the parsing it extracts the generated information by iOS snapshot tests framework and shows in UI

## Installation

### FBSnapshotsViewer application

At the moment there is only one option to install the app:
Navigate to [releases](https://github.com/Antondomashnev/FBSnapshotsViewer/releases) and download the latest `FBSnapshotsViewer-xyz.app.zip` release.

We encourage you to turn automatic update on, so you'll be always up to date 🚀

## Usage

As simple as just run the app and run tests in your app 🎉

### App Code

For the AppCode support the app needs to know where is a folder with generated test logs:
Open `FBSnapshotsViewer` -> `Right click` -> `Preferences` -> Set derived data folder path as a path like `~/Library/Caches/AppCodeXYZ` where `XYZ` is an AppCode version. Usually you'll have only one such folder under the `Caches` directory.

## Contribution

Contributions to FBSnapshotsViewer are welcomed and encouraged!
Please see the [Contributing guide](CONTRIBUTING.md) for more details.

## License

FBSnapshotsViewer is available under the MIT license. See [LICENSE](LICENSE) for more information.