meyfa/phpunit-assert-gd

PHPUnit matcher/assertions for GD image resources

v2.0.0 2019-11-22 20:04 UTC

This package is auto-updated.

Last update: 2019-11-22 20:07:53 UTC


README

Build Status

Trying to assert images with PHPUnit? This project provides a constraint and the required assertions that allow you do to so.

It supports comparing files on disk as well as image resources in memory.

Compatibility note: The 2.x version of this library supports PHP versions of at least 7.2. It supports PHPUnit versions of at least 8.0. If you require support for older versions of PHPUnit and/or PHP, you will need to use version 1.x of this library.

Installation

Add this package to your Composer dev-dependencies:

composer require --dev meyfa/phpunit-assert-gd

Examples

The assertions are available as a trait, so you can easily use them in your test case class:

<?php
use AssertGD\GDAssertTrait;

class ExampleTest extends PHPUnit\Framework\TestCase
{
    // this trait adds the assert methods to your test case
    use GDAssertTrait;

    public function testSomething()
    {
        $this->assertSimilarGD('./tests/expected.png', './tests/actual.png');
    }
}

Plain comparisons

Use assertSimilarGD if you expect 2 images to be exactly equal. Use assertNotSimilarGD if you expect there to be differences.

$this->assertSimilarGD('./tests/img.png', './tests/same.png');
$this->assertNotSimilarGD('./tests/img.png', './tests/other.png');

Threshold values

Provide a number between 0 and 1 to set the error threshold. For example, a value of 0.2 would allow for at most 20% difference.

$this->assertSimilarGD('./tests/img.png', './tests/similar.png', '', 0.2);

Parameter types

Instead of file paths, you can pass in GD image resources. This eliminates having to write something to disk prior to the comparison.

$img = imagecreatetruecolor(10, 10);
$this->assertSimilarGD('./tests/empty-10x10.png', $img);
imagedestroy($img);

Manual constraint

If you need to configure mock objects or do other, more complex matching calls, use isSimilarGD to obtain a constraint object (similar to what would be returned by equalTo, isTrue, etc.).

$this->assertThat(
    './tests/actual.png',
    $this->isSimilarGD('./tests/expected.png')
);