defmodule PrymnWeb.ServerLiveTest do use PrymnWeb.ConnCase import Phoenix.LiveViewTest import Prymn.ServersFixtures @create_attrs %{name: "some name", provider: :Custom} @invalid_attrs %{name: nil} defp create_server(_) do server = server_fixture() %{server: server} end describe "Index" do setup [:create_server, :register_and_log_in_user] test "lists all servers", %{conn: conn, server: server} do {:ok, _index_live, html} = live(conn, ~p"/servers") assert html =~ "Your servers" assert html =~ server.name end test "saves new server", %{conn: conn} do {:ok, index_live, _html} = live(conn, ~p"/servers") assert index_live |> element("a", "Connect a Server") |> render_click() =~ "Add a new server" assert_patch(index_live, ~p"/servers/new") assert index_live |> form("#server-form", server: @invalid_attrs) |> render_change() =~ "can't be blank" assert index_live |> form("#server-form", server: @create_attrs) |> render_submit() assert_patch(index_live, ~p"/servers") html = render(index_live) assert html =~ "Success!" assert html =~ "some name" end end describe "Show" do setup [:create_server, :register_and_log_in_user] test "displays server", %{conn: conn, server: server} do {:ok, _show_live, html} = live(conn, ~p"/servers/#{server}") assert html =~ "Server some name" end end end