BigW Consortium Gitlab

abuse_report_spec.rb 1.52 KB
Newer Older
Stan Hu committed
1 2 3 4 5 6 7 8 9 10 11 12
# == Schema Information
#
# Table name: abuse_reports
#
#  id          :integer          not null, primary key
#  reporter_id :integer
#  user_id     :integer
#  message     :text
#  created_at  :datetime
#  updated_at  :datetime
#

13 14 15 16 17 18
require 'rails_helper'

RSpec.describe AbuseReport, type: :model do
  subject { create(:abuse_report) }

  it { expect(subject).to be_valid }
19 20 21 22 23 24 25 26 27 28

  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) }
29
    it { is_expected.to validate_uniqueness_of(:user_id).with_message('has already been reported') }
30
  end
31

32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47
  describe '#remove_user' do
    it 'blocks the user' do
      report = build(:abuse_report)

      allow(report.user).to receive(:destroy)

      expect { report.remove_user }.to change { report.user.blocked? }.to(true)
    end

    it 'removes the user' do
      report = build(:abuse_report)

      expect { report.remove_user }.to change { User.count }.by(-1)
    end
  end

48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63
  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
64
end