BigW Consortium Gitlab

abuse_report_spec.rb 1.39 KB
Newer Older
1 2 3
require 'rails_helper'

RSpec.describe AbuseReport, type: :model do
4 5
  subject     { create(:abuse_report) }
  let(:user)  { create(:user) }
6 7

  it { expect(subject).to be_valid }
8 9 10 11 12 13 14 15 16 17

  describe 'associations' do
    it { is_expected.to belong_to(:reporter).class_name('User') }
    it { is_expected.to belong_to(:user) }
  end

  describe 'validations' do
    it { is_expected.to validate_presence_of(:reporter) }
    it { is_expected.to validate_presence_of(:user) }
    it { is_expected.to validate_presence_of(:message) }
18
    it { is_expected.to validate_uniqueness_of(:user_id).with_message('has already been reported') }
19
  end
20

21 22
  describe '#remove_user' do
    it 'blocks the user' do
23
      expect { subject.remove_user(deleted_by: user) }.to change { subject.user.blocked? }.to(true)
24 25
    end

26
    it 'lets a worker delete the user' do
27 28
      expect(DeleteUserWorker).to receive(:perform_async).with(user.id, subject.user.id,
                                                              delete_solo_owned_groups: true)
29

30
      subject.remove_user(deleted_by: user)
31 32 33
    end
  end

34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49
  describe '#notify' do
    it 'delivers' do
      expect(AbuseReportMailer).to receive(:notify).with(subject.id).
        and_return(spy)

      subject.notify
    end

    it 'returns early when not persisted' do
      report = build(:abuse_report)

      expect(AbuseReportMailer).not_to receive(:notify)

      report.notify
    end
  end
50
end