Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/honzabrecka/Screenshot

Screenshot is an ActionScript 3 util for integration testing of UI components. It perfectly works with FlexUnit testing flow and Flex Framework UI components.
https://github.com/honzabrecka/Screenshot

Last synced: about 2 months ago
JSON representation

Screenshot is an ActionScript 3 util for integration testing of UI components. It perfectly works with FlexUnit testing flow and Flex Framework UI components.

Awesome Lists containing this project

README

        

Screenshot [![Build Status](https://travis-ci.org/honzabrecka/Screenshot.svg?branch=master)](https://travis-ci.org/honzabrecka/Screenshot)
==========

Screenshot is an ActionScript 3 util for integration testing of UI components. It perfectly works with FlexUnit testing flow and Flex Framework UI components.

> Flash has one special ability - output always looks the same.

Fast, lightweight and easy to use
---------------------------------

```as3
[Test(async, ui)]
public function defaultColor():void
{
var component:Square = new Square();
Async.proceedOnEvent(this, component, Event.ADDED);
UIImpersonator.addChild(component);

// this is the line!
assertTrue(Screenshot.compare("SquareTest.defaultColor", component));
}
```

Setup
-----

At first of all you have to set the `ScreenShot.dictionary` property, which is a simple key value storage. It includes fixtures (expected states of your UI components). You can fill it manually:

```as3
[Embed(source="SquareTest.defaultColor.png")]
private var SquareWithDefaultColor:Class;
...
Screenshot.dictionary = {};
Screenshot.dictionary["SquareTest.defaultColor"] = Bitmap(new SquareWithDefaultColor()).bitmapData;
```

or, which is much better and prefered way, use the `LoadQueue` class and load fixtures at runtime:

```as3
var queue:LoadQueue = new LoadQueue("../fixtures/");
queue.addEventListener(Event.COMPLETE, function(event:Event):void
{
Screenshot.dictionary = queue.dictionary;
});
// list of fixtures, which will be loaded (name is without any extension!)
queue.load(new ["SquareTest.defaultColor"]);
```

Then you have to set the `Screenshot.save` property to a new instance of the `Upload` class to be able to upload a screenshot of an actual state of your UI component to the server:

```as3
Screenshot.save = new Upload("http://127.0.0.1:4000/upload.php");
```

> Server can be started by `$ php -S 127.0.0.1:4000`

Now if you run your test case it should fail, but the `SquareTest.defaultColor-actual.png` file should appear in your fixtures directory. If it looks as you expected, you can mark it as a valid fixture by removing the `-actual` suffix from its name.

You've covered your ass, now!

> `Screenshot.save` is also used for saving a "diff between an actual and an expected state". It's really useful for debugging.

Known issues
------------

Pure ActionScript projects may throw "VerifyError: Error #1014: Class mx.graphics.codec::IImageEncoder could not be found." error when you run your test suite. To solve this, just link the `flex_sdk_location/frameworks/libs/framework.swc`.

Sometimes you can see "Adobe Flash Player has stopped a potentially unsafe operation." error message when you run your test suite. To solve this, just add the swf file location to the trusted list in Adobe FlashPlayer Settings Manager in order to allow a local swf connect the internet.

Best practices
--------------

### Naming

The best is the following format `.`

### Resizing

If you have to test sizable components (let's say bigger than 100px in any way), you should use `Resizer`, which resizes them to smaller version. It can save a lot of time needed by pixel by pixel comparison:

```as3
Screenshot.resizer = new Resizer(100);
```

### Custom assertion

At `com.jx.screenshot` directory create the `assertScreenshot.as` file with the following content:

```as3
package com.jx.screenshot
{
import flash.display.DisplayObject;
import org.flexunit.Assert;

public function assertScreenshot(fixtureName:String, component:DisplayObject, includeBounds:Boolean=false):void
{
Assert.assertTrue(Screenshot.compare(fixtureName, component, includeBounds));
}
}
```

So instead of `assertTrue(Screenshot.compare("SquareTest.defaultColor", component));` you'll write just `assertScreenshot("SquareTest.defaultColor", component)`.

### .gitignore

```
*-actual.png
*-diff.png
```