mirror of
https://github.com/photoprism/photoprism.git
synced 2025-12-12 00:34:13 +01:00
87 lines
1.9 KiB
Go
87 lines
1.9 KiB
Go
package thumb
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/disintegration/imaging"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
)
|
|
|
|
func TestFit(t *testing.T) {
|
|
assert.Equal(t, Sizes[Fit720], Fit(54, 453))
|
|
assert.Equal(t, Sizes[Fit1280], Fit(1000, 1000))
|
|
assert.Equal(t, Sizes[Fit1280], Fit(1250, 1000))
|
|
assert.Equal(t, Sizes[Fit1920], Fit(1300, 1200))
|
|
assert.Equal(t, Sizes[Fit2560], Fit(1300, 1300))
|
|
assert.Equal(t, Sizes[Fit2560], Fit(1600, 1600))
|
|
assert.Equal(t, Sizes[Fit4096], Fit(1000, 3000))
|
|
assert.Equal(t, Sizes[Fit4096], Fit(2300, 2000))
|
|
assert.Equal(t, Sizes[Fit5120], Fit(5000, 2000))
|
|
assert.Equal(t, Sizes[Fit7680], Fit(6020, 2000))
|
|
assert.Equal(t, Sizes[Fit7680], Fit(8000, 8000))
|
|
}
|
|
|
|
func TestFitBounds(t *testing.T) {
|
|
t.Run("ExampleJpg", func(t *testing.T) {
|
|
src := "testdata/example.jpg"
|
|
|
|
assert.FileExists(t, src)
|
|
|
|
img, err := imaging.Open(src, imaging.AutoOrientation(true))
|
|
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
bounds := img.Bounds()
|
|
|
|
assert.Equal(t, 750, bounds.Max.X)
|
|
assert.Equal(t, 500, bounds.Max.Y)
|
|
|
|
size := FitBounds(img.Bounds())
|
|
|
|
assert.Equal(t, "fit_1280", size.Name.String())
|
|
})
|
|
t.Run("ExampleBmp", func(t *testing.T) {
|
|
src := "testdata/example.bmp"
|
|
|
|
assert.FileExists(t, src)
|
|
|
|
img, err := imaging.Open(src, imaging.AutoOrientation(true))
|
|
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
bounds := img.Bounds()
|
|
|
|
assert.Equal(t, 100, bounds.Max.X)
|
|
assert.Equal(t, 67, bounds.Max.Y)
|
|
|
|
size := FitBounds(img.Bounds())
|
|
|
|
assert.Equal(t, "fit_720", size.Name.String())
|
|
})
|
|
t.Run("AnimatedEarthJpg", func(t *testing.T) {
|
|
src := "testdata/animated-earth.jpg"
|
|
|
|
assert.FileExists(t, src)
|
|
|
|
img, err := imaging.Open(src, imaging.AutoOrientation(true))
|
|
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
bounds := img.Bounds()
|
|
|
|
assert.Equal(t, 300, bounds.Max.X)
|
|
assert.Equal(t, 300, bounds.Max.Y)
|
|
|
|
size := FitBounds(img.Bounds())
|
|
|
|
assert.Equal(t, "fit_720", size.Name.String())
|
|
})
|
|
}
|