2019-03-12 10:52:28 +00:00
|
|
|
defmodule Mobilizon.Service.Geospatial.PhotonTest do
|
2019-09-22 14:26:23 +00:00
|
|
|
use ExVCR.Mock, adapter: ExVCR.Adapter.Hackney
|
|
|
|
|
2019-12-20 12:04:34 +00:00
|
|
|
use Mobilizon.DataCase
|
2019-03-12 10:52:28 +00:00
|
|
|
|
|
|
|
import Mock
|
2019-09-22 14:26:23 +00:00
|
|
|
|
|
|
|
alias Mobilizon.Addresses.Address
|
2019-10-11 15:20:03 +00:00
|
|
|
alias Mobilizon.Config
|
2020-01-28 19:15:59 +00:00
|
|
|
alias Mobilizon.Service.Geospatial.Photon
|
2019-10-11 15:20:03 +00:00
|
|
|
|
2020-02-18 07:57:00 +00:00
|
|
|
@http_options [
|
|
|
|
follow_redirect: true,
|
|
|
|
ssl: [{:versions, [:"tlsv1.2"]}]
|
|
|
|
]
|
|
|
|
|
2019-12-20 12:04:34 +00:00
|
|
|
setup do
|
|
|
|
# Config.instance_user_agent/0 makes database calls so because of ownership connection
|
|
|
|
# we need to define it like this instead of a constant
|
|
|
|
# See https://hexdocs.pm/ecto_sql/Ecto.Adapters.SQL.Sandbox.html
|
|
|
|
{:ok,
|
|
|
|
httpoison_headers: [
|
|
|
|
{"User-Agent", Config.instance_user_agent()}
|
|
|
|
]}
|
|
|
|
end
|
2019-03-12 10:52:28 +00:00
|
|
|
|
|
|
|
describe "search address" do
|
2019-12-20 12:04:34 +00:00
|
|
|
test "produces a valid search address with options", %{httpoison_headers: httpoison_headers} do
|
2019-03-12 10:52:28 +00:00
|
|
|
with_mock HTTPoison,
|
2020-02-18 07:57:00 +00:00
|
|
|
get: fn _url, _headers, _options ->
|
2019-03-12 10:52:28 +00:00
|
|
|
{:ok, %HTTPoison.Response{status_code: 200, body: "{\"features\": []"}}
|
|
|
|
end do
|
|
|
|
Photon.search("10 Rue Jangot",
|
|
|
|
limit: 5,
|
|
|
|
lang: "fr"
|
|
|
|
)
|
|
|
|
|
|
|
|
assert_called(
|
2019-10-11 15:20:03 +00:00
|
|
|
HTTPoison.get(
|
|
|
|
"https://photon.komoot.de/api/?q=10%20Rue%20Jangot&lang=fr&limit=5",
|
2020-02-18 07:57:00 +00:00
|
|
|
httpoison_headers,
|
|
|
|
@http_options
|
2019-10-11 15:20:03 +00:00
|
|
|
)
|
2019-03-12 10:52:28 +00:00
|
|
|
)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
test "returns a valid address from search" do
|
|
|
|
use_cassette "geospatial/photon/search" do
|
|
|
|
assert %Address{
|
2019-03-22 14:51:23 +00:00
|
|
|
locality: "Lyon",
|
2019-03-12 10:52:28 +00:00
|
|
|
description: "10 Rue Jangot",
|
2019-03-22 14:51:23 +00:00
|
|
|
region: "Auvergne-Rhône-Alpes",
|
|
|
|
country: "France",
|
|
|
|
postal_code: "69007",
|
|
|
|
street: "10 Rue Jangot",
|
2019-03-12 10:52:28 +00:00
|
|
|
geom: %Geo.Point{
|
|
|
|
coordinates: {4.8425657, 45.7517141},
|
|
|
|
properties: %{},
|
|
|
|
srid: 4326
|
|
|
|
}
|
|
|
|
} == Photon.search("10 rue Jangot") |> hd
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# Photon returns something quite wrong, so no need to test this right now.
|
|
|
|
# test "returns a valid address from reverse geocode" do
|
|
|
|
# use_cassette "geospatial/photon/geocode" do
|
|
|
|
# assert %Address{
|
2019-03-22 14:51:23 +00:00
|
|
|
# locality: "Lyon",
|
2019-03-12 10:52:28 +00:00
|
|
|
# description: "",
|
2019-03-22 14:51:23 +00:00
|
|
|
# region: "Auvergne-Rhône-Alpes",
|
|
|
|
# country: "France",
|
|
|
|
# postal_code: "69007",
|
|
|
|
# street: "10 Rue Jangot",
|
2019-03-12 10:52:28 +00:00
|
|
|
# geom: %Geo.Point{
|
|
|
|
# coordinates: {4.8425657, 45.7517141},
|
|
|
|
# properties: %{},
|
|
|
|
# srid: 4326
|
|
|
|
# }
|
|
|
|
# } ==
|
|
|
|
# Photon.geocode(4.8425657, 45.7517141)
|
|
|
|
# |> hd
|
|
|
|
# end
|
|
|
|
# end
|
|
|
|
end
|
|
|
|
end
|