Change models, new migrations, fix front and make tests work
Signed-off-by: Thomas Citharel <tcit@tcit.fr>
This commit is contained in:
113
test/eventos_web/controllers/session_controller_test.exs
Normal file
113
test/eventos_web/controllers/session_controller_test.exs
Normal file
@@ -0,0 +1,113 @@
|
||||
defmodule EventosWeb.SessionControllerTest do
|
||||
use EventosWeb.ConnCase
|
||||
|
||||
import Eventos.Factory
|
||||
|
||||
alias Eventos.Events
|
||||
alias Eventos.Events.Session
|
||||
|
||||
@create_attrs %{audios_urls: "some audios_urls", language: "some language", long_abstract: "some long_abstract", short_abstract: "some short_abstract", slides_url: "some slides_url", subtitle: "some subtitle", title: "some title", videos_urls: "some videos_urls"}
|
||||
@update_attrs %{audios_urls: "some updated audios_urls", language: "some updated language", long_abstract: "some updated long_abstract", short_abstract: "some updated short_abstract", slides_url: "some updated slides_url", subtitle: "some updated subtitle", title: "some updated title", videos_urls: "some updated videos_urls"}
|
||||
@invalid_attrs %{audios_urls: nil, language: nil, long_abstract: nil, short_abstract: nil, slides_url: nil, subtitle: nil, title: nil, videos_urls: nil}
|
||||
|
||||
def fixture(:session) do
|
||||
{:ok, session} = Events.create_session(@create_attrs)
|
||||
session
|
||||
end
|
||||
|
||||
setup %{conn: conn} do
|
||||
account = insert(:account)
|
||||
user = insert(:user, account: account)
|
||||
event = insert(:event, organizer: account)
|
||||
{:ok, conn: conn, user: user, event: event}
|
||||
end
|
||||
|
||||
describe "index" do
|
||||
test "lists all sessions", %{conn: conn} do
|
||||
conn = get conn, session_path(conn, :index)
|
||||
assert json_response(conn, 200)["data"] == []
|
||||
end
|
||||
end
|
||||
|
||||
describe "create session" do
|
||||
test "renders session 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, session_path(conn, :create), session: attrs
|
||||
assert %{"id" => id} = json_response(conn, 201)["data"]
|
||||
|
||||
conn = get conn, session_path(conn, :show, id)
|
||||
assert json_response(conn, 200)["data"] == %{
|
||||
"id" => id,
|
||||
"audios_urls" => "some audios_urls",
|
||||
"language" => "some language",
|
||||
"long_abstract" => "some long_abstract",
|
||||
"short_abstract" => "some short_abstract",
|
||||
"slides_url" => "some slides_url",
|
||||
"subtitle" => "some subtitle",
|
||||
"title" => "some title",
|
||||
"videos_urls" => "some videos_urls"}
|
||||
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, session_path(conn, :create), session: attrs
|
||||
assert json_response(conn, 422)["errors"] != %{}
|
||||
end
|
||||
end
|
||||
|
||||
describe "update session" do
|
||||
setup [:create_session]
|
||||
|
||||
test "renders session when data is valid", %{conn: conn, session: %Session{id: id} = session, user: user, event: event} do
|
||||
conn = auth_conn(conn, user)
|
||||
attrs = Map.put(@update_attrs, :event_id, event.id)
|
||||
conn = patch conn, session_path(conn, :update, session), session: attrs
|
||||
assert %{"id" => ^id} = json_response(conn, 200)["data"]
|
||||
|
||||
conn = get conn, session_path(conn, :show, id)
|
||||
assert json_response(conn, 200)["data"] == %{
|
||||
"id" => id,
|
||||
"audios_urls" => "some updated audios_urls",
|
||||
"language" => "some updated language",
|
||||
"long_abstract" => "some updated long_abstract",
|
||||
"short_abstract" => "some updated short_abstract",
|
||||
"slides_url" => "some updated slides_url",
|
||||
"subtitle" => "some updated subtitle",
|
||||
"title" => "some updated title",
|
||||
"videos_urls" => "some updated videos_urls"}
|
||||
end
|
||||
|
||||
test "renders errors when data is invalid", %{conn: conn, session: session, user: user} do
|
||||
conn = auth_conn(conn, user)
|
||||
conn = patch conn, session_path(conn, :update, session), session: @invalid_attrs
|
||||
assert json_response(conn, 422)["errors"] != %{}
|
||||
end
|
||||
end
|
||||
|
||||
describe "delete session" do
|
||||
setup [:create_session]
|
||||
|
||||
test "deletes chosen session", %{conn: conn, session: session, user: user} do
|
||||
conn = auth_conn(conn, user)
|
||||
conn = delete conn, session_path(conn, :delete, session)
|
||||
assert response(conn, 204)
|
||||
assert_error_sent 404, fn ->
|
||||
get conn, session_path(conn, :show, session)
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
defp create_session(_) do
|
||||
session = insert(:session)
|
||||
{:ok, session: session}
|
||||
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
|
||||
Reference in New Issue
Block a user