fix: Remove teams on account user destroy (#1766)

This commit is contained in:
Pranav Raj S
2021-02-15 13:32:52 +05:30
committed by GitHub
parent 27cf5ecdce
commit 64d7dc5335
4 changed files with 73 additions and 4 deletions

View File

@@ -4,6 +4,12 @@ require 'rails_helper'
RSpec.describe User do
let!(:account_user) { create(:account_user) }
let(:agent_destroy_service) { double }
before do
allow(Agents::DestroyService).to receive(:new).and_return(agent_destroy_service)
allow(agent_destroy_service).to receive(:perform).and_return(agent_destroy_service)
end
describe 'notification_settings' do
it 'gets created with the right default settings' do
@@ -13,4 +19,15 @@ RSpec.describe User do
expect(account_user.user.notification_settings.first.email_conversation_assignment?).to eq(true)
end
end
describe 'destroy call agent::destroy service' do
it 'gets created with the right default settings' do
user = account_user.user
account = account_user.account
account_user.destroy!
expect(Agents::DestroyService).to have_received(:new).with({
user: user, account: account
})
end
end
end

View File

@@ -0,0 +1,23 @@
require 'rails_helper'
describe Agents::DestroyService do
let(:account) { create(:account) }
let(:user) { create(:user, account: account) }
let(:team1) { create(:team, account: account) }
let!(:inbox) { create(:inbox, account: account) }
before do
create(:team_member, team: team1, user: user)
create(:inbox_member, inbox: inbox, user: user)
end
describe '#perform' do
it 'remove inboxes and teams when removed from account' do
described_class.new(account: account, user: user).perform
user.reload
expect(user.teams.length).to eq 0
expect(user.inboxes.length).to eq 0
expect(user.notification_settings.length).to eq 0
end
end
end