b54dae7e15
Signed-off-by: Thomas Citharel <tcit@tcit.fr>
105 lines
3.7 KiB
Elixir
105 lines
3.7 KiB
Elixir
defmodule Mobilizon.AddressesTest do
|
|
use Mobilizon.DataCase
|
|
|
|
alias Mobilizon.Addresses
|
|
|
|
describe "addresses" do
|
|
alias Mobilizon.Addresses.Address
|
|
|
|
@valid_attrs %{
|
|
addressCountry: "some addressCountry",
|
|
addressLocality: "some addressLocality",
|
|
addressRegion: "some addressRegion",
|
|
description: "some description",
|
|
floor: "some floor",
|
|
postalCode: "some postalCode",
|
|
streetAddress: "some streetAddress",
|
|
geom: %Geo.Point{coordinates: {10, -10}, srid: 4326}
|
|
}
|
|
@update_attrs %{
|
|
addressCountry: "some updated addressCountry",
|
|
addressLocality: "some updated addressLocality",
|
|
addressRegion: "some updated addressRegion",
|
|
description: "some updated description",
|
|
floor: "some updated floor",
|
|
postalCode: "some updated postalCode",
|
|
streetAddress: "some updated streetAddress",
|
|
geom: %Geo.Point{coordinates: {20, -20}, srid: 4326}
|
|
}
|
|
@invalid_attrs %{
|
|
addressCountry: nil,
|
|
addressLocality: nil,
|
|
addressRegion: nil,
|
|
description: nil,
|
|
floor: nil,
|
|
postalCode: nil,
|
|
streetAddress: nil,
|
|
geom: nil
|
|
}
|
|
|
|
def address_fixture(attrs \\ %{}) do
|
|
{:ok, address} =
|
|
attrs
|
|
|> Enum.into(@valid_attrs)
|
|
|> Addresses.create_address()
|
|
|
|
address
|
|
end
|
|
|
|
test "list_addresses/0 returns all addresses" do
|
|
address = address_fixture()
|
|
assert Addresses.list_addresses() == [address]
|
|
end
|
|
|
|
test "get_address!/1 returns the address with given id" do
|
|
address = address_fixture()
|
|
assert Addresses.get_address!(address.id) == address
|
|
end
|
|
|
|
test "create_address/1 with valid data creates a address" do
|
|
assert {:ok, %Address{} = address} = Addresses.create_address(@valid_attrs)
|
|
assert address.addressCountry == "some addressCountry"
|
|
assert address.addressLocality == "some addressLocality"
|
|
assert address.addressRegion == "some addressRegion"
|
|
assert address.description == "some description"
|
|
assert address.floor == "some floor"
|
|
assert address.postalCode == "some postalCode"
|
|
assert address.streetAddress == "some streetAddress"
|
|
end
|
|
|
|
test "update_address/2 with valid data updates the address" do
|
|
address = address_fixture()
|
|
assert {:ok, address} = Addresses.update_address(address, @update_attrs)
|
|
assert %Address{} = address
|
|
assert address.addressCountry == "some updated addressCountry"
|
|
assert address.addressLocality == "some updated addressLocality"
|
|
assert address.addressRegion == "some updated addressRegion"
|
|
assert address.description == "some updated description"
|
|
assert address.floor == "some updated floor"
|
|
assert address.postalCode == "some updated postalCode"
|
|
assert address.streetAddress == "some updated streetAddress"
|
|
end
|
|
|
|
test "delete_address/1 deletes the address" do
|
|
address = address_fixture()
|
|
assert {:ok, %Address{}} = Addresses.delete_address(address)
|
|
assert_raise Ecto.NoResultsError, fn -> Addresses.get_address!(address.id) end
|
|
end
|
|
|
|
test "change_address/1 returns a address changeset" do
|
|
address = address_fixture()
|
|
assert %Ecto.Changeset{} = Addresses.change_address(address)
|
|
end
|
|
|
|
test "process_geom/2 with valid data returns a Point element" do
|
|
attrs = %{"type" => "point", "data" => %{"latitude" => 10, "longitude" => -10}}
|
|
assert {:ok, %Geo.Point{}} = Addresses.process_geom(attrs)
|
|
end
|
|
|
|
test "process_geom/2 with invalid data returns nil" do
|
|
attrs = %{"type" => :point, "data" => %{"latitude" => nil, "longitude" => nil}}
|
|
assert {:error, "Latitude and longitude must be numbers"} = Addresses.process_geom(attrs)
|
|
end
|
|
end
|
|
end
|