Fix ActivityPub follow interaction and add more specs (#4601)
This commit is contained in:
		@ -20,6 +20,6 @@ class ActivityPub::Activity::Accept < ActivityPub::Activity
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  def target_uri
 | 
			
		||||
    @target_uri ||= @object['object'].is_a?(String) ? @object['object'] : @object['object']['id']
 | 
			
		||||
    @target_uri ||= @object['actor']
 | 
			
		||||
  end
 | 
			
		||||
end
 | 
			
		||||
 | 
			
		||||
@ -20,6 +20,6 @@ class ActivityPub::Activity::Reject < ActivityPub::Activity
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  def target_uri
 | 
			
		||||
    @target_uri ||= @object['object'].is_a?(String) ? @object['object'] : @object['object']['id']
 | 
			
		||||
    @target_uri ||= @object['actor']
 | 
			
		||||
  end
 | 
			
		||||
end
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										38
									
								
								spec/lib/activitypub/activity/accept_spec.rb
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										38
									
								
								spec/lib/activitypub/activity/accept_spec.rb
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,38 @@
 | 
			
		||||
require 'rails_helper'
 | 
			
		||||
 | 
			
		||||
RSpec.describe ActivityPub::Activity::Accept do
 | 
			
		||||
  let(:sender)    { Fabricate(:account) }
 | 
			
		||||
  let(:recipient) { Fabricate(:account) }
 | 
			
		||||
 | 
			
		||||
  let(:json) do
 | 
			
		||||
    {
 | 
			
		||||
      '@context': 'https://www.w3.org/ns/activitystreams',
 | 
			
		||||
      id: 'foo',
 | 
			
		||||
      type: 'Accept',
 | 
			
		||||
      actor: ActivityPub::TagManager.instance.uri_for(sender),
 | 
			
		||||
      object: {
 | 
			
		||||
        id: 'bar',
 | 
			
		||||
        type: 'Follow',
 | 
			
		||||
        actor: ActivityPub::TagManager.instance.uri_for(recipient),
 | 
			
		||||
        object: ActivityPub::TagManager.instance.uri_for(sender),
 | 
			
		||||
      },
 | 
			
		||||
    }.with_indifferent_access
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  describe '#perform' do
 | 
			
		||||
    subject { described_class.new(json, sender) }
 | 
			
		||||
 | 
			
		||||
    before do
 | 
			
		||||
      Fabricate(:follow_request, account: recipient, target_account: sender)
 | 
			
		||||
      subject.perform
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    it 'creates a follow relationship' do
 | 
			
		||||
      expect(recipient.following?(sender)).to be true
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    it 'removes the follow request' do
 | 
			
		||||
      expect(recipient.requested?(sender)).to be false
 | 
			
		||||
    end
 | 
			
		||||
  end
 | 
			
		||||
end
 | 
			
		||||
@ -17,12 +17,33 @@ RSpec.describe ActivityPub::Activity::Follow do
 | 
			
		||||
  describe '#perform' do
 | 
			
		||||
    subject { described_class.new(json, sender) }
 | 
			
		||||
 | 
			
		||||
    before do
 | 
			
		||||
      subject.perform
 | 
			
		||||
    context 'unlocked account' do
 | 
			
		||||
      before do
 | 
			
		||||
        subject.perform
 | 
			
		||||
      end
 | 
			
		||||
 | 
			
		||||
      it 'creates a follow from sender to recipient' do
 | 
			
		||||
        expect(sender.following?(recipient)).to be true
 | 
			
		||||
      end
 | 
			
		||||
 | 
			
		||||
      it 'does not create a follow request' do
 | 
			
		||||
        expect(sender.requested?(recipient)).to be false
 | 
			
		||||
      end
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    it 'creates a follow from sender to recipient' do
 | 
			
		||||
      expect(sender.following?(recipient)).to be true
 | 
			
		||||
    context 'locked account' do
 | 
			
		||||
      before do
 | 
			
		||||
        recipient.update(locked: true)
 | 
			
		||||
        subject.perform
 | 
			
		||||
      end
 | 
			
		||||
 | 
			
		||||
      it 'does not create a follow from sender to recipient' do
 | 
			
		||||
        expect(sender.following?(recipient)).to be false
 | 
			
		||||
      end
 | 
			
		||||
 | 
			
		||||
      it 'creates a follow request' do
 | 
			
		||||
        expect(sender.requested?(recipient)).to be true
 | 
			
		||||
      end
 | 
			
		||||
    end
 | 
			
		||||
  end
 | 
			
		||||
end
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										38
									
								
								spec/lib/activitypub/activity/reject_spec.rb
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										38
									
								
								spec/lib/activitypub/activity/reject_spec.rb
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,38 @@
 | 
			
		||||
require 'rails_helper'
 | 
			
		||||
 | 
			
		||||
RSpec.describe ActivityPub::Activity::Reject do
 | 
			
		||||
  let(:sender)    { Fabricate(:account) }
 | 
			
		||||
  let(:recipient) { Fabricate(:account) }
 | 
			
		||||
 | 
			
		||||
  let(:json) do
 | 
			
		||||
    {
 | 
			
		||||
      '@context': 'https://www.w3.org/ns/activitystreams',
 | 
			
		||||
      id: 'foo',
 | 
			
		||||
      type: 'Reject',
 | 
			
		||||
      actor: ActivityPub::TagManager.instance.uri_for(sender),
 | 
			
		||||
      object: {
 | 
			
		||||
        id: 'bar',
 | 
			
		||||
        type: 'Follow',
 | 
			
		||||
        actor: ActivityPub::TagManager.instance.uri_for(recipient),
 | 
			
		||||
        object: ActivityPub::TagManager.instance.uri_for(sender),
 | 
			
		||||
      },
 | 
			
		||||
    }.with_indifferent_access
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  describe '#perform' do
 | 
			
		||||
    subject { described_class.new(json, sender) }
 | 
			
		||||
 | 
			
		||||
    before do
 | 
			
		||||
      Fabricate(:follow_request, account: recipient, target_account: sender)
 | 
			
		||||
      subject.perform
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    it 'does not create a follow relationship' do
 | 
			
		||||
      expect(recipient.following?(sender)).to be false
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    it 'removes the follow request' do
 | 
			
		||||
      expect(recipient.requested?(sender)).to be false
 | 
			
		||||
    end
 | 
			
		||||
  end
 | 
			
		||||
end
 | 
			
		||||
		Reference in New Issue
	
	Block a user