photoprism/pkg/s2/s2_test.go
Michael Mayer 4d1003846c Search: Refactor "lat", "lng", and "dist" filters #1187 #3558
Signed-off-by: Michael Mayer <michael@photoprism.app>
2023-09-20 16:56:38 +02:00

194 lines
4.8 KiB
Go

package s2
import (
"strings"
"testing"
"github.com/stretchr/testify/assert"
)
func TestToken(t *testing.T) {
t.Run("germany", func(t *testing.T) {
token := Token(48.56344833333333, 8.996878333333333)
expected := "4799e370"
assert.True(t, strings.HasPrefix(token, expected))
})
t.Run("lat_overflow", func(t *testing.T) {
token := Token(548.56344833333333, 8.996878333333333)
expected := ""
assert.Equal(t, expected, token)
})
t.Run("lng_overflow", func(t *testing.T) {
token := Token(48.56344833333333, 258.996878333333333)
expected := ""
assert.Equal(t, expected, token)
})
}
func TestTokenLevel(t *testing.T) {
t.Run("level_30", func(t *testing.T) {
token := TokenLevel(48.56344833333333, 8.996878333333333, 30)
expected := "4799e370ca54c8b9"
assert.Equal(t, expected, token)
})
t.Run("level_30_diff", func(t *testing.T) {
plusCode := TokenLevel(48.56344839999999, 8.996878339999999, 30)
expected := "4799e370ca54c8b7"
assert.Equal(t, expected, plusCode)
})
t.Run("level_21", func(t *testing.T) {
plusCode := TokenLevel(48.56344839999999, 8.996878339999999, 21)
expected := "4799e370ca54"
assert.Equal(t, expected, plusCode)
})
t.Run("level_18", func(t *testing.T) {
token := TokenLevel(48.56344833333333, 8.996878333333333, 18)
expected := "4799e370cb"
assert.Equal(t, expected, token)
})
t.Run("level_18_diff", func(t *testing.T) {
token := TokenLevel(48.56344839999999, 8.996878339999999, 18)
expected := "4799e370cb"
assert.Equal(t, expected, token)
})
t.Run("level_15", func(t *testing.T) {
plusCode := TokenLevel(48.56344833333333, 8.996878333333333, 15)
expected := "4799e370c"
assert.Equal(t, expected, plusCode)
})
t.Run("level_10", func(t *testing.T) {
token := TokenLevel(48.56344833333333, 8.996878333333333, 10)
expected := "4799e3"
assert.Equal(t, expected, token)
})
t.Run("lat_overflow", func(t *testing.T) {
token := TokenLevel(548.56344833333333, 8.996878333333333, 30)
expected := ""
assert.Equal(t, expected, token)
})
t.Run("lng_overflow", func(t *testing.T) {
token := TokenLevel(48.56344833333333, 258.996878333333333, 30)
expected := ""
assert.Equal(t, expected, token)
})
t.Run("lat & long 0.0", func(t *testing.T) {
token := TokenLevel(0.0, 0.0, 30)
expected := ""
assert.Equal(t, expected, token)
})
}
func TestLevel(t *testing.T) {
t.Run("8000", func(t *testing.T) {
assert.Equal(t, 0, Level(8000))
})
t.Run("150", func(t *testing.T) {
assert.Equal(t, 6, Level(150))
})
t.Run("0", func(t *testing.T) {
assert.Equal(t, 14, Level(0))
})
}
func TestLatLng(t *testing.T) {
t.Run("Valid", func(t *testing.T) {
lat, lng := LatLng("4799e370ca54c8b9")
assert.Equal(t, 48.56344835921243, lat)
assert.Equal(t, 8.996878323369781, lng)
})
t.Run("Invalid", func(t *testing.T) {
lat, lng := LatLng("4799e370ca5q")
assert.Equal(t, 0.0, lat)
assert.Equal(t, 0.0, lng)
})
t.Run("Empty", func(t *testing.T) {
lat, lng := LatLng("")
assert.Equal(t, 0.0, lat)
assert.Equal(t, 0.0, lng)
})
}
func TestIsZero(t *testing.T) {
t.Run("Valid", func(t *testing.T) {
lat, lng := LatLng("4799e370ca54c8b9")
assert.False(t, IsZero(lat, lng))
})
t.Run("Invalid", func(t *testing.T) {
lat, lng := LatLng("4799e370ca5q")
assert.True(t, IsZero(lat, lng))
})
}
func TestRange(t *testing.T) {
t.Run("Level1", func(t *testing.T) {
start, end := Range("4799e370ca54c8b9", 1)
assert.Equal(t, "3800000000000001", start)
assert.Equal(t, "4800000000000001", end)
})
t.Run("Level2", func(t *testing.T) {
start, end := Range("4799e370ca54c8b9", 2)
assert.Equal(t, "4400000000000001", start)
assert.Equal(t, "4800000000000001", end)
})
t.Run("Level5", func(t *testing.T) {
start, end := Range("4799e370ca54c8b9", 5)
assert.Equal(t, "4790000000000001", start)
assert.Equal(t, "47a0000000000001", end)
})
t.Run("Level7", func(t *testing.T) {
start, end := Range("4799e370ca54c8b9", 7)
assert.Equal(t, "4799000000000001", start)
assert.Equal(t, "479a000000000001", end)
})
t.Run("Level10", func(t *testing.T) {
start, end := Range("4799e370ca54c8b9", 10)
assert.Equal(t, "4799e00000000001", start)
assert.Equal(t, "4799e40000000001", end)
})
t.Run("Level14", func(t *testing.T) {
start, end := Range("4799e370ca54c8b9", 14)
assert.Equal(t, "4799e36e00000001", start)
assert.Equal(t, "4799e37200000001", end)
})
t.Run("Level21", func(t *testing.T) {
start, end := Range("4799e370ca54c8b9", 21)
assert.Equal(t, "4799e370ca480001", start)
assert.Equal(t, "4799e370ca580001", end)
})
t.Run("Level23", func(t *testing.T) {
start, end := Range("4799e370ca54c8b9", 23)
assert.Equal(t, "4799e370ca540001", start)
assert.Equal(t, "4799e370ca550001", end)
})
t.Run("Invalid", func(t *testing.T) {
start, end := Range("4799e370ca5q", 1)
assert.Equal(t, "", start)
assert.Equal(t, "", end)
})
}