forked from shibao/cannery
		
	rename ammo groups to packs
This commit is contained in:
		@@ -1,4 +1,4 @@
 | 
			
		||||
defmodule CanneryWeb.AmmoGroupLiveTest do
 | 
			
		||||
defmodule CanneryWeb.PackLiveTest do
 | 
			
		||||
  @moduledoc """
 | 
			
		||||
  Tests ammo group live pages
 | 
			
		||||
  """
 | 
			
		||||
@@ -7,11 +7,11 @@ defmodule CanneryWeb.AmmoGroupLiveTest do
 | 
			
		||||
  import Phoenix.LiveViewTest
 | 
			
		||||
  alias Cannery.{Ammo, Repo}
 | 
			
		||||
 | 
			
		||||
  @moduletag :ammo_group_live_test
 | 
			
		||||
  @moduletag :pack_live_test
 | 
			
		||||
  @create_attrs %{count: 42, notes: "some notes", price_paid: 120.5}
 | 
			
		||||
  @update_attrs %{count: 43, notes: "some updated notes", price_paid: 456.7}
 | 
			
		||||
  @invalid_attrs %{count: nil, notes: nil, price_paid: nil}
 | 
			
		||||
  @ammo_group_create_limit 10_000
 | 
			
		||||
  @pack_create_limit 10_000
 | 
			
		||||
  @shot_group_create_attrs %{ammo_left: 5, notes: "some notes"}
 | 
			
		||||
  @shot_group_update_attrs %{
 | 
			
		||||
    count: 5,
 | 
			
		||||
@@ -28,296 +28,294 @@ defmodule CanneryWeb.AmmoGroupLiveTest do
 | 
			
		||||
    count: 20
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  defp create_ammo_group(%{current_user: current_user}) do
 | 
			
		||||
  defp create_pack(%{current_user: current_user}) do
 | 
			
		||||
    ammo_type = ammo_type_fixture(current_user)
 | 
			
		||||
    container = container_fixture(current_user)
 | 
			
		||||
    {1, [ammo_group]} = ammo_group_fixture(@create_attrs, ammo_type, container, current_user)
 | 
			
		||||
    [ammo_type: ammo_type, ammo_group: ammo_group, container: container]
 | 
			
		||||
    {1, [pack]} = pack_fixture(@create_attrs, ammo_type, container, current_user)
 | 
			
		||||
    [ammo_type: ammo_type, pack: pack, container: container]
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  defp create_shot_group(%{current_user: current_user, ammo_group: ammo_group}) do
 | 
			
		||||
    shot_group = shot_group_fixture(@shot_group_update_attrs, current_user, ammo_group)
 | 
			
		||||
    ammo_group = ammo_group |> Repo.reload!()
 | 
			
		||||
    [ammo_group: ammo_group, shot_group: shot_group]
 | 
			
		||||
  defp create_shot_group(%{current_user: current_user, pack: pack}) do
 | 
			
		||||
    shot_group = shot_group_fixture(@shot_group_update_attrs, current_user, pack)
 | 
			
		||||
    pack = pack |> Repo.reload!()
 | 
			
		||||
    [pack: pack, shot_group: shot_group]
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  defp create_empty_ammo_group(%{
 | 
			
		||||
  defp create_empty_pack(%{
 | 
			
		||||
         current_user: current_user,
 | 
			
		||||
         ammo_type: ammo_type,
 | 
			
		||||
         container: container
 | 
			
		||||
       }) do
 | 
			
		||||
    {1, [ammo_group]} = ammo_group_fixture(@empty_attrs, ammo_type, container, current_user)
 | 
			
		||||
    shot_group = shot_group_fixture(@shot_group_attrs, current_user, ammo_group)
 | 
			
		||||
    ammo_group = ammo_group |> Repo.reload!()
 | 
			
		||||
    [empty_ammo_group: ammo_group, shot_group: shot_group]
 | 
			
		||||
    {1, [pack]} = pack_fixture(@empty_attrs, ammo_type, container, current_user)
 | 
			
		||||
    shot_group = shot_group_fixture(@shot_group_attrs, current_user, pack)
 | 
			
		||||
    pack = pack |> Repo.reload!()
 | 
			
		||||
    [empty_pack: pack, shot_group: shot_group]
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  describe "Index of ammo group" do
 | 
			
		||||
    setup [:register_and_log_in_user, :create_ammo_group]
 | 
			
		||||
    setup [:register_and_log_in_user, :create_pack]
 | 
			
		||||
 | 
			
		||||
    test "lists all ammo_groups", %{conn: conn, ammo_group: ammo_group} do
 | 
			
		||||
      {:ok, _index_live, html} = live(conn, Routes.ammo_group_index_path(conn, :index))
 | 
			
		||||
      ammo_group = ammo_group |> Repo.preload(:ammo_type)
 | 
			
		||||
    test "lists all packs", %{conn: conn, pack: pack} do
 | 
			
		||||
      {:ok, _index_live, html} = live(conn, Routes.pack_index_path(conn, :index))
 | 
			
		||||
      pack = pack |> Repo.preload(:ammo_type)
 | 
			
		||||
      assert html =~ "Ammo"
 | 
			
		||||
      assert html =~ ammo_group.ammo_type.name
 | 
			
		||||
      assert html =~ pack.ammo_type.name
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    test "can sort by type",
 | 
			
		||||
         %{conn: conn, container: container, current_user: current_user} do
 | 
			
		||||
      rifle_type = ammo_type_fixture(%{class: :rifle}, current_user)
 | 
			
		||||
      {1, [rifle_ammo_group]} = ammo_group_fixture(rifle_type, container, current_user)
 | 
			
		||||
      {1, [rifle_pack]} = pack_fixture(rifle_type, container, current_user)
 | 
			
		||||
      shotgun_type = ammo_type_fixture(%{class: :shotgun}, current_user)
 | 
			
		||||
      {1, [shotgun_ammo_group]} = ammo_group_fixture(shotgun_type, container, current_user)
 | 
			
		||||
      {1, [shotgun_pack]} = pack_fixture(shotgun_type, container, current_user)
 | 
			
		||||
      pistol_type = ammo_type_fixture(%{class: :pistol}, current_user)
 | 
			
		||||
      {1, [pistol_ammo_group]} = ammo_group_fixture(pistol_type, container, current_user)
 | 
			
		||||
      {1, [pistol_pack]} = pack_fixture(pistol_type, container, current_user)
 | 
			
		||||
 | 
			
		||||
      {:ok, index_live, html} = live(conn, Routes.ammo_group_index_path(conn, :index))
 | 
			
		||||
      {:ok, index_live, html} = live(conn, Routes.pack_index_path(conn, :index))
 | 
			
		||||
 | 
			
		||||
      assert html =~ "All"
 | 
			
		||||
 | 
			
		||||
      assert html =~ rifle_ammo_group.ammo_type.name
 | 
			
		||||
      assert html =~ shotgun_ammo_group.ammo_type.name
 | 
			
		||||
      assert html =~ pistol_ammo_group.ammo_type.name
 | 
			
		||||
      assert html =~ rifle_pack.ammo_type.name
 | 
			
		||||
      assert html =~ shotgun_pack.ammo_type.name
 | 
			
		||||
      assert html =~ pistol_pack.ammo_type.name
 | 
			
		||||
 | 
			
		||||
      html =
 | 
			
		||||
        index_live
 | 
			
		||||
        |> form(~s/form[phx-change="change_class"]/)
 | 
			
		||||
        |> render_change(ammo_type: %{class: :rifle})
 | 
			
		||||
 | 
			
		||||
      assert html =~ rifle_ammo_group.ammo_type.name
 | 
			
		||||
      refute html =~ shotgun_ammo_group.ammo_type.name
 | 
			
		||||
      refute html =~ pistol_ammo_group.ammo_type.name
 | 
			
		||||
      assert html =~ rifle_pack.ammo_type.name
 | 
			
		||||
      refute html =~ shotgun_pack.ammo_type.name
 | 
			
		||||
      refute html =~ pistol_pack.ammo_type.name
 | 
			
		||||
 | 
			
		||||
      html =
 | 
			
		||||
        index_live
 | 
			
		||||
        |> form(~s/form[phx-change="change_class"]/)
 | 
			
		||||
        |> render_change(ammo_type: %{class: :shotgun})
 | 
			
		||||
 | 
			
		||||
      refute html =~ rifle_ammo_group.ammo_type.name
 | 
			
		||||
      assert html =~ shotgun_ammo_group.ammo_type.name
 | 
			
		||||
      refute html =~ pistol_ammo_group.ammo_type.name
 | 
			
		||||
      refute html =~ rifle_pack.ammo_type.name
 | 
			
		||||
      assert html =~ shotgun_pack.ammo_type.name
 | 
			
		||||
      refute html =~ pistol_pack.ammo_type.name
 | 
			
		||||
 | 
			
		||||
      html =
 | 
			
		||||
        index_live
 | 
			
		||||
        |> form(~s/form[phx-change="change_class"]/)
 | 
			
		||||
        |> render_change(ammo_type: %{class: :pistol})
 | 
			
		||||
 | 
			
		||||
      refute html =~ rifle_ammo_group.ammo_type.name
 | 
			
		||||
      refute html =~ shotgun_ammo_group.ammo_type.name
 | 
			
		||||
      assert html =~ pistol_ammo_group.ammo_type.name
 | 
			
		||||
      refute html =~ rifle_pack.ammo_type.name
 | 
			
		||||
      refute html =~ shotgun_pack.ammo_type.name
 | 
			
		||||
      assert html =~ pistol_pack.ammo_type.name
 | 
			
		||||
 | 
			
		||||
      html =
 | 
			
		||||
        index_live
 | 
			
		||||
        |> form(~s/form[phx-change="change_class"]/)
 | 
			
		||||
        |> render_change(ammo_type: %{class: :all})
 | 
			
		||||
 | 
			
		||||
      assert html =~ rifle_ammo_group.ammo_type.name
 | 
			
		||||
      assert html =~ shotgun_ammo_group.ammo_type.name
 | 
			
		||||
      assert html =~ pistol_ammo_group.ammo_type.name
 | 
			
		||||
      assert html =~ rifle_pack.ammo_type.name
 | 
			
		||||
      assert html =~ shotgun_pack.ammo_type.name
 | 
			
		||||
      assert html =~ pistol_pack.ammo_type.name
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    test "can search for ammo_groups", %{conn: conn, ammo_group: ammo_group} do
 | 
			
		||||
      {:ok, index_live, html} = live(conn, Routes.ammo_group_index_path(conn, :index))
 | 
			
		||||
    test "can search for packs", %{conn: conn, pack: pack} do
 | 
			
		||||
      {:ok, index_live, html} = live(conn, Routes.pack_index_path(conn, :index))
 | 
			
		||||
 | 
			
		||||
      ammo_group = ammo_group |> Repo.preload(:ammo_type)
 | 
			
		||||
      pack = pack |> Repo.preload(:ammo_type)
 | 
			
		||||
 | 
			
		||||
      assert html =~ ammo_group.ammo_type.name
 | 
			
		||||
      assert html =~ pack.ammo_type.name
 | 
			
		||||
 | 
			
		||||
      assert index_live
 | 
			
		||||
             |> form(~s/form[phx-change="search"]/)
 | 
			
		||||
             |> render_change(search: %{search_term: ammo_group.ammo_type.name}) =~
 | 
			
		||||
               ammo_group.ammo_type.name
 | 
			
		||||
             |> render_change(search: %{search_term: pack.ammo_type.name}) =~
 | 
			
		||||
               pack.ammo_type.name
 | 
			
		||||
 | 
			
		||||
      assert_patch(
 | 
			
		||||
        index_live,
 | 
			
		||||
        Routes.ammo_group_index_path(conn, :search, ammo_group.ammo_type.name)
 | 
			
		||||
        Routes.pack_index_path(conn, :search, pack.ammo_type.name)
 | 
			
		||||
      )
 | 
			
		||||
 | 
			
		||||
      refute index_live
 | 
			
		||||
             |> form(~s/form[phx-change="search"]/)
 | 
			
		||||
             |> render_change(search: %{search_term: "something_else"}) =~
 | 
			
		||||
               ammo_group.ammo_type.name
 | 
			
		||||
               pack.ammo_type.name
 | 
			
		||||
 | 
			
		||||
      assert_patch(index_live, Routes.ammo_group_index_path(conn, :search, "something_else"))
 | 
			
		||||
      assert_patch(index_live, Routes.pack_index_path(conn, :search, "something_else"))
 | 
			
		||||
 | 
			
		||||
      assert index_live
 | 
			
		||||
             |> form(~s/form[phx-change="search"]/)
 | 
			
		||||
             |> render_change(search: %{search_term: ""}) =~ ammo_group.ammo_type.name
 | 
			
		||||
             |> render_change(search: %{search_term: ""}) =~ pack.ammo_type.name
 | 
			
		||||
 | 
			
		||||
      assert_patch(index_live, Routes.ammo_group_index_path(conn, :index))
 | 
			
		||||
      assert_patch(index_live, Routes.pack_index_path(conn, :index))
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    test "saves a single new ammo_group", %{conn: conn} do
 | 
			
		||||
      {:ok, index_live, _html} = live(conn, Routes.ammo_group_index_path(conn, :index))
 | 
			
		||||
    test "saves a single new pack", %{conn: conn} do
 | 
			
		||||
      {:ok, index_live, _html} = live(conn, Routes.pack_index_path(conn, :index))
 | 
			
		||||
 | 
			
		||||
      assert index_live |> element("a", "Add Ammo") |> render_click() =~ "Add Ammo"
 | 
			
		||||
      assert_patch(index_live, Routes.ammo_group_index_path(conn, :new))
 | 
			
		||||
      assert_patch(index_live, Routes.pack_index_path(conn, :new))
 | 
			
		||||
 | 
			
		||||
      assert index_live
 | 
			
		||||
             |> form("#ammo_group-form")
 | 
			
		||||
             |> render_change(ammo_group: @invalid_attrs) =~ "can't be blank"
 | 
			
		||||
             |> form("#pack-form")
 | 
			
		||||
             |> render_change(pack: @invalid_attrs) =~ "can't be blank"
 | 
			
		||||
 | 
			
		||||
      {:ok, _view, html} =
 | 
			
		||||
        index_live
 | 
			
		||||
        |> form("#ammo_group-form")
 | 
			
		||||
        |> render_submit(ammo_group: @create_attrs)
 | 
			
		||||
        |> follow_redirect(conn, Routes.ammo_group_index_path(conn, :index))
 | 
			
		||||
        |> form("#pack-form")
 | 
			
		||||
        |> render_submit(pack: @create_attrs)
 | 
			
		||||
        |> follow_redirect(conn, Routes.pack_index_path(conn, :index))
 | 
			
		||||
 | 
			
		||||
      assert html =~ "Ammo added successfully"
 | 
			
		||||
      assert html =~ "\n42\n"
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    test "saves multiple new ammo_groups", %{conn: conn, current_user: current_user} do
 | 
			
		||||
    test "saves multiple new packs", %{conn: conn, current_user: current_user} do
 | 
			
		||||
      multiplier = 25
 | 
			
		||||
      {:ok, index_live, _html} = live(conn, Routes.ammo_group_index_path(conn, :index))
 | 
			
		||||
      {:ok, index_live, _html} = live(conn, Routes.pack_index_path(conn, :index))
 | 
			
		||||
 | 
			
		||||
      assert index_live |> element("a", "Add Ammo") |> render_click() =~ "Add Ammo"
 | 
			
		||||
      assert_patch(index_live, Routes.ammo_group_index_path(conn, :new))
 | 
			
		||||
      assert_patch(index_live, Routes.pack_index_path(conn, :new))
 | 
			
		||||
 | 
			
		||||
      assert index_live
 | 
			
		||||
             |> form("#ammo_group-form")
 | 
			
		||||
             |> render_change(ammo_group: @invalid_attrs) =~ "can't be blank"
 | 
			
		||||
             |> form("#pack-form")
 | 
			
		||||
             |> render_change(pack: @invalid_attrs) =~ "can't be blank"
 | 
			
		||||
 | 
			
		||||
      {:ok, _view, html} =
 | 
			
		||||
        index_live
 | 
			
		||||
        |> form("#ammo_group-form")
 | 
			
		||||
        |> render_submit(ammo_group: @create_attrs |> Map.put(:multiplier, multiplier))
 | 
			
		||||
        |> follow_redirect(conn, Routes.ammo_group_index_path(conn, :index))
 | 
			
		||||
        |> form("#pack-form")
 | 
			
		||||
        |> render_submit(pack: @create_attrs |> Map.put(:multiplier, multiplier))
 | 
			
		||||
        |> follow_redirect(conn, Routes.pack_index_path(conn, :index))
 | 
			
		||||
 | 
			
		||||
      assert html =~ "Ammo added successfully"
 | 
			
		||||
      assert Ammo.list_ammo_groups(nil, :all, current_user) |> Enum.count() == multiplier + 1
 | 
			
		||||
      assert Ammo.list_packs(nil, :all, current_user) |> Enum.count() == multiplier + 1
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    test "does not save invalid number of new ammo_groups", %{conn: conn} do
 | 
			
		||||
      {:ok, index_live, _html} = live(conn, Routes.ammo_group_index_path(conn, :index))
 | 
			
		||||
    test "does not save invalid number of new packs", %{conn: conn} do
 | 
			
		||||
      {:ok, index_live, _html} = live(conn, Routes.pack_index_path(conn, :index))
 | 
			
		||||
 | 
			
		||||
      assert index_live |> element("a", "Add Ammo") |> render_click() =~ "Add Ammo"
 | 
			
		||||
      assert_patch(index_live, Routes.ammo_group_index_path(conn, :new))
 | 
			
		||||
      assert_patch(index_live, Routes.pack_index_path(conn, :new))
 | 
			
		||||
 | 
			
		||||
      assert index_live
 | 
			
		||||
             |> form("#ammo_group-form")
 | 
			
		||||
             |> render_change(ammo_group: @invalid_attrs) =~ "can't be blank"
 | 
			
		||||
             |> form("#pack-form")
 | 
			
		||||
             |> render_change(pack: @invalid_attrs) =~ "can't be blank"
 | 
			
		||||
 | 
			
		||||
      assert index_live
 | 
			
		||||
             |> form("#ammo_group-form")
 | 
			
		||||
             |> render_submit(ammo_group: @create_attrs |> Map.put(:multiplier, "0")) =~
 | 
			
		||||
               "Invalid number of copies, must be between 1 and #{@ammo_group_create_limit}. Was 0"
 | 
			
		||||
             |> form("#pack-form")
 | 
			
		||||
             |> render_submit(pack: @create_attrs |> Map.put(:multiplier, "0")) =~
 | 
			
		||||
               "Invalid number of copies, must be between 1 and #{@pack_create_limit}. Was 0"
 | 
			
		||||
 | 
			
		||||
      assert index_live
 | 
			
		||||
             |> form("#ammo_group-form")
 | 
			
		||||
             |> render_submit(
 | 
			
		||||
               ammo_group: @create_attrs |> Map.put(:multiplier, @ammo_group_create_limit + 1)
 | 
			
		||||
             ) =~
 | 
			
		||||
               "Invalid number of copies, must be between 1 and #{@ammo_group_create_limit}. Was #{@ammo_group_create_limit + 1}"
 | 
			
		||||
             |> form("#pack-form")
 | 
			
		||||
             |> render_submit(pack: @create_attrs |> Map.put(:multiplier, @pack_create_limit + 1)) =~
 | 
			
		||||
               "Invalid number of copies, must be between 1 and #{@pack_create_limit}. Was #{@pack_create_limit + 1}"
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    test "updates ammo_group in listing", %{conn: conn, ammo_group: ammo_group} do
 | 
			
		||||
      {:ok, index_live, _html} = live(conn, Routes.ammo_group_index_path(conn, :index))
 | 
			
		||||
    test "updates pack in listing", %{conn: conn, pack: pack} do
 | 
			
		||||
      {:ok, index_live, _html} = live(conn, Routes.pack_index_path(conn, :index))
 | 
			
		||||
 | 
			
		||||
      assert index_live
 | 
			
		||||
             |> element(~s/a[aria-label="Edit ammo group of #{ammo_group.count} bullets"]/)
 | 
			
		||||
             |> element(~s/a[aria-label="Edit ammo group of #{pack.count} bullets"]/)
 | 
			
		||||
             |> render_click() =~ "Edit ammo"
 | 
			
		||||
 | 
			
		||||
      assert_patch(index_live, Routes.ammo_group_index_path(conn, :edit, ammo_group))
 | 
			
		||||
      assert_patch(index_live, Routes.pack_index_path(conn, :edit, pack))
 | 
			
		||||
 | 
			
		||||
      assert index_live
 | 
			
		||||
             |> form("#ammo_group-form")
 | 
			
		||||
             |> render_change(ammo_group: @invalid_attrs) =~ "can't be blank"
 | 
			
		||||
             |> form("#pack-form")
 | 
			
		||||
             |> render_change(pack: @invalid_attrs) =~ "can't be blank"
 | 
			
		||||
 | 
			
		||||
      {:ok, _view, html} =
 | 
			
		||||
        index_live
 | 
			
		||||
        |> form("#ammo_group-form")
 | 
			
		||||
        |> render_submit(ammo_group: @update_attrs)
 | 
			
		||||
        |> follow_redirect(conn, Routes.ammo_group_index_path(conn, :index))
 | 
			
		||||
        |> form("#pack-form")
 | 
			
		||||
        |> render_submit(pack: @update_attrs)
 | 
			
		||||
        |> follow_redirect(conn, Routes.pack_index_path(conn, :index))
 | 
			
		||||
 | 
			
		||||
      assert html =~ "Ammo updated successfully"
 | 
			
		||||
      assert html =~ "\n43\n"
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    test "clones ammo_group in listing", %{conn: conn, ammo_group: ammo_group} do
 | 
			
		||||
      {:ok, index_live, _html} = live(conn, Routes.ammo_group_index_path(conn, :index))
 | 
			
		||||
    test "clones pack in listing", %{conn: conn, pack: pack} do
 | 
			
		||||
      {:ok, index_live, _html} = live(conn, Routes.pack_index_path(conn, :index))
 | 
			
		||||
 | 
			
		||||
      html =
 | 
			
		||||
        index_live
 | 
			
		||||
        |> element(~s/a[aria-label="Clone ammo group of #{ammo_group.count} bullets"]/)
 | 
			
		||||
        |> element(~s/a[aria-label="Clone ammo group of #{pack.count} bullets"]/)
 | 
			
		||||
        |> render_click()
 | 
			
		||||
 | 
			
		||||
      assert html =~ "Add Ammo"
 | 
			
		||||
      assert html =~ "$#{display_currency(120.5)}"
 | 
			
		||||
 | 
			
		||||
      assert_patch(index_live, Routes.ammo_group_index_path(conn, :clone, ammo_group))
 | 
			
		||||
      assert_patch(index_live, Routes.pack_index_path(conn, :clone, pack))
 | 
			
		||||
 | 
			
		||||
      {:ok, _index_live, html} =
 | 
			
		||||
        index_live
 | 
			
		||||
        |> form("#ammo_group-form")
 | 
			
		||||
        |> form("#pack-form")
 | 
			
		||||
        |> render_submit()
 | 
			
		||||
        |> follow_redirect(conn, Routes.ammo_group_index_path(conn, :index))
 | 
			
		||||
        |> follow_redirect(conn, Routes.pack_index_path(conn, :index))
 | 
			
		||||
 | 
			
		||||
      assert html =~ "Ammo added successfully"
 | 
			
		||||
      assert html =~ "\n42\n"
 | 
			
		||||
      assert html =~ "$#{display_currency(120.5)}"
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    test "checks validity when cloning", %{conn: conn, ammo_group: ammo_group} do
 | 
			
		||||
      {:ok, index_live, _html} = live(conn, Routes.ammo_group_index_path(conn, :index))
 | 
			
		||||
    test "checks validity when cloning", %{conn: conn, pack: pack} do
 | 
			
		||||
      {:ok, index_live, _html} = live(conn, Routes.pack_index_path(conn, :index))
 | 
			
		||||
 | 
			
		||||
      html =
 | 
			
		||||
        index_live
 | 
			
		||||
        |> element(~s/a[aria-label="Clone ammo group of #{ammo_group.count} bullets"]/)
 | 
			
		||||
        |> element(~s/a[aria-label="Clone ammo group of #{pack.count} bullets"]/)
 | 
			
		||||
        |> render_click()
 | 
			
		||||
 | 
			
		||||
      assert html =~ "Add Ammo"
 | 
			
		||||
      assert html =~ "$#{display_currency(120.5)}"
 | 
			
		||||
 | 
			
		||||
      assert_patch(index_live, Routes.ammo_group_index_path(conn, :clone, ammo_group))
 | 
			
		||||
      assert_patch(index_live, Routes.pack_index_path(conn, :clone, pack))
 | 
			
		||||
 | 
			
		||||
      assert index_live
 | 
			
		||||
             |> form("#ammo_group-form")
 | 
			
		||||
             |> render_change(ammo_group: @invalid_attrs) =~ "can't be blank"
 | 
			
		||||
             |> form("#pack-form")
 | 
			
		||||
             |> render_change(pack: @invalid_attrs) =~ "can't be blank"
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    test "clones ammo_group in listing with updates", %{conn: conn, ammo_group: ammo_group} do
 | 
			
		||||
      {:ok, index_live, _html} = live(conn, Routes.ammo_group_index_path(conn, :index))
 | 
			
		||||
    test "clones pack in listing with updates", %{conn: conn, pack: pack} do
 | 
			
		||||
      {:ok, index_live, _html} = live(conn, Routes.pack_index_path(conn, :index))
 | 
			
		||||
 | 
			
		||||
      html =
 | 
			
		||||
        index_live
 | 
			
		||||
        |> element(~s/a[aria-label="Clone ammo group of #{ammo_group.count} bullets"]/)
 | 
			
		||||
        |> element(~s/a[aria-label="Clone ammo group of #{pack.count} bullets"]/)
 | 
			
		||||
        |> render_click()
 | 
			
		||||
 | 
			
		||||
      assert html =~ "Add Ammo"
 | 
			
		||||
      assert html =~ "$#{display_currency(120.5)}"
 | 
			
		||||
      assert_patch(index_live, Routes.ammo_group_index_path(conn, :clone, ammo_group))
 | 
			
		||||
      assert_patch(index_live, Routes.pack_index_path(conn, :clone, pack))
 | 
			
		||||
 | 
			
		||||
      assert index_live
 | 
			
		||||
             |> form("#ammo_group-form")
 | 
			
		||||
             |> render_change(ammo_group: @invalid_attrs) =~ "can't be blank"
 | 
			
		||||
             |> form("#pack-form")
 | 
			
		||||
             |> render_change(pack: @invalid_attrs) =~ "can't be blank"
 | 
			
		||||
 | 
			
		||||
      {:ok, _view, html} =
 | 
			
		||||
        index_live
 | 
			
		||||
        |> form("#ammo_group-form")
 | 
			
		||||
        |> render_submit(ammo_group: @create_attrs |> Map.put(:count, 43))
 | 
			
		||||
        |> follow_redirect(conn, Routes.ammo_group_index_path(conn, :index))
 | 
			
		||||
        |> form("#pack-form")
 | 
			
		||||
        |> render_submit(pack: @create_attrs |> Map.put(:count, 43))
 | 
			
		||||
        |> follow_redirect(conn, Routes.pack_index_path(conn, :index))
 | 
			
		||||
 | 
			
		||||
      assert html =~ "Ammo added successfully"
 | 
			
		||||
      assert html =~ "\n43\n"
 | 
			
		||||
      assert html =~ "$#{display_currency(120.5)}"
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    test "deletes ammo_group in listing", %{conn: conn, ammo_group: ammo_group} do
 | 
			
		||||
      {:ok, index_live, _html} = live(conn, Routes.ammo_group_index_path(conn, :index))
 | 
			
		||||
    test "deletes pack in listing", %{conn: conn, pack: pack} do
 | 
			
		||||
      {:ok, index_live, _html} = live(conn, Routes.pack_index_path(conn, :index))
 | 
			
		||||
 | 
			
		||||
      assert index_live
 | 
			
		||||
             |> element(~s/a[aria-label="Delete ammo group of #{ammo_group.count} bullets"]/)
 | 
			
		||||
             |> element(~s/a[aria-label="Delete ammo group of #{pack.count} bullets"]/)
 | 
			
		||||
             |> render_click()
 | 
			
		||||
 | 
			
		||||
      refute has_element?(index_live, "#ammo_group-#{ammo_group.id}")
 | 
			
		||||
      refute has_element?(index_live, "#pack-#{pack.id}")
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    test "saves new shot_group", %{conn: conn, ammo_group: ammo_group} do
 | 
			
		||||
      {:ok, index_live, _html} = live(conn, Routes.ammo_group_index_path(conn, :index))
 | 
			
		||||
    test "saves new shot_group", %{conn: conn, pack: pack} do
 | 
			
		||||
      {:ok, index_live, _html} = live(conn, Routes.pack_index_path(conn, :index))
 | 
			
		||||
 | 
			
		||||
      assert index_live |> element("a", "Record shots") |> render_click() =~ "Record shots"
 | 
			
		||||
      assert_patch(index_live, Routes.ammo_group_index_path(conn, :add_shot_group, ammo_group))
 | 
			
		||||
      assert_patch(index_live, Routes.pack_index_path(conn, :add_shot_group, pack))
 | 
			
		||||
 | 
			
		||||
      assert index_live
 | 
			
		||||
             |> form("#shot-group-form")
 | 
			
		||||
@@ -327,7 +325,7 @@ defmodule CanneryWeb.AmmoGroupLiveTest do
 | 
			
		||||
        index_live
 | 
			
		||||
        |> form("#shot-group-form")
 | 
			
		||||
        |> render_submit(shot_group: @shot_group_create_attrs)
 | 
			
		||||
        |> follow_redirect(conn, Routes.ammo_group_index_path(conn, :index))
 | 
			
		||||
        |> follow_redirect(conn, Routes.pack_index_path(conn, :index))
 | 
			
		||||
 | 
			
		||||
      assert html =~ "Shots recorded successfully"
 | 
			
		||||
    end
 | 
			
		||||
@@ -337,19 +335,19 @@ defmodule CanneryWeb.AmmoGroupLiveTest do
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  describe "Index of empty ammo group" do
 | 
			
		||||
    setup [:register_and_log_in_user, :create_ammo_group, :create_empty_ammo_group]
 | 
			
		||||
    setup [:register_and_log_in_user, :create_pack, :create_empty_pack]
 | 
			
		||||
 | 
			
		||||
    test "hides empty ammo groups by default", %{
 | 
			
		||||
      conn: conn,
 | 
			
		||||
      empty_ammo_group: ammo_group,
 | 
			
		||||
      empty_pack: pack,
 | 
			
		||||
      current_user: current_user
 | 
			
		||||
    } do
 | 
			
		||||
      {:ok, show_live, html} = live(conn, Routes.ammo_group_index_path(conn, :index))
 | 
			
		||||
      {:ok, show_live, html} = live(conn, Routes.pack_index_path(conn, :index))
 | 
			
		||||
 | 
			
		||||
      assert html =~ "Show used"
 | 
			
		||||
      refute html =~ "$#{display_currency(50.00)}"
 | 
			
		||||
 | 
			
		||||
      percentage = ammo_group |> Ammo.get_percentage_remaining(current_user)
 | 
			
		||||
      percentage = pack |> Ammo.get_percentage_remaining(current_user)
 | 
			
		||||
      refute html =~ "\n#{"#{percentage}%"}\n"
 | 
			
		||||
 | 
			
		||||
      html =
 | 
			
		||||
@@ -358,49 +356,49 @@ defmodule CanneryWeb.AmmoGroupLiveTest do
 | 
			
		||||
        |> render_click()
 | 
			
		||||
 | 
			
		||||
      assert html =~ "$#{display_currency(50.00)}"
 | 
			
		||||
      percentage = ammo_group |> Ammo.get_percentage_remaining(current_user)
 | 
			
		||||
      percentage = pack |> Ammo.get_percentage_remaining(current_user)
 | 
			
		||||
      assert html =~ "\n#{"#{percentage}%"}\n"
 | 
			
		||||
    end
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  describe "Show ammo group" do
 | 
			
		||||
    setup [:register_and_log_in_user, :create_ammo_group]
 | 
			
		||||
    setup [:register_and_log_in_user, :create_pack]
 | 
			
		||||
 | 
			
		||||
    test "displays ammo_group", %{conn: conn, ammo_group: ammo_group} do
 | 
			
		||||
      {:ok, _show_live, html} = live(conn, Routes.ammo_group_show_path(conn, :show, ammo_group))
 | 
			
		||||
      ammo_group = ammo_group |> Repo.preload(:ammo_type)
 | 
			
		||||
    test "displays pack", %{conn: conn, pack: pack} do
 | 
			
		||||
      {:ok, _show_live, html} = live(conn, Routes.pack_show_path(conn, :show, pack))
 | 
			
		||||
      pack = pack |> Repo.preload(:ammo_type)
 | 
			
		||||
      assert html =~ "Show Ammo"
 | 
			
		||||
      assert html =~ ammo_group.ammo_type.name
 | 
			
		||||
      assert html =~ pack.ammo_type.name
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    test "updates ammo_group within modal", %{conn: conn, ammo_group: ammo_group} do
 | 
			
		||||
      {:ok, show_live, _html} = live(conn, Routes.ammo_group_show_path(conn, :show, ammo_group))
 | 
			
		||||
    test "updates pack within modal", %{conn: conn, pack: pack} do
 | 
			
		||||
      {:ok, show_live, _html} = live(conn, Routes.pack_show_path(conn, :show, pack))
 | 
			
		||||
 | 
			
		||||
      assert show_live
 | 
			
		||||
             |> element(~s/a[aria-label="Edit ammo group of #{ammo_group.count} bullets"]/)
 | 
			
		||||
             |> element(~s/a[aria-label="Edit ammo group of #{pack.count} bullets"]/)
 | 
			
		||||
             |> render_click() =~ "Edit Ammo"
 | 
			
		||||
 | 
			
		||||
      assert_patch(show_live, Routes.ammo_group_show_path(conn, :edit, ammo_group))
 | 
			
		||||
      assert_patch(show_live, Routes.pack_show_path(conn, :edit, pack))
 | 
			
		||||
 | 
			
		||||
      assert show_live
 | 
			
		||||
             |> form("#ammo_group-form")
 | 
			
		||||
             |> render_change(ammo_group: @invalid_attrs) =~ "can't be blank"
 | 
			
		||||
             |> form("#pack-form")
 | 
			
		||||
             |> render_change(pack: @invalid_attrs) =~ "can't be blank"
 | 
			
		||||
 | 
			
		||||
      {:ok, _view, html} =
 | 
			
		||||
        show_live
 | 
			
		||||
        |> form("#ammo_group-form")
 | 
			
		||||
        |> render_submit(ammo_group: @update_attrs)
 | 
			
		||||
        |> follow_redirect(conn, Routes.ammo_group_show_path(conn, :show, ammo_group))
 | 
			
		||||
        |> form("#pack-form")
 | 
			
		||||
        |> render_submit(pack: @update_attrs)
 | 
			
		||||
        |> follow_redirect(conn, Routes.pack_show_path(conn, :show, pack))
 | 
			
		||||
 | 
			
		||||
      assert html =~ "Ammo updated successfully"
 | 
			
		||||
      assert html =~ "some updated notes"
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    test "saves new shot_group", %{conn: conn, ammo_group: ammo_group} do
 | 
			
		||||
      {:ok, index_live, _html} = live(conn, Routes.ammo_group_show_path(conn, :show, ammo_group))
 | 
			
		||||
    test "saves new shot_group", %{conn: conn, pack: pack} do
 | 
			
		||||
      {:ok, index_live, _html} = live(conn, Routes.pack_show_path(conn, :show, pack))
 | 
			
		||||
 | 
			
		||||
      assert index_live |> element("a", "Record shots") |> render_click() =~ "Record shots"
 | 
			
		||||
      assert_patch(index_live, Routes.ammo_group_show_path(conn, :add_shot_group, ammo_group))
 | 
			
		||||
      assert_patch(index_live, Routes.pack_show_path(conn, :add_shot_group, pack))
 | 
			
		||||
 | 
			
		||||
      assert index_live
 | 
			
		||||
             |> form("#shot-group-form")
 | 
			
		||||
@@ -410,18 +408,18 @@ defmodule CanneryWeb.AmmoGroupLiveTest do
 | 
			
		||||
        index_live
 | 
			
		||||
        |> form("#shot-group-form")
 | 
			
		||||
        |> render_submit(shot_group: @shot_group_create_attrs)
 | 
			
		||||
        |> follow_redirect(conn, Routes.ammo_group_show_path(conn, :show, ammo_group))
 | 
			
		||||
        |> follow_redirect(conn, Routes.pack_show_path(conn, :show, pack))
 | 
			
		||||
 | 
			
		||||
      assert html =~ "Shots recorded successfully"
 | 
			
		||||
    end
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  describe "Show ammo group with shot group" do
 | 
			
		||||
    setup [:register_and_log_in_user, :create_ammo_group, :create_shot_group]
 | 
			
		||||
    setup [:register_and_log_in_user, :create_pack, :create_shot_group]
 | 
			
		||||
 | 
			
		||||
    test "updates shot_group in listing",
 | 
			
		||||
         %{conn: conn, ammo_group: ammo_group, shot_group: shot_group} do
 | 
			
		||||
      {:ok, index_live, _html} = live(conn, Routes.ammo_group_show_path(conn, :edit, ammo_group))
 | 
			
		||||
         %{conn: conn, pack: pack, shot_group: shot_group} do
 | 
			
		||||
      {:ok, index_live, _html} = live(conn, Routes.pack_show_path(conn, :edit, pack))
 | 
			
		||||
 | 
			
		||||
      assert index_live
 | 
			
		||||
             |> element(~s/a[aria-label="Edit shot group of #{shot_group.count} shots"]/)
 | 
			
		||||
@@ -429,7 +427,7 @@ defmodule CanneryWeb.AmmoGroupLiveTest do
 | 
			
		||||
 | 
			
		||||
      assert_patch(
 | 
			
		||||
        index_live,
 | 
			
		||||
        Routes.ammo_group_show_path(conn, :edit_shot_group, ammo_group, shot_group)
 | 
			
		||||
        Routes.pack_show_path(conn, :edit_shot_group, pack, shot_group)
 | 
			
		||||
      )
 | 
			
		||||
 | 
			
		||||
      assert index_live
 | 
			
		||||
@@ -440,16 +438,16 @@ defmodule CanneryWeb.AmmoGroupLiveTest do
 | 
			
		||||
        index_live
 | 
			
		||||
        |> form("#shot-group-form")
 | 
			
		||||
        |> render_submit(shot_group: @shot_group_update_attrs)
 | 
			
		||||
        |> follow_redirect(conn, Routes.ammo_group_show_path(conn, :show, ammo_group))
 | 
			
		||||
        |> follow_redirect(conn, Routes.pack_show_path(conn, :show, pack))
 | 
			
		||||
 | 
			
		||||
      assert html =~ "Shot records updated successfully"
 | 
			
		||||
      assert html =~ "some updated notes"
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    test "deletes shot_group in listing",
 | 
			
		||||
         %{conn: conn, ammo_group: ammo_group, shot_group: shot_group} do
 | 
			
		||||
         %{conn: conn, pack: pack, shot_group: shot_group} do
 | 
			
		||||
      {:ok, index_live, _html} =
 | 
			
		||||
        live(conn, Routes.ammo_group_show_path(conn, :edit_shot_group, ammo_group, shot_group))
 | 
			
		||||
        live(conn, Routes.pack_show_path(conn, :edit_shot_group, pack, shot_group))
 | 
			
		||||
 | 
			
		||||
      assert index_live
 | 
			
		||||
             |> element(~s/a[aria-label="Delete shot record of #{shot_group.count} shots"]/)
 | 
			
		||||
 
 | 
			
		||||
@@ -33,7 +33,7 @@ defmodule CanneryWeb.AmmoTypeLiveTest do
 | 
			
		||||
    name: nil,
 | 
			
		||||
    grains: nil
 | 
			
		||||
  }
 | 
			
		||||
  @ammo_group_attrs %{
 | 
			
		||||
  @pack_attrs %{
 | 
			
		||||
    notes: "some ammo group",
 | 
			
		||||
    count: 20
 | 
			
		||||
  }
 | 
			
		||||
@@ -46,18 +46,18 @@ defmodule CanneryWeb.AmmoTypeLiveTest do
 | 
			
		||||
    [ammo_type: ammo_type_fixture(@create_attrs, current_user)]
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  defp create_ammo_group(%{ammo_type: ammo_type, current_user: current_user}) do
 | 
			
		||||
  defp create_pack(%{ammo_type: ammo_type, current_user: current_user}) do
 | 
			
		||||
    container = container_fixture(current_user)
 | 
			
		||||
    {1, [ammo_group]} = ammo_group_fixture(@ammo_group_attrs, ammo_type, container, current_user)
 | 
			
		||||
    [ammo_group: ammo_group, container: container]
 | 
			
		||||
    {1, [pack]} = pack_fixture(@pack_attrs, ammo_type, container, current_user)
 | 
			
		||||
    [pack: pack, container: container]
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  defp create_empty_ammo_group(%{ammo_type: ammo_type, current_user: current_user}) do
 | 
			
		||||
  defp create_empty_pack(%{ammo_type: ammo_type, current_user: current_user}) do
 | 
			
		||||
    container = container_fixture(current_user)
 | 
			
		||||
    {1, [ammo_group]} = ammo_group_fixture(@ammo_group_attrs, ammo_type, container, current_user)
 | 
			
		||||
    shot_group = shot_group_fixture(@shot_group_attrs, current_user, ammo_group)
 | 
			
		||||
    ammo_group = ammo_group |> Repo.reload!()
 | 
			
		||||
    [ammo_group: ammo_group, container: container, shot_group: shot_group]
 | 
			
		||||
    {1, [pack]} = pack_fixture(@pack_attrs, ammo_type, container, current_user)
 | 
			
		||||
    shot_group = shot_group_fixture(@shot_group_attrs, current_user, pack)
 | 
			
		||||
    pack = pack |> Repo.reload!()
 | 
			
		||||
    [pack: pack, container: container, shot_group: shot_group]
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  describe "Index" do
 | 
			
		||||
@@ -249,10 +249,10 @@ defmodule CanneryWeb.AmmoTypeLiveTest do
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  describe "Index with ammo group" do
 | 
			
		||||
    setup [:register_and_log_in_user, :create_ammo_type, :create_ammo_group]
 | 
			
		||||
    setup [:register_and_log_in_user, :create_ammo_type, :create_pack]
 | 
			
		||||
 | 
			
		||||
    test "shows used ammo groups on toggle",
 | 
			
		||||
         %{conn: conn, ammo_group: ammo_group, current_user: current_user} do
 | 
			
		||||
         %{conn: conn, pack: pack, current_user: current_user} do
 | 
			
		||||
      {:ok, index_live, html} = live(conn, Routes.ammo_type_index_path(conn, :index))
 | 
			
		||||
 | 
			
		||||
      assert html =~ "Show used"
 | 
			
		||||
@@ -275,7 +275,7 @@ defmodule CanneryWeb.AmmoTypeLiveTest do
 | 
			
		||||
      assert html =~ "\n0\n"
 | 
			
		||||
      assert html =~ "\n1\n"
 | 
			
		||||
 | 
			
		||||
      shot_group_fixture(%{count: 5}, current_user, ammo_group)
 | 
			
		||||
      shot_group_fixture(%{count: 5}, current_user, pack)
 | 
			
		||||
 | 
			
		||||
      {:ok, index_live, _html} = live(conn, Routes.ammo_type_index_path(conn, :index))
 | 
			
		||||
 | 
			
		||||
@@ -328,7 +328,7 @@ defmodule CanneryWeb.AmmoTypeLiveTest do
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  describe "Show ammo type with ammo group" do
 | 
			
		||||
    setup [:register_and_log_in_user, :create_ammo_type, :create_ammo_group]
 | 
			
		||||
    setup [:register_and_log_in_user, :create_ammo_type, :create_pack]
 | 
			
		||||
 | 
			
		||||
    test "displays ammo group", %{
 | 
			
		||||
      conn: conn,
 | 
			
		||||
@@ -357,7 +357,7 @@ defmodule CanneryWeb.AmmoTypeLiveTest do
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  describe "Show ammo type with empty ammo group" do
 | 
			
		||||
    setup [:register_and_log_in_user, :create_ammo_type, :create_empty_ammo_group]
 | 
			
		||||
    setup [:register_and_log_in_user, :create_ammo_type, :create_empty_pack]
 | 
			
		||||
 | 
			
		||||
    test "displays empty ammo groups on toggle",
 | 
			
		||||
         %{conn: conn, ammo_type: ammo_type, container: %{name: container_name}} do
 | 
			
		||||
 
 | 
			
		||||
@@ -30,7 +30,7 @@ defmodule CanneryWeb.ContainerLiveTest do
 | 
			
		||||
    name: "some name",
 | 
			
		||||
    grains: 120
 | 
			
		||||
  }
 | 
			
		||||
  @ammo_group_attrs %{
 | 
			
		||||
  @pack_attrs %{
 | 
			
		||||
    notes: "some ammo group",
 | 
			
		||||
    count: 20
 | 
			
		||||
  }
 | 
			
		||||
@@ -40,11 +40,11 @@ defmodule CanneryWeb.ContainerLiveTest do
 | 
			
		||||
    [container: container]
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  defp create_ammo_group(%{container: container, current_user: current_user}) do
 | 
			
		||||
  defp create_pack(%{container: container, current_user: current_user}) do
 | 
			
		||||
    ammo_type = ammo_type_fixture(@ammo_type_attrs, current_user)
 | 
			
		||||
    {1, [ammo_group]} = ammo_group_fixture(@ammo_group_attrs, ammo_type, container, current_user)
 | 
			
		||||
    {1, [pack]} = pack_fixture(@pack_attrs, ammo_type, container, current_user)
 | 
			
		||||
 | 
			
		||||
    [ammo_type: ammo_type, ammo_group: ammo_group]
 | 
			
		||||
    [ammo_type: ammo_type, pack: pack]
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  describe "Index" do
 | 
			
		||||
@@ -246,60 +246,60 @@ defmodule CanneryWeb.ContainerLiveTest do
 | 
			
		||||
    test "can sort by type",
 | 
			
		||||
         %{conn: conn, container: container, current_user: current_user} do
 | 
			
		||||
      rifle_type = ammo_type_fixture(%{class: :rifle}, current_user)
 | 
			
		||||
      {1, [rifle_ammo_group]} = ammo_group_fixture(rifle_type, container, current_user)
 | 
			
		||||
      {1, [rifle_pack]} = pack_fixture(rifle_type, container, current_user)
 | 
			
		||||
      shotgun_type = ammo_type_fixture(%{class: :shotgun}, current_user)
 | 
			
		||||
      {1, [shotgun_ammo_group]} = ammo_group_fixture(shotgun_type, container, current_user)
 | 
			
		||||
      {1, [shotgun_pack]} = pack_fixture(shotgun_type, container, current_user)
 | 
			
		||||
      pistol_type = ammo_type_fixture(%{class: :pistol}, current_user)
 | 
			
		||||
      {1, [pistol_ammo_group]} = ammo_group_fixture(pistol_type, container, current_user)
 | 
			
		||||
      {1, [pistol_pack]} = pack_fixture(pistol_type, container, current_user)
 | 
			
		||||
 | 
			
		||||
      {:ok, index_live, html} = live(conn, Routes.container_show_path(conn, :show, container))
 | 
			
		||||
 | 
			
		||||
      assert html =~ "All"
 | 
			
		||||
 | 
			
		||||
      assert html =~ rifle_ammo_group.ammo_type.name
 | 
			
		||||
      assert html =~ shotgun_ammo_group.ammo_type.name
 | 
			
		||||
      assert html =~ pistol_ammo_group.ammo_type.name
 | 
			
		||||
      assert html =~ rifle_pack.ammo_type.name
 | 
			
		||||
      assert html =~ shotgun_pack.ammo_type.name
 | 
			
		||||
      assert html =~ pistol_pack.ammo_type.name
 | 
			
		||||
 | 
			
		||||
      html =
 | 
			
		||||
        index_live
 | 
			
		||||
        |> form(~s/form[phx-change="change_class"]/)
 | 
			
		||||
        |> render_change(ammo_type: %{class: :rifle})
 | 
			
		||||
 | 
			
		||||
      assert html =~ rifle_ammo_group.ammo_type.name
 | 
			
		||||
      refute html =~ shotgun_ammo_group.ammo_type.name
 | 
			
		||||
      refute html =~ pistol_ammo_group.ammo_type.name
 | 
			
		||||
      assert html =~ rifle_pack.ammo_type.name
 | 
			
		||||
      refute html =~ shotgun_pack.ammo_type.name
 | 
			
		||||
      refute html =~ pistol_pack.ammo_type.name
 | 
			
		||||
 | 
			
		||||
      html =
 | 
			
		||||
        index_live
 | 
			
		||||
        |> form(~s/form[phx-change="change_class"]/)
 | 
			
		||||
        |> render_change(ammo_type: %{class: :shotgun})
 | 
			
		||||
 | 
			
		||||
      refute html =~ rifle_ammo_group.ammo_type.name
 | 
			
		||||
      assert html =~ shotgun_ammo_group.ammo_type.name
 | 
			
		||||
      refute html =~ pistol_ammo_group.ammo_type.name
 | 
			
		||||
      refute html =~ rifle_pack.ammo_type.name
 | 
			
		||||
      assert html =~ shotgun_pack.ammo_type.name
 | 
			
		||||
      refute html =~ pistol_pack.ammo_type.name
 | 
			
		||||
 | 
			
		||||
      html =
 | 
			
		||||
        index_live
 | 
			
		||||
        |> form(~s/form[phx-change="change_class"]/)
 | 
			
		||||
        |> render_change(ammo_type: %{class: :pistol})
 | 
			
		||||
 | 
			
		||||
      refute html =~ rifle_ammo_group.ammo_type.name
 | 
			
		||||
      refute html =~ shotgun_ammo_group.ammo_type.name
 | 
			
		||||
      assert html =~ pistol_ammo_group.ammo_type.name
 | 
			
		||||
      refute html =~ rifle_pack.ammo_type.name
 | 
			
		||||
      refute html =~ shotgun_pack.ammo_type.name
 | 
			
		||||
      assert html =~ pistol_pack.ammo_type.name
 | 
			
		||||
 | 
			
		||||
      html =
 | 
			
		||||
        index_live
 | 
			
		||||
        |> form(~s/form[phx-change="change_class"]/)
 | 
			
		||||
        |> render_change(ammo_type: %{class: :all})
 | 
			
		||||
 | 
			
		||||
      assert html =~ rifle_ammo_group.ammo_type.name
 | 
			
		||||
      assert html =~ shotgun_ammo_group.ammo_type.name
 | 
			
		||||
      assert html =~ pistol_ammo_group.ammo_type.name
 | 
			
		||||
      assert html =~ rifle_pack.ammo_type.name
 | 
			
		||||
      assert html =~ shotgun_pack.ammo_type.name
 | 
			
		||||
      assert html =~ pistol_pack.ammo_type.name
 | 
			
		||||
    end
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  describe "Show with ammo group" do
 | 
			
		||||
    setup [:register_and_log_in_user, :create_container, :create_ammo_group]
 | 
			
		||||
    setup [:register_and_log_in_user, :create_container, :create_pack]
 | 
			
		||||
 | 
			
		||||
    test "displays ammo group",
 | 
			
		||||
         %{conn: conn, ammo_type: %{name: ammo_type_name}, container: container} do
 | 
			
		||||
 
 | 
			
		||||
@@ -16,16 +16,16 @@ defmodule CanneryWeb.RangeLiveTest do
 | 
			
		||||
    container = container_fixture(%{staged: true}, current_user)
 | 
			
		||||
    ammo_type = ammo_type_fixture(current_user)
 | 
			
		||||
 | 
			
		||||
    {1, [ammo_group]} = ammo_group_fixture(%{staged: true}, ammo_type, container, current_user)
 | 
			
		||||
    {1, [pack]} = pack_fixture(%{staged: true}, ammo_type, container, current_user)
 | 
			
		||||
 | 
			
		||||
    shot_group =
 | 
			
		||||
      %{count: 5, date: ~N[2022-02-13 03:17:00], notes: "some notes"}
 | 
			
		||||
      |> shot_group_fixture(current_user, ammo_group)
 | 
			
		||||
      |> shot_group_fixture(current_user, pack)
 | 
			
		||||
 | 
			
		||||
    [
 | 
			
		||||
      container: container,
 | 
			
		||||
      ammo_type: ammo_type,
 | 
			
		||||
      ammo_group: ammo_group,
 | 
			
		||||
      pack: pack,
 | 
			
		||||
      shot_group: shot_group
 | 
			
		||||
    ]
 | 
			
		||||
  end
 | 
			
		||||
@@ -43,21 +43,19 @@ defmodule CanneryWeb.RangeLiveTest do
 | 
			
		||||
    test "can sort by type",
 | 
			
		||||
         %{conn: conn, container: container, current_user: current_user} do
 | 
			
		||||
      rifle_ammo_type = ammo_type_fixture(%{class: :rifle}, current_user)
 | 
			
		||||
      {1, [rifle_ammo_group]} = ammo_group_fixture(rifle_ammo_type, container, current_user)
 | 
			
		||||
      {1, [rifle_pack]} = pack_fixture(rifle_ammo_type, container, current_user)
 | 
			
		||||
 | 
			
		||||
      rifle_shot_group = shot_group_fixture(%{notes: "group_one"}, current_user, rifle_ammo_group)
 | 
			
		||||
      rifle_shot_group = shot_group_fixture(%{notes: "group_one"}, current_user, rifle_pack)
 | 
			
		||||
 | 
			
		||||
      shotgun_ammo_type = ammo_type_fixture(%{class: :shotgun}, current_user)
 | 
			
		||||
      {1, [shotgun_ammo_group]} = ammo_group_fixture(shotgun_ammo_type, container, current_user)
 | 
			
		||||
      {1, [shotgun_pack]} = pack_fixture(shotgun_ammo_type, container, current_user)
 | 
			
		||||
 | 
			
		||||
      shotgun_shot_group =
 | 
			
		||||
        shot_group_fixture(%{notes: "group_two"}, current_user, shotgun_ammo_group)
 | 
			
		||||
      shotgun_shot_group = shot_group_fixture(%{notes: "group_two"}, current_user, shotgun_pack)
 | 
			
		||||
 | 
			
		||||
      pistol_ammo_type = ammo_type_fixture(%{class: :pistol}, current_user)
 | 
			
		||||
      {1, [pistol_ammo_group]} = ammo_group_fixture(pistol_ammo_type, container, current_user)
 | 
			
		||||
      {1, [pistol_pack]} = pack_fixture(pistol_ammo_type, container, current_user)
 | 
			
		||||
 | 
			
		||||
      pistol_shot_group =
 | 
			
		||||
        shot_group_fixture(%{notes: "group_three"}, current_user, pistol_ammo_group)
 | 
			
		||||
      pistol_shot_group = shot_group_fixture(%{notes: "group_three"}, current_user, pistol_pack)
 | 
			
		||||
 | 
			
		||||
      {:ok, index_live, html} = live(conn, Routes.range_index_path(conn, :index))
 | 
			
		||||
 | 
			
		||||
@@ -128,11 +126,11 @@ defmodule CanneryWeb.RangeLiveTest do
 | 
			
		||||
      assert_patch(index_live, Routes.range_index_path(conn, :index))
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    test "saves new shot_group", %{conn: conn, ammo_group: ammo_group} do
 | 
			
		||||
    test "saves new shot_group", %{conn: conn, pack: pack} do
 | 
			
		||||
      {:ok, index_live, _html} = live(conn, Routes.range_index_path(conn, :index))
 | 
			
		||||
 | 
			
		||||
      assert index_live |> element("a", "Record shots") |> render_click() =~ "Record shots"
 | 
			
		||||
      assert_patch(index_live, Routes.range_index_path(conn, :add_shot_group, ammo_group))
 | 
			
		||||
      assert_patch(index_live, Routes.range_index_path(conn, :add_shot_group, pack))
 | 
			
		||||
 | 
			
		||||
      assert index_live
 | 
			
		||||
             |> form("#shot-group-form")
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user