2020-01-26 20:34:25 +01:00
|
|
|
|
defmodule Mobilizon.GraphQL.Resolvers.SearchTest do
|
2020-01-26 21:36:50 +01:00
|
|
|
|
use Mobilizon.Web.ConnCase
|
2020-01-23 00:55:07 +01:00
|
|
|
|
|
2019-02-21 18:11:49 +01:00
|
|
|
|
import Mobilizon.Factory
|
2020-01-23 00:55:07 +01:00
|
|
|
|
|
|
|
|
|
alias Mobilizon.Service.Workers
|
2020-01-26 20:34:25 +01:00
|
|
|
|
|
|
|
|
|
alias Mobilizon.GraphQL.AbsintheHelpers
|
2019-02-21 18:11:49 +01:00
|
|
|
|
|
|
|
|
|
setup %{conn: conn} do
|
|
|
|
|
user = insert(:user)
|
|
|
|
|
|
|
|
|
|
{:ok, conn: conn, user: user}
|
|
|
|
|
end
|
|
|
|
|
|
2020-07-31 17:52:26 +02:00
|
|
|
|
describe "search events/3" do
|
|
|
|
|
@search_events_query """
|
2020-08-05 11:42:23 +02:00
|
|
|
|
query SearchEvents($location: String, $radius: Float, $tags: String, $term: String, $beginsOn: DateTime, $endsOn: DateTime) {
|
|
|
|
|
searchEvents(location: $location, radius: $radius, tags: $tags, term: $term, beginsOn: $beginsOn, endsOn: $endsOn) {
|
2020-07-31 17:52:26 +02:00
|
|
|
|
total,
|
|
|
|
|
elements {
|
|
|
|
|
id
|
|
|
|
|
title,
|
|
|
|
|
uuid,
|
|
|
|
|
__typename
|
2019-04-12 15:04:32 +02:00
|
|
|
|
}
|
2020-07-31 17:52:26 +02:00
|
|
|
|
}
|
2019-04-12 15:04:32 +02:00
|
|
|
|
}
|
|
|
|
|
"""
|
|
|
|
|
|
2020-07-31 17:52:26 +02:00
|
|
|
|
test "finds events with basic search", %{
|
|
|
|
|
conn: conn,
|
|
|
|
|
user: user
|
|
|
|
|
} do
|
|
|
|
|
insert(:actor, user: user, preferred_username: "test_person")
|
|
|
|
|
insert(:actor, type: :Group, preferred_username: "test_group")
|
|
|
|
|
event = insert(:event, title: "test_event")
|
|
|
|
|
Workers.BuildSearch.insert_search_event(event)
|
|
|
|
|
|
|
|
|
|
res =
|
|
|
|
|
AbsintheHelpers.graphql_query(conn,
|
|
|
|
|
query: @search_events_query,
|
|
|
|
|
variables: %{term: "test"}
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
assert res["errors"] == nil
|
|
|
|
|
assert res["data"]["searchEvents"]["total"] == 1
|
|
|
|
|
assert res["data"]["searchEvents"]["elements"] |> length == 1
|
|
|
|
|
|
|
|
|
|
assert hd(res["data"]["searchEvents"]["elements"])["uuid"] ==
|
|
|
|
|
to_string(event.uuid)
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
test "finds events and actors with word search", %{
|
|
|
|
|
conn: conn,
|
|
|
|
|
user: user
|
|
|
|
|
} do
|
|
|
|
|
insert(:actor, user: user, preferred_username: "person", name: "I like pineapples")
|
|
|
|
|
event1 = insert(:event, title: "Pineapple fashion week")
|
|
|
|
|
event2 = insert(:event, title: "I love pineAPPLE")
|
|
|
|
|
event3 = insert(:event, title: "Hello")
|
|
|
|
|
Workers.BuildSearch.insert_search_event(event1)
|
|
|
|
|
Workers.BuildSearch.insert_search_event(event2)
|
|
|
|
|
Workers.BuildSearch.insert_search_event(event3)
|
|
|
|
|
|
|
|
|
|
res =
|
|
|
|
|
AbsintheHelpers.graphql_query(conn,
|
|
|
|
|
query: @search_events_query,
|
|
|
|
|
variables: %{term: "pineapple"}
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
assert res["errors"] == nil
|
|
|
|
|
assert res["data"]["searchEvents"]["total"] == 2
|
|
|
|
|
|
|
|
|
|
assert res["data"]["searchEvents"]["elements"]
|
|
|
|
|
|> length == 2
|
|
|
|
|
|
|
|
|
|
assert res["data"]["searchEvents"]["elements"]
|
|
|
|
|
|> Enum.map(& &1["title"]) == [
|
|
|
|
|
"Pineapple fashion week",
|
|
|
|
|
"I love pineAPPLE"
|
|
|
|
|
]
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
test "finds events with accented search", %{
|
|
|
|
|
conn: conn,
|
|
|
|
|
user: user
|
|
|
|
|
} do
|
|
|
|
|
insert(:actor, user: user, preferred_username: "person", name: "Torréfaction du Kafé")
|
|
|
|
|
insert(:actor, type: :Group, preferred_username: "group", name: "Kafé group")
|
|
|
|
|
event = insert(:event, title: "Tour du monde des Kafés")
|
|
|
|
|
Workers.BuildSearch.insert_search_event(event)
|
|
|
|
|
|
|
|
|
|
res =
|
|
|
|
|
AbsintheHelpers.graphql_query(conn,
|
|
|
|
|
query: @search_events_query,
|
|
|
|
|
variables: %{term: "Kafés"}
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
assert res["errors"] == nil
|
|
|
|
|
assert res["data"]["searchEvents"]["total"] == 1
|
|
|
|
|
|
|
|
|
|
assert hd(res["data"]["searchEvents"]["elements"])["uuid"] ==
|
|
|
|
|
event.uuid
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
test "finds events by tag", %{conn: conn} do
|
|
|
|
|
tag = insert(:tag, title: "Café")
|
|
|
|
|
tag2 = insert(:tag, title: "Thé")
|
|
|
|
|
event = insert(:event, title: "Tour du monde", tags: [tag, tag2])
|
2020-08-03 17:34:50 +02:00
|
|
|
|
insert(:event, title: "Autre événement")
|
2020-07-31 17:52:26 +02:00
|
|
|
|
Workers.BuildSearch.insert_search_event(event)
|
|
|
|
|
|
|
|
|
|
res =
|
|
|
|
|
AbsintheHelpers.graphql_query(conn,
|
|
|
|
|
query: @search_events_query,
|
2020-08-03 17:34:50 +02:00
|
|
|
|
variables: %{tags: "Café,Sirop"}
|
2020-07-31 17:52:26 +02:00
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
assert res["errors"] == nil
|
|
|
|
|
assert res["data"]["searchEvents"]["total"] == 1
|
|
|
|
|
|
|
|
|
|
assert hd(res["data"]["searchEvents"]["elements"])["uuid"] ==
|
|
|
|
|
event.uuid
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
test "finds events by location", %{conn: conn} do
|
|
|
|
|
{lon, lat} = {45.75, 4.85}
|
|
|
|
|
point = %Geo.Point{coordinates: {lon, lat}, srid: 4326}
|
|
|
|
|
geohash = Geohax.encode(lon, lat, 6)
|
|
|
|
|
address = insert(:address, geom: point)
|
|
|
|
|
event = insert(:event, title: "Tour du monde", physical_address: address)
|
|
|
|
|
Workers.BuildSearch.insert_search_event(event)
|
|
|
|
|
|
|
|
|
|
res =
|
|
|
|
|
AbsintheHelpers.graphql_query(conn,
|
|
|
|
|
query: @search_events_query,
|
|
|
|
|
variables: %{location: geohash}
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
assert res["errors"] == nil
|
|
|
|
|
assert res["data"]["searchEvents"]["total"] == 1
|
|
|
|
|
|
|
|
|
|
assert hd(res["data"]["searchEvents"]["elements"])["uuid"] ==
|
|
|
|
|
event.uuid
|
|
|
|
|
end
|
|
|
|
|
|
2020-08-05 11:42:23 +02:00
|
|
|
|
test "finds events by begins_on and ends_on", %{conn: conn} do
|
|
|
|
|
now = DateTime.utc_now()
|
|
|
|
|
|
|
|
|
|
# TODO
|
|
|
|
|
event =
|
|
|
|
|
insert(:event,
|
|
|
|
|
title: "Tour du monde",
|
|
|
|
|
begins_on: DateTime.add(now, 3600 * 24 * 3),
|
|
|
|
|
ends_on: DateTime.add(now, 3600 * 24 * 10)
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
insert(:event,
|
|
|
|
|
title: "Autre événement",
|
|
|
|
|
begins_on: DateTime.add(now, 3600 * 24 * 30),
|
|
|
|
|
ends_on: nil
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
Workers.BuildSearch.insert_search_event(event)
|
|
|
|
|
|
|
|
|
|
res =
|
|
|
|
|
AbsintheHelpers.graphql_query(conn,
|
|
|
|
|
query: @search_events_query,
|
|
|
|
|
variables: %{
|
|
|
|
|
beginsOn: now |> DateTime.add(86_400) |> DateTime.to_iso8601(),
|
|
|
|
|
endsOn: now |> DateTime.add(1_728_000) |> DateTime.to_iso8601()
|
|
|
|
|
}
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
assert res["errors"] == nil
|
|
|
|
|
assert res["data"]["searchEvents"]["total"] == 1
|
|
|
|
|
|
|
|
|
|
assert hd(res["data"]["searchEvents"]["elements"])["uuid"] ==
|
|
|
|
|
event.uuid
|
|
|
|
|
end
|
|
|
|
|
|
2020-07-31 17:52:26 +02:00
|
|
|
|
test "finds events with multiple criteria", %{conn: conn} do
|
|
|
|
|
{lon, lat} = {45.75, 4.85}
|
|
|
|
|
point = %Geo.Point{coordinates: {lon, lat}, srid: 4326}
|
|
|
|
|
geohash = Geohax.encode(lon, lat, 6)
|
|
|
|
|
address = insert(:address, geom: point)
|
|
|
|
|
tag = insert(:tag, title: "Café")
|
|
|
|
|
tag2 = insert(:tag, title: "Thé")
|
|
|
|
|
event = insert(:event, title: "Tour du monde", physical_address: address, tags: [tag, tag2])
|
|
|
|
|
insert(:event, title: "Autre événement avec même tags", tags: [tag, tag2])
|
|
|
|
|
insert(:event, title: "Même endroit", physical_address: address)
|
|
|
|
|
insert(:event, title: "Même monde")
|
|
|
|
|
Workers.BuildSearch.insert_search_event(event)
|
|
|
|
|
|
|
|
|
|
res =
|
|
|
|
|
AbsintheHelpers.graphql_query(conn,
|
|
|
|
|
query: @search_events_query,
|
2020-08-03 17:34:50 +02:00
|
|
|
|
variables: %{location: geohash, radius: 10, tags: "Thé", term: "Monde"}
|
2020-07-31 17:52:26 +02:00
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
assert res["errors"] == nil
|
|
|
|
|
assert res["data"]["searchEvents"]["total"] == 1
|
|
|
|
|
|
|
|
|
|
assert hd(res["data"]["searchEvents"]["elements"])["uuid"] ==
|
|
|
|
|
event.uuid
|
|
|
|
|
end
|
2019-04-12 15:04:32 +02:00
|
|
|
|
end
|
|
|
|
|
|
2020-07-31 17:52:26 +02:00
|
|
|
|
describe "search_persons/3" do
|
2020-08-05 16:44:08 +02:00
|
|
|
|
@search_persons_query """
|
|
|
|
|
query SearchPersons($term: String!, $page: Int, $limit: Int) {
|
|
|
|
|
searchPersons(term: $term, page: $page, limit: $limit) {
|
|
|
|
|
total
|
|
|
|
|
elements {
|
|
|
|
|
id
|
|
|
|
|
avatar {
|
|
|
|
|
url
|
|
|
|
|
}
|
|
|
|
|
domain
|
|
|
|
|
preferredUsername
|
|
|
|
|
name
|
|
|
|
|
__typename
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
"""
|
|
|
|
|
|
2020-07-31 17:52:26 +02:00
|
|
|
|
test "finds persons with basic search", %{
|
|
|
|
|
conn: conn,
|
|
|
|
|
user: user
|
|
|
|
|
} do
|
|
|
|
|
actor = insert(:actor, user: user, preferred_username: "test_person")
|
|
|
|
|
insert(:actor, type: :Group, preferred_username: "test_group")
|
|
|
|
|
event = insert(:event, title: "test_event")
|
|
|
|
|
Workers.BuildSearch.insert_search_event(event)
|
|
|
|
|
|
|
|
|
|
res =
|
2020-08-05 16:44:08 +02:00
|
|
|
|
AbsintheHelpers.graphql_query(conn,
|
|
|
|
|
query: @search_persons_query,
|
|
|
|
|
variables: %{term: "test"}
|
|
|
|
|
)
|
2020-07-31 17:52:26 +02:00
|
|
|
|
|
2020-08-05 16:44:08 +02:00
|
|
|
|
assert res["errors"] == nil
|
|
|
|
|
assert res["data"]["searchPersons"]["total"] == 1
|
|
|
|
|
assert res["data"]["searchPersons"]["elements"] |> length == 1
|
2020-07-31 17:52:26 +02:00
|
|
|
|
|
2020-08-05 16:44:08 +02:00
|
|
|
|
assert hd(res["data"]["searchPersons"]["elements"])["preferredUsername"] ==
|
2020-07-31 17:52:26 +02:00
|
|
|
|
actor.preferred_username
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
test "finds persons with word search", %{
|
|
|
|
|
conn: conn,
|
|
|
|
|
user: user
|
|
|
|
|
} do
|
|
|
|
|
actor = insert(:actor, user: user, preferred_username: "person", name: "I like pineapples")
|
|
|
|
|
insert(:actor, preferred_username: "group", type: :Group, name: "pineapple group")
|
|
|
|
|
event1 = insert(:event, title: "Pineapple fashion week")
|
|
|
|
|
event2 = insert(:event, title: "I love pineAPPLE")
|
|
|
|
|
event3 = insert(:event, title: "Hello")
|
|
|
|
|
Workers.BuildSearch.insert_search_event(event1)
|
|
|
|
|
Workers.BuildSearch.insert_search_event(event2)
|
|
|
|
|
Workers.BuildSearch.insert_search_event(event3)
|
|
|
|
|
|
|
|
|
|
res =
|
2020-08-05 16:44:08 +02:00
|
|
|
|
AbsintheHelpers.graphql_query(conn,
|
|
|
|
|
query: @search_persons_query,
|
|
|
|
|
variables: %{term: "pineapple"}
|
|
|
|
|
)
|
2019-02-21 18:11:49 +01:00
|
|
|
|
|
2020-08-05 16:44:08 +02:00
|
|
|
|
assert res["errors"] == nil
|
|
|
|
|
assert res["data"]["searchPersons"]["total"] == 1
|
2019-04-12 15:04:32 +02:00
|
|
|
|
|
2020-08-05 16:44:08 +02:00
|
|
|
|
assert res["data"]["searchPersons"]["elements"]
|
2020-07-31 17:52:26 +02:00
|
|
|
|
|> length == 1
|
2019-04-12 15:04:32 +02:00
|
|
|
|
|
2020-08-05 16:44:08 +02:00
|
|
|
|
assert hd(res["data"]["searchPersons"]["elements"])["preferredUsername"] ==
|
2020-07-31 17:52:26 +02:00
|
|
|
|
actor.preferred_username
|
|
|
|
|
end
|
2019-04-12 15:04:32 +02:00
|
|
|
|
end
|
|
|
|
|
|
2020-07-31 17:52:26 +02:00
|
|
|
|
describe "search_groups/3" do
|
2020-08-05 16:44:08 +02:00
|
|
|
|
@search_groups_query """
|
|
|
|
|
query SearchGroups($term: String, $location: String, $radius: Float) {
|
|
|
|
|
searchGroups(term: $term, location: $location, radius: $radius) {
|
|
|
|
|
total
|
|
|
|
|
elements {
|
|
|
|
|
avatar {
|
|
|
|
|
url
|
|
|
|
|
}
|
|
|
|
|
domain
|
|
|
|
|
preferredUsername
|
|
|
|
|
name
|
|
|
|
|
__typename
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
"""
|
|
|
|
|
|
2020-07-31 17:52:26 +02:00
|
|
|
|
test "finds persons with basic search", %{
|
|
|
|
|
conn: conn,
|
|
|
|
|
user: user
|
|
|
|
|
} do
|
|
|
|
|
insert(:actor, user: user, preferred_username: "test_person")
|
|
|
|
|
group = insert(:actor, type: :Group, preferred_username: "test_group")
|
|
|
|
|
event = insert(:event, title: "test_event")
|
|
|
|
|
Workers.BuildSearch.insert_search_event(event)
|
|
|
|
|
|
|
|
|
|
res =
|
2020-08-05 16:44:08 +02:00
|
|
|
|
AbsintheHelpers.graphql_query(conn,
|
|
|
|
|
query: @search_groups_query,
|
|
|
|
|
variables: %{term: "test"}
|
|
|
|
|
)
|
2020-07-31 17:52:26 +02:00
|
|
|
|
|
2020-08-05 16:44:08 +02:00
|
|
|
|
assert res["errors"] == nil
|
|
|
|
|
assert res["data"]["searchGroups"]["total"] == 1
|
|
|
|
|
assert res["data"]["searchGroups"]["elements"] |> length == 1
|
2020-07-31 17:52:26 +02:00
|
|
|
|
|
2020-08-05 16:44:08 +02:00
|
|
|
|
assert hd(res["data"]["searchGroups"]["elements"])["preferredUsername"] ==
|
2020-07-31 17:52:26 +02:00
|
|
|
|
group.preferred_username
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
test "finds groups with accented search", %{
|
|
|
|
|
conn: conn,
|
|
|
|
|
user: user
|
|
|
|
|
} do
|
|
|
|
|
insert(:actor, user: user, preferred_username: "person", name: "Torréfaction du Kafé")
|
|
|
|
|
group = insert(:actor, type: :Group, preferred_username: "group", name: "Kafé group")
|
|
|
|
|
event = insert(:event, title: "Tour du monde des Kafés")
|
|
|
|
|
Workers.BuildSearch.insert_search_event(event)
|
|
|
|
|
|
2020-08-05 16:44:08 +02:00
|
|
|
|
res =
|
|
|
|
|
AbsintheHelpers.graphql_query(conn,
|
|
|
|
|
query: @search_groups_query,
|
|
|
|
|
variables: %{term: "Kafé"}
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
assert res["errors"] == nil
|
|
|
|
|
assert res["data"]["searchGroups"]["total"] == 1
|
|
|
|
|
|
|
|
|
|
assert hd(res["data"]["searchGroups"]["elements"])["preferredUsername"] ==
|
|
|
|
|
group.preferred_username
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
test "finds groups with location", %{conn: conn} do
|
|
|
|
|
{lon, lat} = {45.75, 4.85}
|
|
|
|
|
point = %Geo.Point{coordinates: {lon, lat}, srid: 4326}
|
|
|
|
|
geohash = Geohax.encode(lon, lat, 6)
|
|
|
|
|
geohash_2 = Geohax.encode(25, -19, 6)
|
|
|
|
|
address = insert(:address, geom: point)
|
|
|
|
|
|
|
|
|
|
group =
|
|
|
|
|
insert(:actor,
|
|
|
|
|
type: :Group,
|
|
|
|
|
preferred_username: "want_coffee",
|
|
|
|
|
name: "Want coffee ?",
|
|
|
|
|
physical_address: address
|
|
|
|
|
)
|
2019-02-21 18:11:49 +01:00
|
|
|
|
|
2020-07-31 17:52:26 +02:00
|
|
|
|
res =
|
2020-08-05 16:44:08 +02:00
|
|
|
|
AbsintheHelpers.graphql_query(conn,
|
|
|
|
|
query: @search_groups_query,
|
|
|
|
|
variables: %{location: geohash}
|
|
|
|
|
)
|
2019-02-21 18:11:49 +01:00
|
|
|
|
|
2020-08-05 16:44:08 +02:00
|
|
|
|
assert res["errors"] == nil
|
|
|
|
|
assert res["data"]["searchGroups"]["total"] == 1
|
2019-04-12 15:04:32 +02:00
|
|
|
|
|
2020-08-05 16:44:08 +02:00
|
|
|
|
assert hd(res["data"]["searchGroups"]["elements"])["preferredUsername"] ==
|
2020-07-31 17:52:26 +02:00
|
|
|
|
group.preferred_username
|
2020-08-05 16:44:08 +02:00
|
|
|
|
|
|
|
|
|
res =
|
|
|
|
|
AbsintheHelpers.graphql_query(conn,
|
|
|
|
|
query: @search_groups_query,
|
|
|
|
|
variables: %{location: geohash_2}
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
assert res["errors"] == nil
|
|
|
|
|
assert res["data"]["searchGroups"]["total"] == 0
|
2020-07-31 17:52:26 +02:00
|
|
|
|
end
|
2019-02-21 18:11:49 +01:00
|
|
|
|
end
|
|
|
|
|
end
|