defmodule MemexWeb.ContextLiveTest do use MemexWeb.ConnCase import Phoenix.LiveViewTest import Memex.{ContextsFixtures, NotesFixtures} alias MemexWeb.Endpoint @create_attrs %{ "content" => "some content", "tags_string" => "tag1", "slug" => "some-slug", "visibility" => :public } @update_attrs %{ "content" => "some updated content", "tags_string" => "tag1,tag2", "slug" => "some-updated-slug", "visibility" => :private } @invalid_attrs %{ "content" => nil, "tags_string" => " ", "slug" => nil, "visibility" => nil } defp create_context(%{current_user: current_user}) do [context: context_fixture(current_user)] end describe "Index" do setup [:register_and_log_in_user, :create_context] test "lists all contexts", %{conn: conn, context: context} do {:ok, _index_live, html} = live(conn, Routes.context_index_path(conn, :index)) assert html =~ "contexts" assert html =~ context.slug end test "searches by tag", %{conn: conn} do {:ok, index_live, html} = live(conn, Routes.context_index_path(conn, :index)) assert html =~ "example-tag" assert index_live |> element("a", "example-tag") |> render_click() assert_patch(index_live, Routes.context_index_path(conn, :search, "example-tag")) end test "saves new context", %{conn: conn} do {:ok, index_live, _html} = live(conn, Routes.context_index_path(conn, :index)) assert index_live |> element("a", "new context") |> render_click() =~ "new context" assert_patch(index_live, Routes.context_index_path(conn, :new)) assert index_live |> form("#context-form", context: @invalid_attrs) |> render_change() =~ "can't be blank" {:ok, _, html} = index_live |> form("#context-form", context: @create_attrs) |> render_submit() |> follow_redirect(conn, Routes.context_index_path(conn, :index)) assert html =~ "#{@create_attrs |> Map.get("slug")} created" assert html =~ "some-slug" end test "updates context in listing", %{conn: conn, context: context} do {:ok, index_live, _html} = live(conn, Routes.context_index_path(conn, :index)) assert index_live |> element("[data-qa=\"context-edit-#{context.id}\"]") |> render_click() =~ "edit" assert_patch(index_live, Routes.context_index_path(conn, :edit, context.slug)) assert index_live |> form("#context-form", context: @invalid_attrs) |> render_change() =~ "can't be blank" {:ok, _, html} = index_live |> form("#context-form", context: @update_attrs) |> render_submit() |> follow_redirect(conn, Routes.context_index_path(conn, :index)) assert html =~ "#{@update_attrs |> Map.get("slug")} saved" assert html =~ "some-updated-slug" end test "deletes context in listing", %{conn: conn, context: context} do {:ok, index_live, _html} = live(conn, Routes.context_index_path(conn, :index)) assert index_live |> element("[data-qa=\"delete-context-#{context.id}\"]") |> render_click() refute has_element?(index_live, "#context-#{context.id}") end end describe "show" do setup [:register_and_log_in_user, :create_context] test "displays context", %{conn: conn, context: context} do {:ok, _show_live, html} = live(conn, Routes.context_show_path(conn, :show, context.slug)) assert html =~ "context" assert html =~ context.slug end test "updates context within modal", %{conn: conn, context: context} do {:ok, show_live, _html} = live(conn, Routes.context_show_path(conn, :show, context.slug)) assert show_live |> element("a", "edit") |> render_click() =~ "edit" assert_patch(show_live, Routes.context_show_path(conn, :edit, context.slug)) html = show_live |> form("#context-form", context: @invalid_attrs) |> render_change() assert html =~ "can't be blank" assert html =~ "tags must be comma-delimited" {:ok, _, html} = show_live |> form("#context-form", context: Map.put(@update_attrs, "slug", context.slug)) |> render_submit() |> follow_redirect(conn, Routes.context_show_path(conn, :show, context.slug)) assert html =~ "#{context.slug} saved" assert html =~ "tag2" end test "deletes context", %{conn: conn, context: context} do {:ok, show_live, _html} = live(conn, Routes.context_show_path(conn, :show, context.slug)) {:ok, index_live, _html} = show_live |> element("[data-qa=\"delete-context-#{context.id}\"]") |> render_click() |> follow_redirect(conn, Routes.context_index_path(conn, :index)) refute has_element?(index_live, "#context-#{context.id}") end end describe "show with note" do setup [:register_and_log_in_user] setup %{current_user: current_user} do %{slug: note_slug} = note = note_fixture(current_user) [ note: note, context: context_fixture( %{content: "example with backlink to [[#{note_slug}]] note"}, current_user ) ] end test "searches by tag", %{conn: conn, context: context} do {:ok, show_live, html} = live(conn, Routes.context_show_path(conn, :show, context.slug)) assert html =~ "example-tag" assert show_live |> element("a", "example-tag") |> render_click() assert_redirect(show_live, Routes.context_index_path(conn, :search, "example-tag")) end test "displays context", %{conn: conn, context: context, note: %{slug: note_slug}} do {:ok, show_live, html} = live(conn, Routes.context_show_path(conn, :show, context.slug)) assert html =~ "context" assert html =~ Routes.note_show_path(Endpoint, :show, note_slug) assert has_element?(show_live, "[data-qa=\"context-note-#{note_slug}\"]") end end end