forked from vitali-fedulov/images4
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathimage_test.go
49 lines (45 loc) · 1.05 KB
/
image_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
package images4
import (
"image"
"path"
"reflect"
"testing"
)
const (
testDir1 = "testdata"
testDir2 = "resample"
)
func TestResizeByNearest(t *testing.T) {
testDir := path.Join(testDir1, testDir2)
tables := []struct {
inFile string
srcX, srcY int
outFile string
dstX, dstY int
}{
{"original.png", 533, 400,
"nearest100x100.png", 100, 100},
{"nearest100x100.png", 100, 100,
"nearest533x400.png", 533, 400},
}
for _, table := range tables {
inImg, err := Open(path.Join(testDir, table.inFile))
if err != nil {
t.Error("Cannot decode", path.Join(testDir, table.inFile))
}
outImg, err := Open(path.Join(testDir, table.outFile))
if err != nil {
t.Error("Cannot decode", path.Join(testDir, table.outFile))
}
resampled, srcSize := resizeByNearest(inImg,
image.Point{table.dstX, table.dstY})
if !reflect.DeepEqual(
outImg.(*image.RGBA), &resampled) ||
table.srcX != srcSize.X ||
table.srcY != srcSize.Y {
t.Errorf(
"Resample data do not match for %s and %s.",
table.inFile, table.outFile)
}
}
}