Files
sure/test/controllers/invitations_controller_test.rb
Juan José Mata 705b5a8b26 First cut of a simplified "intro" UI layout (#265)
* First cut of a simplified "intro" UI layout

* Linter

* Add guest role and intro-only access

* Fix guest role UI defaults (#940)

Use enum predicate to avoid missing role helper.

* Remove legacy user role mapping (#941)

Drop the unused user role references in role normalization
and SSO role mapping forms to avoid implying a role that
never existed.

Refs: #0

* Remove role normalization (#942)

Remove role normalization

Roles are now stored directly without legacy mappings.

* Revert role mapping logic

* Remove `normalize_role_settings`

* Remove unnecessary migration

* Make `member` the default

* Broken `.erb`

---------

Signed-off-by: Juan José Mata <juanjo.mata@gmail.com>
2026-02-09 11:09:25 +01:00

189 lines
5.5 KiB
Ruby

require "test_helper"
class InvitationsControllerTest < ActionDispatch::IntegrationTest
setup do
sign_in @admin = users(:family_admin)
@invitation = invitations(:one)
end
test "should get new" do
get new_invitation_url
assert_response :success
assert_select "option[value=?]", "member"
assert_select "option[value=?]", "guest"
assert_select "option[value=?]", "admin"
end
test "should create invitation for member" do
Rails.application.config.stubs(:app_mode).returns("managed".inquiry)
assert_difference("Invitation.count") do
assert_enqueued_with(job: ActionMailer::MailDeliveryJob) do
post invitations_url, params: {
invitation: {
email: "new@example.com",
role: "member"
}
}
end
end
invitation = Invitation.order(created_at: :desc).first
assert_equal "member", invitation.role
assert_equal @admin, invitation.inviter
assert_equal "new@example.com", invitation.email
assert_redirected_to settings_profile_path
assert_equal I18n.t("invitations.create.success"), flash[:notice]
end
test "should add existing user to household when inviting their email" do
existing_user = users(:empty)
assert existing_user.family_id != @admin.family_id
assert_difference("Invitation.count") do
assert_no_enqueued_jobs only: ActionMailer::MailDeliveryJob do
post invitations_url, params: {
invitation: {
email: existing_user.email,
role: "member"
}
}
end
end
invitation = Invitation.order(created_at: :desc).first
assert invitation.accepted_at.present?, "Invitation should be accepted"
existing_user.reload
assert_equal @admin.family_id, existing_user.family_id
assert_equal "member", existing_user.role
assert_redirected_to settings_profile_path
assert_equal I18n.t("invitations.create.existing_user_added"), flash[:notice]
end
test "non-admin cannot create invitations" do
sign_in users(:family_member)
assert_no_difference("Invitation.count") do
post invitations_url, params: {
invitation: {
email: "new@example.com",
role: "admin"
}
}
end
assert_redirected_to settings_profile_path
assert_equal I18n.t("invitations.create.failure"), flash[:alert]
end
test "admin can create admin invitation" do
assert_difference("Invitation.count") do
post invitations_url, params: {
invitation: {
email: "new@example.com",
role: "admin"
}
}
end
invitation = Invitation.order(created_at: :desc).first
assert_equal "admin", invitation.role
assert_equal @admin.family, invitation.family
assert_equal @admin, invitation.inviter
end
test "admin can create guest invitation" do
assert_difference("Invitation.count") do
post invitations_url, params: {
invitation: {
email: "intro-invite@example.com",
role: "guest"
}
}
end
invitation = Invitation.order(created_at: :desc).first
assert_equal "guest", invitation.role
assert_equal @admin.family, invitation.family
assert_equal @admin, invitation.inviter
end
test "inviting an existing user as guest applies intro defaults" do
existing_user = users(:empty)
existing_user.update!(
role: :member,
ui_layout: :dashboard,
show_sidebar: true,
show_ai_sidebar: true,
ai_enabled: false
)
assert_difference("Invitation.count") do
post invitations_url, params: {
invitation: {
email: existing_user.email,
role: "guest"
}
}
end
existing_user.reload
assert_equal "guest", existing_user.role
assert existing_user.ui_layout_intro?
assert_not existing_user.show_sidebar?
assert_not existing_user.show_ai_sidebar?
assert existing_user.ai_enabled?
end
test "should handle invalid invitation creation" do
assert_no_difference("Invitation.count") do
post invitations_url, params: {
invitation: {
email: "",
role: "member"
}
}
end
assert_redirected_to settings_profile_path
assert_equal I18n.t("invitations.create.failure"), flash[:alert]
end
test "should accept invitation and show choice between sign in and create account" do
get accept_invitation_url(@invitation.token)
assert_response :success
assert_select "a[href=?]", new_registration_path(invitation: @invitation.token), text: /Create new account/i
assert_select "a[href=?]", new_session_path(invitation: @invitation.token), text: /already have an account/i
end
test "should not accept invalid invitation token" do
get accept_invitation_url("invalid-token")
assert_response :not_found
end
test "admin can remove pending invitation" do
assert_difference("Invitation.count", -1) do
delete invitation_url(@invitation)
end
assert_redirected_to settings_profile_path
assert_equal I18n.t("invitations.destroy.success"), flash[:notice]
end
test "non-admin cannot remove invitations" do
sign_in users(:family_member)
assert_no_difference("Invitation.count") do
delete invitation_url(@invitation)
end
assert_redirected_to settings_profile_path
assert_equal I18n.t("invitations.destroy.not_authorized"), flash[:alert]
end
test "should handle invalid invitation removal" do
delete invitation_url(id: "invalid-id")
assert_response :not_found
end
end