mirror of
https://github.com/maybe-finance/maybe.git
synced 2025-07-22 22:59:39 +02:00
Add ability to delete Maybe account (#698)
* Build out user deactivation and purging workflows * Add i18n translations for user deletion * Add tests for user deletion * Fix lint issue
This commit is contained in:
parent
55cb1ae5bd
commit
19ee773d9b
15 changed files with 128 additions and 8 deletions
|
@ -4,8 +4,39 @@ class Settings::ProfilesControllerTest < ActionDispatch::IntegrationTest
|
|||
setup do
|
||||
sign_in @user = users(:family_admin)
|
||||
end
|
||||
|
||||
test "get" do
|
||||
get settings_profile_url
|
||||
assert_response :success
|
||||
end
|
||||
|
||||
test "member can deactivate their account" do
|
||||
sign_in @member = users(:family_member)
|
||||
delete settings_profile_url
|
||||
|
||||
assert_redirected_to root_url
|
||||
|
||||
assert_not User.find(@member.id).active?
|
||||
assert_enqueued_with(job: UserPurgeJob, args: [ @member ])
|
||||
end
|
||||
|
||||
test "admin prevented from deactivating when other users are present" do
|
||||
sign_in @admin = users(:family_admin)
|
||||
delete settings_profile_url
|
||||
|
||||
assert_redirected_to settings_profile_url
|
||||
assert_no_enqueued_jobs only: UserPurgeJob
|
||||
assert User.find(@admin.id).active?
|
||||
end
|
||||
|
||||
test "admin can deactivate their account when they are the last user in the family" do
|
||||
sign_in @admin = users(:family_admin)
|
||||
users(:family_member).destroy
|
||||
|
||||
delete settings_profile_url
|
||||
|
||||
assert_redirected_to root_url
|
||||
assert_not User.find(@admin.id).active?
|
||||
assert_enqueued_with(job: UserPurgeJob, args: [ @admin ])
|
||||
end
|
||||
end
|
||||
|
|
1
test/fixtures/users.yml
vendored
1
test/fixtures/users.yml
vendored
|
@ -4,6 +4,7 @@ family_admin:
|
|||
last_name: Dylan
|
||||
email: bob@bobdylan.com
|
||||
password_digest: <%= BCrypt::Password.create('password') %>
|
||||
role: admin
|
||||
|
||||
family_member:
|
||||
family: dylan_family
|
||||
|
|
7
test/jobs/user_purge_job_test.rb
Normal file
7
test/jobs/user_purge_job_test.rb
Normal file
|
@ -0,0 +1,7 @@
|
|||
require "test_helper"
|
||||
|
||||
class UserPurgeJobTest < ActiveJob::TestCase
|
||||
# test "the truth" do
|
||||
# assert true
|
||||
# end
|
||||
end
|
Loading…
Add table
Add a link
Reference in a new issue