refactor: improve email copy with MapSet, RFC 5322 commas, and cond
All checks were successful
continuous-integration/drone/push Build is passing
All checks were successful
continuous-integration/drone/push Build is passing
Performance optimization, RFC-compliant separator, better tests
This commit is contained in:
parent
ba78a6ac7a
commit
39d2cb7820
4 changed files with 92 additions and 271 deletions
|
|
@ -348,7 +348,7 @@ defmodule MvWeb.MemberLive.IndexTest do
|
|||
assert render(view) =~ "1"
|
||||
end
|
||||
|
||||
test "copy_emails handles case where selected members are deleted", %{
|
||||
test "copy_emails handles case where selected member is deleted before copy", %{
|
||||
conn: conn,
|
||||
member1: member1
|
||||
} do
|
||||
|
|
@ -360,10 +360,69 @@ defmodule MvWeb.MemberLive.IndexTest do
|
|||
|> element("[phx-click='select_member'][phx-value-id='#{member1.id}']")
|
||||
|> render_click()
|
||||
|
||||
# Click copy button - should work correctly
|
||||
view |> element("#copy-emails-btn") |> render_click()
|
||||
# Delete the member from the database
|
||||
Ash.destroy!(member1)
|
||||
|
||||
# Should show count of actual members found (1)
|
||||
# Trigger copy_emails event directly - selection still contains the deleted ID
|
||||
# but the member is no longer in @members list after reload
|
||||
result = render_hook(view, "copy_emails", %{})
|
||||
|
||||
# Should show error since no visible members match selection
|
||||
assert result =~ "No email" or result =~ "Keine E-Mail" or result =~ "0"
|
||||
end
|
||||
|
||||
test "copy_emails formats emails as RFC 5322 compliant comma-separated list", %{
|
||||
conn: conn,
|
||||
member1: member1,
|
||||
member2: member2
|
||||
} do
|
||||
conn = conn_with_oidc_user(conn)
|
||||
{:ok, view, _html} = live(conn, "/members")
|
||||
|
||||
# Select two members
|
||||
view
|
||||
|> element("[phx-click='select_member'][phx-value-id='#{member1.id}']")
|
||||
|> render_click()
|
||||
|
||||
view
|
||||
|> element("[phx-click='select_member'][phx-value-id='#{member2.id}']")
|
||||
|> render_click()
|
||||
|
||||
# Get the socket state to verify the formatted email string
|
||||
state = :sys.get_state(view.pid)
|
||||
selected_members = state.socket.assigns.selected_members
|
||||
|
||||
# Verify MapSet is used
|
||||
assert %MapSet{} = selected_members
|
||||
assert MapSet.size(selected_members) == 2
|
||||
end
|
||||
|
||||
test "email format is 'First Last <email>' with comma separator", %{
|
||||
conn: conn,
|
||||
member1: _member1
|
||||
} do
|
||||
# Test the format_member_email function indirectly
|
||||
# by checking the push_event payload structure
|
||||
conn = conn_with_oidc_user(conn)
|
||||
|
||||
# Create a member with known data
|
||||
{:ok, test_member} =
|
||||
Mv.Membership.create_member(%{
|
||||
first_name: "Test",
|
||||
last_name: "Format",
|
||||
email: "test.format@example.com"
|
||||
})
|
||||
|
||||
{:ok, view, _html} = live(conn, "/members")
|
||||
|
||||
# Select the test member
|
||||
view
|
||||
|> element("[phx-click='select_member'][phx-value-id='#{test_member.id}']")
|
||||
|> render_click()
|
||||
|
||||
# The format should be "Test Format <test.format@example.com>"
|
||||
# We verify this by checking the flash shows 1 email was copied
|
||||
view |> element("#copy-emails-btn") |> render_click()
|
||||
assert render(view) =~ "1"
|
||||
end
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue