From 00467d249ac1f4df11d80718f6fe28067c61dda0 Mon Sep 17 00:00:00 2001 From: KKlochko Date: Tue, 3 Sep 2024 10:15:06 +0300 Subject: [PATCH] Add tests for Links' LiveViews. --- .../live/link_live_test.exs | 115 ++++++++++++++++++ 1 file changed, 115 insertions(+) create mode 100644 test/link_shortener_web/live/link_live_test.exs diff --git a/test/link_shortener_web/live/link_live_test.exs b/test/link_shortener_web/live/link_live_test.exs new file mode 100644 index 0000000..6451ceb --- /dev/null +++ b/test/link_shortener_web/live/link_live_test.exs @@ -0,0 +1,115 @@ +defmodule LinkShortenerWeb.LinkLiveTest do + use LinkShortenerWeb.ConnCase + + import Phoenix.LiveViewTest + import LinkShortener.LinksFixtures + import LinkShortener.AccountsFixtures + + alias LinkShortener.Factories.LinkFactory + + @create_attrs %{name: "some name", shorten: "some shorten", url: "some url"} + @update_attrs %{name: "some updated name", shorten: "some updated shorten", url: "some updated url"} + @invalid_attrs %{name: nil, shorten: nil, url: nil} + + setup %{conn: conn} do + user = user_fixture() + link = LinkFactory.create_link(%{user_id: user.id}) + + %{conn: log_in_user(conn, user), + link: link} + end + + describe "Index" do + test "lists all links", %{conn: conn, link: link} do + {:ok, _index_live, html} = live(conn, ~p"/links") + + assert html =~ "Listing Links" + assert html =~ link.name + end + + test "saves new link", %{conn: conn} do + {:ok, index_live, _html} = live(conn, ~p"/links") + + assert index_live |> element("a", "New Link") |> render_click() =~ + "New Link" + + assert_patch(index_live, ~p"/links/new") + + assert index_live + |> form("#link-form", link: @invalid_attrs) + |> render_change() =~ "can't be blank" + + assert index_live + |> form("#link-form", link: @create_attrs) + |> render_submit() + + assert_patch(index_live, ~p"/links") + + html = render(index_live) + assert html =~ "Link created successfully" + assert html =~ "some name" + end + + test "updates link in listing", %{conn: conn, link: link} do + {:ok, index_live, _html} = live(conn, ~p"/links") + + assert index_live |> element("#links-#{link.id} a", "Edit") |> render_click() =~ + "Edit Link" + + assert_patch(index_live, ~p"/links/#{link}/edit") + + assert index_live + |> form("#link-form", link: @invalid_attrs) + |> render_change() =~ "can't be blank" + + assert index_live + |> form("#link-form", link: @update_attrs) + |> render_submit() + + assert_patch(index_live, ~p"/links") + + html = render(index_live) + assert html =~ "Link updated successfully" + assert html =~ "some updated name" + end + + test "deletes link in listing", %{conn: conn, link: link} do + {:ok, index_live, _html} = live(conn, ~p"/links") + + assert index_live |> element("#links-#{link.id} a", "Delete") |> render_click() + refute has_element?(index_live, "#links-#{link.id}") + end + end + + describe "Show" do + test "displays link", %{conn: conn, link: link} do + {:ok, _show_live, html} = live(conn, ~p"/links/#{link}") + + assert html =~ "Show Link" + assert html =~ link.name + end + + test "updates link within modal", %{conn: conn, link: link} do + {:ok, show_live, _html} = live(conn, ~p"/links/#{link}") + + assert show_live |> element("a", "Edit") |> render_click() =~ + "Edit Link" + + assert_patch(show_live, ~p"/links/#{link}/show/edit") + + assert show_live + |> form("#link-form", link: @invalid_attrs) + |> render_change() =~ "can't be blank" + + assert show_live + |> form("#link-form", link: @update_attrs) + |> render_submit() + + assert_patch(show_live, ~p"/links/#{link}") + + html = render(show_live) + assert html =~ "Link updated successfully" + assert html =~ "some updated name" + end + end +end