d8e0364dbb
This needs to be very well tested and discussed, as these changes can lead to private photos being accidentally published. Thank you! Signed-off-by: Michael Mayer <michael@photoprism.app>
195 lines
4.6 KiB
Go
195 lines
4.6 KiB
Go
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)
|
|
})
|
|
t.Run("aliases", func(t *testing.T) {
|
|
form := &SearchPhotosGeo{Query: "people:\"Jens & Mander\" folder:Foo person:Bar"}
|
|
|
|
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: "q:\"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: "q:\"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)
|
|
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)
|
|
})
|
|
t.Run("query for favorites with uncommon bool value", func(t *testing.T) {
|
|
form := &SearchPhotosGeo{Query: "favorite:cat"}
|
|
|
|
err := form.ParseQueryString()
|
|
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
assert.True(t, form.Favorite)
|
|
})
|
|
t.Run("query for before with invalid type", func(t *testing.T) {
|
|
form := &SearchPhotosGeo{Query: "before:cat"}
|
|
|
|
err := form.ParseQueryString()
|
|
|
|
if err == nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
assert.Equal(t, "Could not find format for \"cat\"", err.Error())
|
|
})
|
|
t.Run("query for lat with invalid type", func(t *testing.T) {
|
|
form := &SearchPhotosGeo{Query: "lat:&cat"}
|
|
|
|
err := form.ParseQueryString()
|
|
|
|
if err == nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
assert.Contains(t, err.Error(), "invalid syntax")
|
|
})
|
|
t.Run("query for quality with invalid type", func(t *testing.T) {
|
|
form := &SearchPhotosGeo{Query: "quality:`cat"}
|
|
|
|
err := form.ParseQueryString()
|
|
|
|
if err == nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
assert.Contains(t, err.Error(), "invalid syntax")
|
|
})
|
|
t.Run("query for dist with invalid type", func(t *testing.T) {
|
|
form := &SearchPhotosGeo{Query: "dist:c@t"}
|
|
|
|
err := form.ParseQueryString()
|
|
|
|
if err == nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
assert.Contains(t, err.Error(), "invalid syntax")
|
|
})
|
|
}
|
|
|
|
func TestGeoSearch_Serialize(t *testing.T) {
|
|
form := &SearchPhotosGeo{Query: "q:\"fooBar baz\"", Favorite: true}
|
|
|
|
assert.Equal(t, "q:\"q:fooBar baz\" favorite:true", form.Serialize())
|
|
}
|
|
|
|
func TestGeoSearch_SerializeAll(t *testing.T) {
|
|
form := &SearchPhotosGeo{Query: "q:\"fooBar baz\"", Favorite: true}
|
|
|
|
assert.Equal(t, "q:\"q:fooBar baz\" favorite:true", form.SerializeAll())
|
|
}
|
|
|
|
func TestNewGeoSearch(t *testing.T) {
|
|
r := NewGeoSearch("Berlin")
|
|
assert.IsType(t, SearchPhotosGeo{}, r)
|
|
}
|