forked from lukeroth/gdal
-
Notifications
You must be signed in to change notification settings - Fork 0
/
gdal_test.go
93 lines (81 loc) · 2.26 KB
/
gdal_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
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
// Copyright 2011 go-gdal. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
package gdal
import (
"image/png"
"os"
"testing"
"github.com/stretchr/testify/assert"
)
func TestTiffDriver(t *testing.T) {
_, err := GetDriverByName("GTiff")
if err != nil {
t.Errorf(err.Error())
}
}
func TestMissingMetadata(t *testing.T) {
ds, err := Open("testdata/tiles.gpkg", ReadOnly)
if err != nil {
t.Fatalf("failed to open test file: %v", err)
}
metadata := ds.Metadata("something-that-wont-exist")
if len(metadata) != 0 {
t.Errorf("got %d items, want 0", len(metadata))
}
}
func TestRegenerateOverviews(t *testing.T) {
memDrv, err := GetDriverByName("MEM")
if err != nil {
t.Errorf(err.Error())
}
// 4x4 pixel size
ds, err := Open("testdata/smallgeo.tif", ReadOnly)
if err != nil {
t.Fatalf("failed to open test file: %v", err)
}
redband := ds.RasterBand(1)
// create 1x1 pixelled tiff which would store overview of redband
dstile := memDrv.Create("", 1, 1, 3, Byte, nil)
redbandDsTile := dstile.RasterBand(1)
greenbandDsTile := dstile.RasterBand(2)
blueBandDsTile := dstile.RasterBand(3)
bands := []RasterBand{
redbandDsTile,
greenbandDsTile,
blueBandDsTile,
}
err = redband.RegenerateOverviews(3, &bands[0], "average", DummyProgress, nil)
if err != nil {
t.Errorf(err.Error())
}
// generate PNG
outDrv, err := GetDriverByName("PNG")
if err != nil {
panic(err)
}
outDrv.CreateCopy("testdata/temp.png", dstile, 0, nil, nil, nil)
imgFile, err := os.Open("testdata/temp.png")
if err != nil {
t.Errorf(err.Error())
}
imgData, err := png.Decode(imgFile)
if err != nil {
t.Errorf(err.Error())
}
// assert that png is of 1x1 pixel
assert.Equal(t, imgData.Bounds().Min.X, 0)
assert.Equal(t, imgData.Bounds().Min.Y, 0)
assert.Equal(t, imgData.Bounds().Max.X, 1)
assert.Equal(t, imgData.Bounds().Max.Y, 1)
// assert that image contains values RGB(32896, 32896, 32896)
// 32896 is the computed average of r, g, b values from smallgeo.tif
r, g, b, _ := imgData.At(0, 0).RGBA()
assert.Equal(t, int(r), 32896)
assert.Equal(t, int(g), 32896)
assert.Equal(t, int(b), 32896)
// remove temp.png
if err := os.Remove("testdata/temp.png"); err != nil {
t.Errorf(err.Error())
}
}