Change models, new migrations, fix front and make tests work
Signed-off-by: Thomas Citharel <tcit@tcit.fr>
This commit is contained in:
@@ -1,80 +1,88 @@
|
||||
defmodule EventosWeb.GroupControllerTest do
|
||||
use EventosWeb.ConnCase
|
||||
|
||||
alias Eventos.Accounts
|
||||
import Eventos.Factory
|
||||
|
||||
alias Eventos.Groups
|
||||
alias Eventos.Groups.Group
|
||||
|
||||
@create_attrs %{description: "some description", suspended: true, title: "some title", uri: "some uri", url: "some url"}
|
||||
@update_attrs %{description: "some updated description", suspended: false, title: "some updated title", uri: "some updated uri", url: "some updated url"}
|
||||
@invalid_attrs %{description: nil, suspended: nil, title: nil, uri: nil, url: nil}
|
||||
|
||||
def fixture(:group) do
|
||||
{:ok, group} = Accounts.create_group(@create_attrs)
|
||||
{:ok, group} = Groups.create_group(@create_attrs)
|
||||
group
|
||||
end
|
||||
|
||||
setup %{conn: conn} do
|
||||
account = insert(:account)
|
||||
user = insert(:user, account: account)
|
||||
{:ok, conn: conn, user: user}
|
||||
end
|
||||
|
||||
describe "index" do
|
||||
test "lists all groups", %{conn: conn} do
|
||||
conn = get conn, group_path(conn, :index)
|
||||
assert html_response(conn, 200) =~ "Listing Groups"
|
||||
end
|
||||
end
|
||||
|
||||
describe "new group" do
|
||||
test "renders form", %{conn: conn} do
|
||||
conn = get conn, group_path(conn, :new)
|
||||
assert html_response(conn, 200) =~ "New Group"
|
||||
assert json_response(conn, 200)["data"] == []
|
||||
end
|
||||
end
|
||||
|
||||
describe "create group" do
|
||||
test "redirects to show when data is valid", %{conn: conn} do
|
||||
test "renders group when data is valid", %{conn: conn, user: user} do
|
||||
conn = auth_conn(conn, user)
|
||||
conn = post conn, group_path(conn, :create), group: @create_attrs
|
||||
|
||||
assert %{id: id} = redirected_params(conn)
|
||||
assert redirected_to(conn) == group_path(conn, :show, id)
|
||||
assert %{"id" => id} = json_response(conn, 201)["data"]
|
||||
|
||||
conn = get conn, group_path(conn, :show, id)
|
||||
assert html_response(conn, 200) =~ "Show Group"
|
||||
assert json_response(conn, 200)["data"] == %{
|
||||
"id" => id,
|
||||
"description" => "some description",
|
||||
"suspended" => true,
|
||||
"title" => "some title",
|
||||
"uri" => "some uri",
|
||||
"url" => "some url"}
|
||||
end
|
||||
|
||||
test "renders errors when data is invalid", %{conn: conn} do
|
||||
test "renders errors when data is invalid", %{conn: conn, user: user} do
|
||||
conn = auth_conn(conn, user)
|
||||
conn = post conn, group_path(conn, :create), group: @invalid_attrs
|
||||
assert html_response(conn, 200) =~ "New Group"
|
||||
end
|
||||
end
|
||||
|
||||
describe "edit group" do
|
||||
setup [:create_group]
|
||||
|
||||
test "renders form for editing chosen group", %{conn: conn, group: group} do
|
||||
conn = get conn, group_path(conn, :edit, group)
|
||||
assert html_response(conn, 200) =~ "Edit Group"
|
||||
assert json_response(conn, 422)["errors"] != %{}
|
||||
end
|
||||
end
|
||||
|
||||
describe "update group" do
|
||||
setup [:create_group]
|
||||
|
||||
test "redirects when data is valid", %{conn: conn, group: group} do
|
||||
test "renders group when data is valid", %{conn: conn, group: %Group{id: id} = group, user: user} do
|
||||
conn = auth_conn(conn, user)
|
||||
conn = put conn, group_path(conn, :update, group), group: @update_attrs
|
||||
assert redirected_to(conn) == group_path(conn, :show, group)
|
||||
assert %{"id" => ^id} = json_response(conn, 200)["data"]
|
||||
|
||||
conn = get conn, group_path(conn, :show, group)
|
||||
assert html_response(conn, 200) =~ "some updated description"
|
||||
conn = get conn, group_path(conn, :show, id)
|
||||
assert json_response(conn, 200)["data"] == %{
|
||||
"id" => id,
|
||||
"description" => "some updated description",
|
||||
"suspended" => false,
|
||||
"title" => "some updated title",
|
||||
"uri" => "some updated uri",
|
||||
"url" => "some updated url"}
|
||||
end
|
||||
|
||||
test "renders errors when data is invalid", %{conn: conn, group: group} do
|
||||
test "renders errors when data is invalid", %{conn: conn, group: group, user: user} do
|
||||
conn = auth_conn(conn, user)
|
||||
conn = put conn, group_path(conn, :update, group), group: @invalid_attrs
|
||||
assert html_response(conn, 200) =~ "Edit Group"
|
||||
assert json_response(conn, 422)["errors"] != %{}
|
||||
end
|
||||
end
|
||||
|
||||
describe "delete group" do
|
||||
setup [:create_group]
|
||||
|
||||
test "deletes chosen group", %{conn: conn, group: group} do
|
||||
test "deletes chosen group", %{conn: conn, group: group, user: user} do
|
||||
conn = auth_conn(conn, user)
|
||||
conn = delete conn, group_path(conn, :delete, group)
|
||||
assert redirected_to(conn) == group_path(conn, :index)
|
||||
assert response(conn, 204)
|
||||
assert_error_sent 404, fn ->
|
||||
get conn, group_path(conn, :show, group)
|
||||
end
|
||||
@@ -85,4 +93,11 @@ defmodule EventosWeb.GroupControllerTest do
|
||||
group = fixture(:group)
|
||||
{:ok, group: group}
|
||||
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