253 lines
5 KiB
Go
253 lines
5 KiB
Go
package thumb
|
|
|
|
import (
|
|
"os"
|
|
"testing"
|
|
|
|
"github.com/photoprism/photoprism/pkg/fs"
|
|
"github.com/stretchr/testify/assert"
|
|
)
|
|
|
|
func TestJpeg(t *testing.T) {
|
|
formats := []string{"bmp", "gif", "png", "tif"}
|
|
|
|
for _, ext := range formats {
|
|
t.Run(ext, func(t *testing.T) {
|
|
src := "testdata/example." + ext
|
|
dst := "testdata/example." + ext + fs.JpegExt
|
|
|
|
assert.NoFileExists(t, dst)
|
|
|
|
img, err := Jpeg(src, dst, OrientationRotate270)
|
|
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
assert.FileExists(t, dst)
|
|
|
|
bounds := img.Bounds()
|
|
assert.Equal(t, 67, bounds.Max.X)
|
|
assert.Equal(t, 100, bounds.Max.Y)
|
|
|
|
if err := os.Remove(dst); err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
})
|
|
t.Run("OrientationFlipH", func(t *testing.T) {
|
|
src := "testdata/example." + ext
|
|
dst := "testdata/example." + ext + fs.JpegExt
|
|
|
|
assert.NoFileExists(t, dst)
|
|
|
|
img, err := Jpeg(src, dst, OrientationFlipH)
|
|
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
assert.FileExists(t, dst)
|
|
|
|
bounds := img.Bounds()
|
|
assert.Equal(t, 100, bounds.Max.X)
|
|
assert.Equal(t, 67, bounds.Max.Y)
|
|
|
|
if err := os.Remove(dst); err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
})
|
|
t.Run("OrientationFlipV", func(t *testing.T) {
|
|
src := "testdata/example." + ext
|
|
dst := "testdata/example." + ext + fs.JpegExt
|
|
|
|
assert.NoFileExists(t, dst)
|
|
|
|
img, err := Jpeg(src, dst, OrientationFlipV)
|
|
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
assert.FileExists(t, dst)
|
|
|
|
bounds := img.Bounds()
|
|
assert.Equal(t, 100, bounds.Max.X)
|
|
assert.Equal(t, 67, bounds.Max.Y)
|
|
|
|
if err := os.Remove(dst); err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
})
|
|
t.Run("OrientationRotate90", func(t *testing.T) {
|
|
src := "testdata/example." + ext
|
|
dst := "testdata/example." + ext + fs.JpegExt
|
|
|
|
assert.NoFileExists(t, dst)
|
|
|
|
img, err := Jpeg(src, dst, OrientationRotate90)
|
|
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
assert.FileExists(t, dst)
|
|
|
|
bounds := img.Bounds()
|
|
assert.Equal(t, 67, bounds.Max.X)
|
|
assert.Equal(t, 100, bounds.Max.Y)
|
|
|
|
if err := os.Remove(dst); err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
})
|
|
t.Run("OrientationRotate180", func(t *testing.T) {
|
|
src := "testdata/example." + ext
|
|
dst := "testdata/example." + ext + fs.JpegExt
|
|
|
|
assert.NoFileExists(t, dst)
|
|
|
|
img, err := Jpeg(src, dst, OrientationRotate180)
|
|
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
assert.FileExists(t, dst)
|
|
|
|
bounds := img.Bounds()
|
|
assert.Equal(t, 100, bounds.Max.X)
|
|
assert.Equal(t, 67, bounds.Max.Y)
|
|
|
|
if err := os.Remove(dst); err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
})
|
|
t.Run("OrientationTranspose", func(t *testing.T) {
|
|
src := "testdata/example." + ext
|
|
dst := "testdata/example." + ext + fs.JpegExt
|
|
|
|
assert.NoFileExists(t, dst)
|
|
|
|
img, err := Jpeg(src, dst, OrientationTranspose)
|
|
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
assert.FileExists(t, dst)
|
|
|
|
bounds := img.Bounds()
|
|
assert.Equal(t, 67, bounds.Max.X)
|
|
assert.Equal(t, 100, bounds.Max.Y)
|
|
|
|
if err := os.Remove(dst); err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
})
|
|
t.Run("OrientationTransverse", func(t *testing.T) {
|
|
src := "testdata/example." + ext
|
|
dst := "testdata/example." + ext + fs.JpegExt
|
|
|
|
assert.NoFileExists(t, dst)
|
|
|
|
img, err := Jpeg(src, dst, OrientationTransverse)
|
|
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
assert.FileExists(t, dst)
|
|
|
|
bounds := img.Bounds()
|
|
assert.Equal(t, 67, bounds.Max.X)
|
|
assert.Equal(t, 100, bounds.Max.Y)
|
|
|
|
if err := os.Remove(dst); err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
})
|
|
t.Run("OrientationUnspecified", func(t *testing.T) {
|
|
src := "testdata/example." + ext
|
|
dst := "testdata/example." + ext + fs.JpegExt
|
|
|
|
assert.NoFileExists(t, dst)
|
|
|
|
img, err := Jpeg(src, dst, OrientationUnspecified)
|
|
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
assert.FileExists(t, dst)
|
|
|
|
bounds := img.Bounds()
|
|
assert.Equal(t, 100, bounds.Max.X)
|
|
assert.Equal(t, 67, bounds.Max.Y)
|
|
|
|
if err := os.Remove(dst); err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
})
|
|
t.Run("OrientationNormal", func(t *testing.T) {
|
|
src := "testdata/example." + ext
|
|
dst := "testdata/example." + ext + fs.JpegExt
|
|
|
|
assert.NoFileExists(t, dst)
|
|
|
|
img, err := Jpeg(src, dst, OrientationNormal)
|
|
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
assert.FileExists(t, dst)
|
|
|
|
bounds := img.Bounds()
|
|
assert.Equal(t, 100, bounds.Max.X)
|
|
assert.Equal(t, 67, bounds.Max.Y)
|
|
|
|
if err := os.Remove(dst); err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
})
|
|
t.Run("invalid orientation", func(t *testing.T) {
|
|
src := "testdata/example." + ext
|
|
dst := "testdata/example." + ext + fs.JpegExt
|
|
|
|
assert.NoFileExists(t, dst)
|
|
|
|
img, err := Jpeg(src, dst, 500)
|
|
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
assert.FileExists(t, dst)
|
|
|
|
bounds := img.Bounds()
|
|
assert.Equal(t, 100, bounds.Max.X)
|
|
assert.Equal(t, 67, bounds.Max.Y)
|
|
|
|
if err := os.Remove(dst); err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
})
|
|
}
|
|
|
|
t.Run("foo", func(t *testing.T) {
|
|
src := "testdata/example.foo"
|
|
dst := "testdata/example.foo.jpg"
|
|
|
|
assert.NoFileExists(t, dst)
|
|
|
|
img, err := Jpeg(src, dst, OrientationFlipV)
|
|
|
|
assert.NoFileExists(t, dst)
|
|
|
|
if img != nil {
|
|
t.Fatal("img should be nil")
|
|
}
|
|
|
|
assert.Error(t, err)
|
|
})
|
|
}
|