2023-02-22 09:55:31 +09:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2022-02-15 05:27:53 +09:00
|
|
|
require 'rails_helper'
|
|
|
|
|
2024-09-04 14:12:25 +09:00
|
|
|
RSpec.describe Appeal do
|
2024-06-11 00:23:17 +09:00
|
|
|
describe 'Validations' do
|
2024-10-23 15:42:57 +09:00
|
|
|
subject { Fabricate.build :appeal, strike: Fabricate(:account_warning) }
|
|
|
|
|
|
|
|
it { is_expected.to validate_length_of(:text).is_at_most(described_class::TEXT_LENGTH_LIMIT) }
|
|
|
|
|
|
|
|
context 'with a strike created too long ago' do
|
|
|
|
let(:strike) { Fabricate.build :account_warning, created_at: 100.days.ago }
|
|
|
|
|
|
|
|
it { is_expected.to_not allow_values(strike).for(:strike).against(:base).on(:create) }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe 'Query methods' do
|
|
|
|
describe '#pending?' do
|
|
|
|
subject { Fabricate.build :appeal, approved_at:, rejected_at: }
|
|
|
|
|
|
|
|
context 'with not approved and not rejected' do
|
|
|
|
let(:approved_at) { nil }
|
|
|
|
let(:rejected_at) { nil }
|
|
|
|
|
|
|
|
it { expect(subject).to be_pending }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with approved and rejected' do
|
|
|
|
let(:approved_at) { 1.day.ago }
|
|
|
|
let(:rejected_at) { 1.day.ago }
|
|
|
|
|
|
|
|
it { expect(subject).to_not be_pending }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with approved and not rejected' do
|
|
|
|
let(:approved_at) { 1.day.ago }
|
|
|
|
let(:rejected_at) { nil }
|
|
|
|
|
|
|
|
it { expect(subject).to_not be_pending }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with not approved and rejected' do
|
|
|
|
let(:approved_at) { nil }
|
|
|
|
let(:rejected_at) { 1.day.ago }
|
|
|
|
|
|
|
|
it { expect(subject).to_not be_pending }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe '#approved?' do
|
|
|
|
subject { Fabricate.build :appeal, approved_at: }
|
|
|
|
|
|
|
|
context 'with not approved' do
|
|
|
|
let(:approved_at) { nil }
|
|
|
|
|
|
|
|
it { expect(subject).to_not be_approved }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with approved' do
|
|
|
|
let(:approved_at) { 1.day.ago }
|
|
|
|
|
|
|
|
it { expect(subject).to be_approved }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe '#rejected?' do
|
|
|
|
subject { Fabricate.build :appeal, rejected_at: }
|
|
|
|
|
|
|
|
context 'with not rejected' do
|
|
|
|
let(:rejected_at) { nil }
|
|
|
|
|
|
|
|
it { expect(subject).to_not be_rejected }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with rejected' do
|
|
|
|
let(:rejected_at) { 1.day.ago }
|
|
|
|
|
|
|
|
it { expect(subject).to be_rejected }
|
|
|
|
end
|
2024-06-11 00:23:17 +09:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2024-10-23 15:42:57 +09:00
|
|
|
describe 'Scopes' do
|
|
|
|
describe '.approved' do
|
2023-03-05 01:16:45 +09:00
|
|
|
let(:approved_appeal) { Fabricate(:appeal, approved_at: 10.days.ago) }
|
|
|
|
let(:not_approved_appeal) { Fabricate(:appeal, approved_at: nil) }
|
|
|
|
|
|
|
|
it 'finds the correct records' do
|
|
|
|
results = described_class.approved
|
|
|
|
expect(results).to eq([approved_appeal])
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2024-10-23 15:42:57 +09:00
|
|
|
describe '.rejected' do
|
2023-03-05 01:16:45 +09:00
|
|
|
let(:rejected_appeal) { Fabricate(:appeal, rejected_at: 10.days.ago) }
|
|
|
|
let(:not_rejected_appeal) { Fabricate(:appeal, rejected_at: nil) }
|
|
|
|
|
|
|
|
it 'finds the correct records' do
|
|
|
|
results = described_class.rejected
|
|
|
|
expect(results).to eq([rejected_appeal])
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2024-10-23 15:42:57 +09:00
|
|
|
describe '.pending' do
|
2023-03-05 01:16:45 +09:00
|
|
|
let(:approved_appeal) { Fabricate(:appeal, approved_at: 10.days.ago) }
|
|
|
|
let(:rejected_appeal) { Fabricate(:appeal, rejected_at: 10.days.ago) }
|
|
|
|
let(:pending_appeal) { Fabricate(:appeal, rejected_at: nil, approved_at: nil) }
|
|
|
|
|
|
|
|
it 'finds the correct records' do
|
|
|
|
results = described_class.pending
|
|
|
|
expect(results).to eq([pending_appeal])
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2022-02-15 05:27:53 +09:00
|
|
|
end
|