Files
2026-02-04 20:27:13 +08:00

179 lines
5.0 KiB
Go

/*
* GO interface to libheif
* Copyright (c) 2018 struktur AG, Joachim Bauch <bauch@struktur.de>
*
* This file is part of heif, an example application using libheif.
*
* libheif is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as
* published by the Free Software Foundation, either version 3 of
* the License, or (at your option) any later version.
*
* libheif is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with libheif. If not, see <http://www.gnu.org/licenses/>.
*/
package _libheif
import (
"fmt"
"image"
"io/ioutil"
"os"
"path"
"testing"
)
func TestGetVersion(t *testing.T) {
version := GetVersion()
if version == "" {
t.Fatal("Version is missing")
}
}
type decodeTest struct {
colorspace Colorspace
chroma Chroma
}
func CheckHeifImage(t *testing.T, handle *ImageHandle, thumbnail bool) {
handle.GetWidth()
handle.GetHeight()
handle.HasAlphaChannel()
handle.HasDepthImage()
count := handle.GetNumberOfDepthImages()
if ids := handle.GetListOfDepthImageIDs(); len(ids) != count {
t.Errorf("Expected %d depth image ids, got %d", count, len(ids))
}
if !thumbnail {
count = handle.GetNumberOfThumbnails()
ids := handle.GetListOfThumbnailIDs()
if len(ids) != count {
t.Errorf("Expected %d thumbnail image ids, got %d", count, len(ids))
}
for _, id := range ids {
if thumb, err := handle.GetThumbnail(id); err != nil {
t.Errorf("Could not get thumbnail %d: %s", id, err)
} else {
CheckHeifImage(t, thumb, true)
}
}
}
decodeTests := []decodeTest{
decodeTest{ColorspaceUndefined, ChromaUndefined},
decodeTest{ColorspaceYCbCr, Chroma420},
decodeTest{ColorspaceYCbCr, Chroma422},
decodeTest{ColorspaceYCbCr, Chroma444},
decodeTest{ColorspaceRGB, Chroma444},
decodeTest{ColorspaceRGB, ChromaInterleavedRGB},
decodeTest{ColorspaceRGB, ChromaInterleavedRGBA},
decodeTest{ColorspaceRGB, ChromaInterleavedRRGGBB_BE},
decodeTest{ColorspaceRGB, ChromaInterleavedRRGGBBAA_BE},
}
for _, test := range decodeTests {
if img, err := handle.DecodeImage(test.colorspace, test.chroma, nil); err != nil {
t.Errorf("Could not decode image with %v / %v: %s", test.colorspace, test.chroma, err)
} else {
img.GetColorspace()
img.GetChromaFormat()
if _, err := img.GetImage(); err != nil {
t.Errorf("Could not get image with %v /%v: %s", test.colorspace, test.chroma, err)
continue
}
}
}
}
func CheckHeifFile(t *testing.T, ctx *Context) {
if count := ctx.GetNumberOfTopLevelImages(); count != 2 {
t.Errorf("Expected %d top level images, got %d", 2, count)
}
if ids := ctx.GetListOfTopLevelImageIDs(); len(ids) != 2 {
t.Errorf("Expected %d top level image ids, got %+v", 2, ids)
}
if _, err := ctx.GetPrimaryImageID(); err != nil {
t.Errorf("Expected a primary image, got %s", err)
}
if handle, err := ctx.GetPrimaryImageHandle(); err != nil {
t.Errorf("Could not get primary image handle: %s", err)
} else {
if !handle.IsPrimaryImage() {
t.Error("Expected primary image")
}
CheckHeifImage(t, handle, false)
}
}
func TestReadFromFile(t *testing.T) {
ctx, err := NewContext()
if err != nil {
t.Fatalf("Can't create context: %s", err)
}
filename := path.Join("..", "..", "examples", "example.heic")
if err := ctx.ReadFromFile(filename); err != nil {
t.Fatalf("Can't read from %s: %s", filename, err)
}
CheckHeifFile(t, ctx)
}
func TestReadFromMemory(t *testing.T) {
ctx, err := NewContext()
if err != nil {
t.Fatalf("Can't create context: %s", err)
}
filename := path.Join("..", "..", "examples", "example.heic")
data, err := ioutil.ReadFile(filename)
if err != nil {
t.Fatalf("Can't read file %s: %s", filename, err)
}
if err := ctx.ReadFromMemory(data); err != nil {
t.Fatalf("Can't read from memory: %s", err)
}
data = nil // Make sure future processing works if "data" is GC'd
CheckHeifFile(t, ctx)
}
func TestReadImage(t *testing.T) {
filename := path.Join("..", "..", "examples", "example.heic")
fp, err := os.Open(filename)
if err != nil {
t.Fatalf("Could not open %s: %s", filename, err)
}
defer fp.Close()
config, format1, err := image.DecodeConfig(fp)
if err != nil {
t.Fatalf("Could not load image config from %s: %s", filename, err)
}
if format1 != "heif" {
t.Errorf("Expected format heif, got %s", format1)
}
if _, err := fp.Seek(0, 0); err != nil {
t.Fatalf("Could not seek to start of %s: %s", filename, err)
}
img, format2, err := image.Decode(fp)
if err != nil {
t.Fatalf("Could not load image from %s: %s", filename, err)
}
if format2 != "heif" {
t.Errorf("Expected format heif, got %s", format2)
}
r := img.Bounds()
if config.Width != (r.Max.X-r.Min.X) || config.Height != (r.Max.Y-r.Min.Y) {
fmt.Printf("Image size %+v does not match config %+v\n", r, config)
}
}