Fix deletion of unconfirmed users with Webauthn set (#33186)
parent
8b223f3b15
commit
21f6780498
|
@ -19,6 +19,7 @@ class Scheduler::UserCleanupScheduler
|
||||||
User.unconfirmed.where(confirmation_sent_at: ..UNCONFIRMED_ACCOUNTS_MAX_AGE_DAYS.days.ago).find_in_batches do |batch|
|
User.unconfirmed.where(confirmation_sent_at: ..UNCONFIRMED_ACCOUNTS_MAX_AGE_DAYS.days.ago).find_in_batches do |batch|
|
||||||
# We have to do it separately because of missing database constraints
|
# We have to do it separately because of missing database constraints
|
||||||
AccountModerationNote.where(target_account_id: batch.map(&:account_id)).delete_all
|
AccountModerationNote.where(target_account_id: batch.map(&:account_id)).delete_all
|
||||||
|
WebauthnCredential.where(user_id: batch.map(&:id)).delete_all
|
||||||
Account.where(id: batch.map(&:account_id)).delete_all
|
Account.where(id: batch.map(&:account_id)).delete_all
|
||||||
User.where(id: batch.map(&:id)).delete_all
|
User.where(id: batch.map(&:id)).delete_all
|
||||||
end
|
end
|
||||||
|
|
|
@ -9,6 +9,7 @@ RSpec.describe Scheduler::UserCleanupScheduler do
|
||||||
let!(:old_unconfirmed_user) { Fabricate(:user) }
|
let!(:old_unconfirmed_user) { Fabricate(:user) }
|
||||||
let!(:confirmed_user) { Fabricate(:user) }
|
let!(:confirmed_user) { Fabricate(:user) }
|
||||||
let!(:moderation_note) { Fabricate(:account_moderation_note, account: Fabricate(:account), target_account: old_unconfirmed_user.account) }
|
let!(:moderation_note) { Fabricate(:account_moderation_note, account: Fabricate(:account), target_account: old_unconfirmed_user.account) }
|
||||||
|
let!(:webauthn_credential) { Fabricate(:webauthn_credential, user_id: old_unconfirmed_user.id) }
|
||||||
|
|
||||||
describe '#perform' do
|
describe '#perform' do
|
||||||
before do
|
before do
|
||||||
|
@ -26,6 +27,8 @@ RSpec.describe Scheduler::UserCleanupScheduler do
|
||||||
.from(true).to(false)
|
.from(true).to(false)
|
||||||
expect { moderation_note.reload }
|
expect { moderation_note.reload }
|
||||||
.to raise_error(ActiveRecord::RecordNotFound)
|
.to raise_error(ActiveRecord::RecordNotFound)
|
||||||
|
expect { webauthn_credential.reload }
|
||||||
|
.to raise_error(ActiveRecord::RecordNotFound)
|
||||||
expect_preservation_of(new_unconfirmed_user)
|
expect_preservation_of(new_unconfirmed_user)
|
||||||
expect_preservation_of(confirmed_user)
|
expect_preservation_of(confirmed_user)
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in New Issue