/
OrientationTest.php
111 lines (92 loc) 路 3.64 KB
/
OrientationTest.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
<?php
use Jenssegers\ImageHash\ImageHash;
use Jenssegers\ImageHash\Implementations\AverageHash;
use Jenssegers\ImageHash\Implementations\DifferenceHash;
use Jenssegers\ImageHash\Implementations\PerceptualHash;
class OrientationTest extends PHPUnit_Framework_TestCase
{
protected $precision = 5;
public static function setUpBeforeClass()
{
if (extension_loaded('gmp')) {
echo "INFO: gmp extension loaded \n";
} else {
echo "INFO: gmp extension not loaded \n";
}
}
public function setUp()
{
$this->hashers = [
new AverageHash,
new DifferenceHash,
new PerceptualHash,
];
}
public function testEqualHashes()
{
foreach ($this->hashers as $hasher) {
$score = 0;
$imageHash = new ImageHash($hasher);
$imageHash->autorotate = true;
$imageHash->autoflip = true;
$images = glob('tests/images/orientation/match*');
// Disable test flipping images on versions of PHP that include the
// imageflip GD function. Which means we need to remove the flip
// test images as well so they don't fail.
if (!function_exists('imageflip')) {
$imageHash->autoflip = true;
$newImages = array();
foreach ($images as $image) {
if (preg_match('/-f0\.jpg$/', $image)) {
$newImages[] = $image;
}
}
$images = $newImages;
}
$hashes = [];
foreach ($images as $image) {
$hashes[$image] = $hash = $imageHash->hash($image);
echo "[" . get_class($hasher) . "] $image = $hash \n";
}
foreach ($hashes as $image => $hash) {
foreach ($hashes as $target => $compare) {
if ($target == $image) {
continue;
}
$distance = $imageHash->distance($hash, $compare);
$this->assertLessThan($this->precision, $distance, "[" . get_class($hasher) . "] $image ($hash) ^ $target ($compare)");
$score += $distance;
echo "[" . get_class($hasher) . "] $image ^ $target = $distance \n";
}
}
echo "[" . get_class($hasher) . "] Total score: $score \n";
}
}
public function testDifferentHashes()
{
foreach ($this->hashers as $hasher) {
$score = 0;
$imageHash = new ImageHash($hasher);
$imageHash->autorotate = true;
$imageHash->autoflip = true;
$images = glob('tests/images/orientation/mismatch*');
$hashes = [];
foreach ($images as $image) {
$hashes[$image] = $hash = $imageHash->hash($image);
echo "[" . get_class($hasher) . "] $image = $hash \n";
}
foreach ($hashes as $image => $hash) {
foreach ($hashes as $target => $compare) {
if ($target == $image) {
continue;
}
$distance = $imageHash->distance($hash, $compare);
$this->assertGreaterThan($this->precision, $distance, "[" . get_class($hasher) . "] $image ($hash) ^ $target ($compare)");
$score += $distance;
echo "[" . get_class($hasher) . "] $image ^ $target = $distance \n";
}
}
echo "[" . get_class($hasher) . "] Total score: $score \n";
}
}
}