-
Notifications
You must be signed in to change notification settings - Fork 92
/
reader_test.go
71 lines (62 loc) · 1.41 KB
/
reader_test.go
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
// Copyright 2014 <chaishushan{AT}gmail.com>. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
package webp
import (
"image"
_ "image/png"
"os"
"testing"
)
const testdataDir = "./testdata/"
func loadImage(filename string) (m image.Image, err error) {
f, err := os.Open(testdataDir + filename)
if err != nil {
return
}
defer f.Close()
m, _, err = image.Decode(f)
return
}
func TestDecode(t *testing.T) {
img0, err := loadImage("video-001.png")
if err != nil {
t.Fatal(err)
}
img1, err := loadImage("video-001.webp")
if err != nil {
t.Fatal(err)
}
// Compare the average delta to the tolerance level.
want := 15
if got := averageDelta(img0, img1); got > want {
t.Fatalf("average delta too high; got %d, want <= %d", got, want)
}
}
// averageDelta returns the average delta in RGB space. The two images must
// have the same bounds.
func averageDelta(m0, m1 image.Image) int {
b := m0.Bounds()
var sum, n int64
for y := b.Min.Y; y < b.Max.Y; y++ {
for x := b.Min.X; x < b.Max.X; x++ {
c0 := m0.At(x, y)
c1 := m1.At(x, y)
r0, g0, b0, a0 := c0.RGBA()
r1, g1, b1, a1 := c1.RGBA()
sum += delta(r0, r1)
sum += delta(g0, g1)
sum += delta(b0, b1)
sum += delta(a0, a1)
n += 4
}
}
return int((sum / n) >> 8)
}
func delta(u0, u1 uint32) int64 {
d := int64(u0) - int64(u1)
if d < 0 {
return -d
}
return d
}