182 lines
7.1 KiB
Go
182 lines
7.1 KiB
Go
package crop
|
|
|
|
import (
|
|
"fmt"
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
)
|
|
|
|
func TestArea_String(t *testing.T) {
|
|
t.Run("3e814d0011f4", func(t *testing.T) {
|
|
expected := fmt.Sprintf("%x%x00%x%x", 1000, 333, 1, 500)
|
|
m := NewArea("face", 1.000, 0.33333, 0.001, 0.5)
|
|
assert.Equal(t, expected, m.String())
|
|
})
|
|
t.Run("3360a7064042_face", func(t *testing.T) {
|
|
m := NewArea("face", 0.822059, 0.167969, 0.1, 0.0664062)
|
|
assert.Equal(t, "3360a7064042", m.String())
|
|
})
|
|
t.Run("3360a7064042_back", func(t *testing.T) {
|
|
m := NewArea("back", 0.822059, 0.167969, 0.1, 0.0664062)
|
|
assert.Equal(t, "3360a7064042", m.String())
|
|
})
|
|
t.Run("0c93e801e000", func(t *testing.T) {
|
|
m := NewArea("face", 0.201, 1.000, 0.03, 0.00000001)
|
|
assert.Equal(t, "0c93e801e000", m.String())
|
|
})
|
|
t.Run("0003e8000000", func(t *testing.T) {
|
|
m := NewArea("face", 0.0001, 1.000, 0, 0.00000001)
|
|
assert.Equal(t, "0003e8000000", m.String())
|
|
})
|
|
t.Run("00007b0003e8", func(t *testing.T) {
|
|
m := NewArea("", -2.0001, 0.123, -0.1, 4.00000001)
|
|
assert.Equal(t, "00007b0003e8", m.String())
|
|
})
|
|
t.Run("00007b0003e8", func(t *testing.T) {
|
|
m := NewArea("", 0, 0, 0, 0)
|
|
assert.Equal(t, "", m.String())
|
|
})
|
|
}
|
|
|
|
func TestArea_Thumb(t *testing.T) {
|
|
t.Run("3e814d0011f4", func(t *testing.T) {
|
|
expected := fmt.Sprintf("346b3897eec9ef75e35fbf0bbc4c83c55ca41e31-%x%x00%x%x", 1000, 333, 1, 500)
|
|
m := NewArea("face", 1.000, 0.33333, 0.001, 0.5)
|
|
assert.Equal(t, expected, m.Thumb("346b3897eec9ef75e35fbf0bbc4c83c55ca41e31"))
|
|
})
|
|
t.Run("3360a7064042_face", func(t *testing.T) {
|
|
m := NewArea("face", 0.822059, 0.167969, 0.1, 0.0664062)
|
|
assert.Equal(t, "346b3897eec9ef75e35fbf0bbc4c83c55ca41e31-3360a7064042", m.Thumb("346b3897eec9ef75e35fbf0bbc4c83c55ca41e31"))
|
|
})
|
|
t.Run("3360a7064042_back", func(t *testing.T) {
|
|
m := NewArea("back", 0.822059, 0.167969, 0.1, 0.0664062)
|
|
assert.Equal(t, "346b3897eec9ef75e35fbf0bbc4c83c55ca41e31-3360a7064042", m.Thumb("346b3897eec9ef75e35fbf0bbc4c83c55ca41e31"))
|
|
})
|
|
t.Run("0c93e801e000", func(t *testing.T) {
|
|
m := NewArea("face", 0.201, 1.000, 0.03, 0.00000001)
|
|
assert.Equal(t, "346b3897eec9ef75e35fbf0bbc4c83c55ca41e31-0c93e801e000", m.Thumb("346b3897eec9ef75e35fbf0bbc4c83c55ca41e31"))
|
|
})
|
|
t.Run("0003e8000000", func(t *testing.T) {
|
|
m := NewArea("face", 0.0001, 1.000, 0, 0.00000001)
|
|
assert.Equal(t, "346b3897eec9ef75e35fbf0bbc4c83c55ca41e31-0003e8000000", m.Thumb("346b3897eec9ef75e35fbf0bbc4c83c55ca41e31"))
|
|
})
|
|
t.Run("ShortHash", func(t *testing.T) {
|
|
m := NewArea("", -2.0001, 0.123, -0.1, 4.00000001)
|
|
assert.Equal(t, "00007b0003e8", m.Thumb("346b3897eec9ef75e35fbf0bbc4c83c55ca41"))
|
|
})
|
|
t.Run("Empty", func(t *testing.T) {
|
|
m := NewArea("", 0, 0, 0, 0)
|
|
assert.Equal(t, "", m.Thumb("346b3897eec9ef75e35fbf0bbc4c83c55ca41"))
|
|
})
|
|
}
|
|
|
|
func TestAreaFromString(t *testing.T) {
|
|
t.Run("3e814d0011f4", func(t *testing.T) {
|
|
a := AreaFromString("3e814d0011f4")
|
|
assert.Equal(t, float32(1), a.X)
|
|
assert.Equal(t, float32(0.333), a.Y)
|
|
assert.Equal(t, float32(0.001), a.W)
|
|
assert.Equal(t, float32(0.5), a.H)
|
|
})
|
|
t.Run("3360a7064042", func(t *testing.T) {
|
|
a := AreaFromString("3360a7064042")
|
|
assert.Equal(t, NewArea("crop", 0.822, 0.167, 0.1, 0.066), a)
|
|
})
|
|
}
|
|
|
|
func TestIsCroppedThumb(t *testing.T) {
|
|
t.Run("True", func(t *testing.T) {
|
|
assert.Equal(t, 40, IsCroppedThumb("346b3897eec9ef75e35fbf0bbc4c83c55ca41e31-00007b0003e8"))
|
|
})
|
|
t.Run("Invalid", func(t *testing.T) {
|
|
assert.Equal(t, -1, IsCroppedThumb("346b3897eec9ef75e35fbf0bbc4c83c55ca41e3100007b0003e8-"))
|
|
})
|
|
t.Run("CropArea", func(t *testing.T) {
|
|
assert.Equal(t, -1, IsCroppedThumb("00007b0003e8"))
|
|
})
|
|
t.Run("ShortHash", func(t *testing.T) {
|
|
assert.Equal(t, -1, IsCroppedThumb("346b3897eec9ef75e35fbf0bbc4c83c55ca41"))
|
|
})
|
|
t.Run("HashOnly", func(t *testing.T) {
|
|
assert.Equal(t, -1, IsCroppedThumb("346b3897eec9ef75e35fbf0bbc4c83c55ca41e31"))
|
|
})
|
|
}
|
|
|
|
func TestParseThumb(t *testing.T) {
|
|
t.Run("True", func(t *testing.T) {
|
|
h, a := ParseThumb("346b3897eec9ef75e35fbf0bbc4c83c55ca41e31-00007b0003e8")
|
|
assert.Equal(t, 40, len(h))
|
|
assert.Equal(t, 12, len(a))
|
|
assert.False(t, AreaFromString(a).Empty())
|
|
})
|
|
t.Run("Invalid", func(t *testing.T) {
|
|
h, a := ParseThumb("346b3897eec9ef75e35fbf0bbc4c83c55ca41e3100007b0003e8-")
|
|
assert.Equal(t, "346b3897eec9ef75e35fbf0bbc4c83c55ca41e3100007b0003e8", h)
|
|
assert.Equal(t, 0, len(a))
|
|
assert.True(t, AreaFromString(a).Empty())
|
|
})
|
|
t.Run("CropArea", func(t *testing.T) {
|
|
h, a := ParseThumb("00007b0003e8")
|
|
assert.Equal(t, 0, len(h))
|
|
assert.Equal(t, 12, len(a))
|
|
assert.False(t, AreaFromString(a).Empty())
|
|
})
|
|
t.Run("ShortHash", func(t *testing.T) {
|
|
h, a := ParseThumb("346b3897eec9ef75e35fbf0bbc4c83c55ca41")
|
|
assert.Equal(t, 37, len(h))
|
|
assert.Equal(t, "346b3897eec9ef75e35fbf0bbc4c83c55ca41", h)
|
|
assert.Equal(t, 0, len(a))
|
|
assert.True(t, AreaFromString(a).Empty())
|
|
})
|
|
t.Run("HashOnly", func(t *testing.T) {
|
|
h, a := ParseThumb("346b3897eec9ef75e35fbf0bbc4c83c55ca41e31")
|
|
assert.Equal(t, 40, len(h))
|
|
assert.Equal(t, "346b3897eec9ef75e35fbf0bbc4c83c55ca41e31", h)
|
|
assert.Equal(t, 0, len(a))
|
|
assert.True(t, AreaFromString(a).Empty())
|
|
})
|
|
}
|
|
|
|
func TestArea_SurfaceRatio(t *testing.T) {
|
|
var a1 = Area{Name: "face", X: 0.308333, Y: 0.206944, W: 0.355556, H: 0.355556}
|
|
var a2 = Area{Name: "face", X: 0.208313, Y: 0.156914, W: 0.655556, H: 0.655556}
|
|
var a3 = Area{Name: "face", X: 0.998133, Y: 0.816944, W: 0.0001, H: 0.0001}
|
|
var a4 = Area{Name: "face", X: 0.298133, Y: 0.216944, W: 0.255556, H: 0.155556}
|
|
|
|
assert.Equal(t, 99, int(a1.SurfaceRatio(a1.OverlapArea(a1))*100))
|
|
assert.Equal(t, 99, int(a1.SurfaceRatio(a1.OverlapArea(a2))*100))
|
|
assert.Equal(t, 29, int(a2.SurfaceRatio(a2.OverlapArea(a1))*100))
|
|
assert.Equal(t, 0, int(a1.SurfaceRatio(a1.OverlapArea(a3))*100))
|
|
assert.Equal(t, 30, int(a1.SurfaceRatio(a1.OverlapArea(a4))*100))
|
|
assert.Equal(t, 0, int(a1.SurfaceRatio(a3.OverlapArea(a1))*100))
|
|
assert.Equal(t, 30, int(a1.SurfaceRatio(a4.OverlapArea(a1))*100))
|
|
}
|
|
|
|
func TestArea_OverlapArea(t *testing.T) {
|
|
var a1 = Area{Name: "face", X: 0.308333, Y: 0.206944, W: 0.355556, H: 0.355556}
|
|
var a2 = Area{Name: "face", X: 0.208313, Y: 0.156914, W: 0.655556, H: 0.655556}
|
|
var a3 = Area{Name: "face", X: 0.998133, Y: 0.816944, W: 0.0001, H: 0.0001}
|
|
var a4 = Area{Name: "face", X: 0.298133, Y: 0.216944, W: 0.255556, H: 0.155556}
|
|
|
|
assert.Equal(t, 0.1264200823986168, a1.OverlapArea(a1))
|
|
assert.Equal(t, int(a1.Surface()*10000), int(a1.OverlapArea(a1)*10000))
|
|
assert.Equal(t, 0.1264200823986168, a1.OverlapArea(a2))
|
|
assert.Equal(t, 0.1264200823986168, a2.OverlapArea(a1))
|
|
assert.Equal(t, 0.0, a1.OverlapArea(a3))
|
|
assert.Equal(t, 0.038166598943088825, a1.OverlapArea(a4))
|
|
}
|
|
|
|
func TestArea_OverlapPercent(t *testing.T) {
|
|
var a1 = Area{Name: "face", X: 0.308333, Y: 0.206944, W: 0.355556, H: 0.355556}
|
|
var a2 = Area{Name: "face", X: 0.208313, Y: 0.156914, W: 0.655556, H: 0.655556}
|
|
var a3 = Area{Name: "face", X: 0.998133, Y: 0.816944, W: 0.0001, H: 0.0001}
|
|
var a4 = Area{Name: "face", X: 0.298133, Y: 0.216944, W: 0.255556, H: 0.155556}
|
|
|
|
assert.Equal(t, 100, a1.OverlapPercent(a1))
|
|
assert.Equal(t, 29, a1.OverlapPercent(a2))
|
|
assert.Equal(t, 100, a2.OverlapPercent(a1))
|
|
assert.Equal(t, 0, a1.OverlapPercent(a3))
|
|
assert.Equal(t, 96, a1.OverlapPercent(a4))
|
|
}
|