mirror of
https://git.kescher.at/CatCatNya/catstodon.git
synced 2024-11-25 10:58:06 +01:00
67 lines
2.1 KiB
Ruby
67 lines
2.1 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require 'rails_helper'
|
|
|
|
RSpec.describe Follow do
|
|
let(:alice) { Fabricate(:account, username: 'alice') }
|
|
let(:bob) { Fabricate(:account, username: 'bob') }
|
|
|
|
describe 'validations' do
|
|
subject { described_class.new(account: alice, target_account: bob, rate_limit: true) }
|
|
|
|
it 'is invalid without an account' do
|
|
follow = Fabricate.build(:follow, account: nil)
|
|
follow.valid?
|
|
expect(follow).to model_have_error_on_field(:account)
|
|
end
|
|
|
|
it 'is invalid without a target_account' do
|
|
follow = Fabricate.build(:follow, target_account: nil)
|
|
follow.valid?
|
|
expect(follow).to model_have_error_on_field(:target_account)
|
|
end
|
|
|
|
it 'is invalid if account already follows too many people' do
|
|
alice.update(following_count: FollowLimitValidator::LIMIT)
|
|
|
|
expect(subject).to_not be_valid
|
|
expect(subject).to model_have_error_on_field(:base)
|
|
end
|
|
|
|
it 'is valid if account is only on the brink of following too many people' do
|
|
alice.update(following_count: FollowLimitValidator::LIMIT - 1)
|
|
|
|
expect(subject).to be_valid
|
|
expect(subject).to_not model_have_error_on_field(:base)
|
|
end
|
|
end
|
|
|
|
describe 'recent' do
|
|
it 'sorts so that more recent follows comes earlier' do
|
|
follow0 = described_class.create!(account: alice, target_account: bob)
|
|
follow1 = described_class.create!(account: bob, target_account: alice)
|
|
|
|
a = described_class.recent.to_a
|
|
|
|
expect(a.size).to eq 2
|
|
expect(a[0]).to eq follow1
|
|
expect(a[1]).to eq follow0
|
|
end
|
|
end
|
|
|
|
describe 'revoke_request!' do
|
|
let(:follow) { Fabricate(:follow, account: account, target_account: target_account) }
|
|
let(:account) { Fabricate(:account) }
|
|
let(:target_account) { Fabricate(:account) }
|
|
|
|
it 'revokes the follow relation' do
|
|
follow.revoke_request!
|
|
expect(account.following?(target_account)).to be false
|
|
end
|
|
|
|
it 'creates a follow request' do
|
|
follow.revoke_request!
|
|
expect(account.requested?(target_account)).to be true
|
|
end
|
|
end
|
|
end
|