mirror of
https://git.bsd.gay/fef/nyastodon.git
synced 2025-01-15 15:54:06 +01:00
b7370ac8ba
* Deliver ActivityPub Like * Deliver ActivityPub Undo-Like * Deliver ActivityPub Create/Announce activities * Deliver ActivityPub creates from mentions * Deliver ActivityPub Block/Undo-Block * Deliver ActivityPub Accept/Reject-Follow * Deliver ActivityPub Undo-Follow * Deliver ActivityPub Follow * Deliver ActivityPub Delete activities Incidentally fix #889 * Adjust BatchedRemoveStatusService for ActivityPub * Add tests for ActivityPub workers * Add tests for FollowService * Add tests for FavouriteService, UnfollowService and PostStatusService * Add tests for ReblogService, BlockService, UnblockService, ProcessMentionsService * Add tests for AuthorizeFollowService, RejectFollowService, RemoveStatusService * Add tests for BatchedRemoveStatusService * Deliver updates to a local account to ActivityPub followers * Minor adjustments
71 lines
2.2 KiB
Ruby
71 lines
2.2 KiB
Ruby
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(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
|