reject_follow_service_spec.rb (2282B)
- require 'rails_helper'
- RSpec.describe RejectFollowService do
- let(:sender) { Fabricate(:account, username: 'alice') }
- subject { RejectFollowService.new }
- describe 'local' do
- let(:bob) { Fabricate(:user, email: 'bob@example.com', account: Fabricate(:account, username: 'bob')).account }
- before do
- FollowRequest.create(account: bob, target_account: sender)
- subject.call(bob, sender)
- end
- it 'removes follow request' do
- expect(bob.requested?(sender)).to be false
- end
- it 'does not create follow relation' do
- expect(bob.following?(sender)).to be false
- end
- end
- describe 'remote OStatus' do
- let(:bob) { Fabricate(:user, email: 'bob@example.com', account: Fabricate(:account, username: 'bob', domain: 'example.com', salmon_url: 'http://salmon.example.com')).account }
- before do
- FollowRequest.create(account: bob, target_account: sender)
- stub_request(:post, "http://salmon.example.com/").to_return(:status => 200, :body => "", :headers => {})
- subject.call(bob, sender)
- end
- it 'removes follow request' do
- expect(bob.requested?(sender)).to be false
- end
- it 'does not create follow relation' do
- expect(bob.following?(sender)).to be false
- end
- it 'sends a follow request rejection salmon slap' do
- expect(a_request(:post, "http://salmon.example.com/").with { |req|
- xml = OStatus2::Salmon.new.unpack(req.body)
- xml.match(OStatus::TagManager::VERBS[:reject])
- }).to have_been_made.once
- end
- end
- describe 'remote ActivityPub' do
- let(:bob) { Fabricate(:user, email: 'bob@example.com', account: Fabricate(:account, username: 'bob', domain: 'example.com', protocol: :activitypub, inbox_url: 'http://example.com/inbox')).account }
- before do
- FollowRequest.create(account: bob, target_account: sender)
- stub_request(:post, bob.inbox_url).to_return(status: 200)
- subject.call(bob, sender)
- end
- it 'removes follow request' do
- expect(bob.requested?(sender)).to be false
- end
- it 'does not create follow relation' do
- expect(bob.following?(sender)).to be false
- end
- it 'sends a reject activity' do
- expect(a_request(:post, bob.inbox_url)).to have_been_made.once
- end
- end
- end