photoprism/internal/form/search_photos_geo_test.go

141 lines
3.4 KiB
Go
Raw Normal View History

package form
import (
"testing"
"time"
"github.com/stretchr/testify/assert"
)
func TestGeoSearch(t *testing.T) {
t.Run("subjects", func(t *testing.T) {
form := &SearchPhotosGeo{Query: "subjects:\"Jens Mander\""}
err := form.ParseQueryString()
if err != nil {
t.Fatal(err)
}
assert.Equal(t, "Jens Mander", form.Subjects)
})
2021-09-20 12:36:59 +02:00
t.Run("aliases", func(t *testing.T) {
form := &SearchPhotosGeo{Query: "people:\"Jens & Mander\" folder:Foo person:Bar"}
2021-09-20 12:36:59 +02:00
err := form.ParseQueryString()
if err != nil {
t.Fatal(err)
}
assert.Equal(t, "", form.Folder)
assert.Equal(t, "", form.Person)
assert.Equal(t, "", form.People)
assert.Equal(t, "Foo", form.Path)
assert.Equal(t, "Bar", form.Subject)
assert.Equal(t, "Jens & Mander", form.Subjects)
})
t.Run("keywords", func(t *testing.T) {
form := &SearchPhotosGeo{Query: "keywords:\"Foo Bar\""}
err := form.ParseQueryString()
if err != nil {
t.Fatal(err)
}
assert.Equal(t, "Foo Bar", form.Keywords)
})
t.Run("valid query", func(t *testing.T) {
form := &SearchPhotosGeo{Query: "query:\"fooBar baz\" before:2019-01-15 dist:25000 lat:33.45343166666667"}
err := form.ParseQueryString()
if err != nil {
t.Fatal("err should be nil")
}
// log.Debugf("%+v\n", form)
assert.Equal(t, "fooBar baz", form.Query)
assert.Equal(t, time.Date(2019, 01, 15, 0, 0, 0, 0, time.UTC), form.Before)
assert.Equal(t, uint(0x61a8), form.Dist)
assert.Equal(t, float32(33.45343), form.Lat)
})
t.Run("valid query path empty folder not empty", func(t *testing.T) {
form := &SearchPhotosGeo{Query: "query:\"fooBar baz\" before:2019-01-15 dist:25000 lat:33.45343166666667 folder:test"}
err := form.ParseQueryString()
if err != nil {
t.Fatal("err should be nil")
}
// log.Debugf("%+v\n", form)
assert.Equal(t, "fooBar baz", form.Query)
assert.Equal(t, "test", form.Path)
2021-09-20 12:36:59 +02:00
assert.Equal(t, "", form.Folder)
assert.Equal(t, time.Date(2019, 01, 15, 0, 0, 0, 0, time.UTC), form.Before)
assert.Equal(t, uint(0x61a8), form.Dist)
assert.Equal(t, float32(33.45343), form.Lat)
})
t.Run("PortraitLandscapeSquare", func(t *testing.T) {
form := &SearchPhotosGeo{Query: "portrait:true landscape:yes square:jo"}
assert.False(t, form.Portrait)
assert.False(t, form.Landscape)
assert.False(t, form.Square)
assert.False(t, form.Panorama)
err := form.ParseQueryString()
if err != nil {
t.Fatal(err)
}
assert.True(t, form.Portrait)
assert.True(t, form.Landscape)
assert.True(t, form.Square)
assert.False(t, form.Panorama)
})
t.Run("AnimatedYes", func(t *testing.T) {
form := &SearchPhotosGeo{Query: "animated:yes"}
err := form.ParseQueryString()
if err != nil {
t.Fatal(err)
}
assert.False(t, form.Vector)
assert.True(t, form.Animated)
})
t.Run("VectorYes", func(t *testing.T) {
form := &SearchPhotosGeo{Query: "vector:yes"}
err := form.ParseQueryString()
if err != nil {
t.Fatal(err)
}
assert.False(t, form.Animated)
assert.True(t, form.Vector)
})
}
func TestGeoSearch_Serialize(t *testing.T) {
form := &SearchPhotosGeo{Query: "query:\"fooBar baz\"", Favorite: true}
assert.Equal(t, "q:\"query:fooBar baz\" favorite:true", form.Serialize())
}
func TestGeoSearch_SerializeAll(t *testing.T) {
form := &SearchPhotosGeo{Query: "query:\"fooBar baz\"", Favorite: true}
assert.Equal(t, "q:\"query:fooBar baz\" favorite:true", form.SerializeAll())
}
2020-05-06 17:05:06 +02:00
func TestNewGeoSearch(t *testing.T) {
r := NewGeoSearch("Berlin")
assert.IsType(t, SearchPhotosGeo{}, r)
2020-05-06 17:05:06 +02:00
}