debianize-mobilizon/test/eventos_web/controllers/track_controller_test.exs

105 lines
3.4 KiB
Elixir
Raw Normal View History

defmodule EventosWeb.TrackControllerTest do
use EventosWeb.ConnCase
import Eventos.Factory
alias Eventos.Events
alias Eventos.Events.Track
@create_attrs %{color: "some color", description: "some description", name: "some name"}
@update_attrs %{color: "some updated color", description: "some updated description", name: "some updated name"}
@invalid_attrs %{color: nil, description: nil, name: nil}
def fixture(:track) do
{:ok, track} = Events.create_track(@create_attrs)
track
end
setup %{conn: conn} do
account = insert(:account)
user = insert(:user, account: account)
event = insert(:event, organizer_account: account)
{:ok, conn: conn, user: user, event: event}
end
describe "index" do
test "lists all tracks", %{conn: conn} do
conn = get conn, track_path(conn, :index)
assert json_response(conn, 200)["data"] == []
end
end
describe "create track" do
test "renders track when data is valid", %{conn: conn, user: user, event: event} do
conn = auth_conn(conn, user)
attrs = Map.put(@create_attrs, :event_id, event.id)
conn = post conn, track_path(conn, :create), track: attrs
assert %{"id" => id} = json_response(conn, 201)["data"]
conn = get conn, track_path(conn, :show, id)
assert json_response(conn, 200)["data"] == %{
"id" => id,
"color" => "some color",
"description" => "some description",
"name" => "some name"}
end
test "renders errors when data is invalid", %{conn: conn, user: user, event: event} do
conn = auth_conn(conn, user)
attrs = Map.put(@invalid_attrs, :event_id, event.id)
conn = post conn, track_path(conn, :create), track: attrs
assert json_response(conn, 422)["errors"] != %{}
end
end
describe "update track" do
setup [:create_track]
test "renders track when data is valid", %{conn: conn, track: %Track{id: id} = track, user: user, event: event} do
conn = auth_conn(conn, user)
attrs = Map.put(@update_attrs, :event_id, event.id)
conn = put conn, track_path(conn, :update, track), track: attrs
assert %{"id" => ^id} = json_response(conn, 200)["data"]
conn = get conn, track_path(conn, :show, id)
assert json_response(conn, 200)["data"] == %{
"id" => id,
"color" => "some updated color",
"description" => "some updated description",
"name" => "some updated name"}
end
test "renders errors when data is invalid", %{conn: conn, track: track, user: user, event: event} do
conn = auth_conn(conn, user)
attrs = Map.put(@invalid_attrs, :event_id, event.id)
conn = put conn, track_path(conn, :update, track), track: attrs
assert json_response(conn, 422)["errors"] != %{}
end
end
describe "delete track" do
setup [:create_track]
test "deletes chosen track", %{conn: conn, track: track, user: user} do
conn = auth_conn(conn, user)
conn = delete conn, track_path(conn, :delete, track)
assert response(conn, 204)
assert_error_sent 404, fn ->
get conn, track_path(conn, :show, track)
end
end
end
defp create_track(_) do
track = insert(:track)
{:ok, track: track}
end
defp auth_conn(conn, %Eventos.Accounts.User{} = user) do
{:ok, token, _claims} = EventosWeb.Guardian.encode_and_sign(user)
conn
|> put_req_header("authorization", "Bearer #{token}")
|> put_req_header("accept", "application/json")
end
end