Merge branch 'main' into glitch-soc/merge-upstream
Conflicts: - `app/controllers/accounts_controller.rb`: Upstream introduced support for private pinned toots, but glitch-soc's query was a bit different as it filtered out local-only toots. Used upstream's query, while adding local-only filtering back. - `app/controllers/activitypub/collections_controller.rb`: Same thing with regards to local-only posts. - `app/validators/status_pin_validator.rb`: Not a real conflict, but the line below was different in glitch-soc due to the configurable pinned toots limit.
This commit is contained in:
		@@ -23,6 +23,7 @@ RSpec.describe ActivityPub::Activity::Accept do
 | 
			
		||||
    subject { described_class.new(json, sender) }
 | 
			
		||||
 | 
			
		||||
    before do
 | 
			
		||||
      allow(RemoteAccountRefreshWorker).to receive(:perform_async)
 | 
			
		||||
      Fabricate(:follow_request, account: recipient, target_account: sender)
 | 
			
		||||
      subject.perform
 | 
			
		||||
    end
 | 
			
		||||
@@ -34,6 +35,10 @@ RSpec.describe ActivityPub::Activity::Accept do
 | 
			
		||||
    it 'removes the follow request' do
 | 
			
		||||
      expect(recipient.requested?(sender)).to be false
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    it 'queues a refresh' do
 | 
			
		||||
      expect(RemoteAccountRefreshWorker).to have_received(:perform_async).with(sender.id)
 | 
			
		||||
    end
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  context 'given a relay' do
 | 
			
		||||
 
 | 
			
		||||
@@ -1,8 +1,8 @@
 | 
			
		||||
require 'rails_helper'
 | 
			
		||||
 | 
			
		||||
RSpec.describe ActivityPub::Activity::Add do
 | 
			
		||||
  let(:sender) { Fabricate(:account, featured_collection_url: 'https://example.com/featured') }
 | 
			
		||||
  let(:status) { Fabricate(:status, account: sender) }
 | 
			
		||||
  let(:sender) { Fabricate(:account, featured_collection_url: 'https://example.com/featured', domain: 'example.com') }
 | 
			
		||||
  let(:status) { Fabricate(:status, account: sender, visibility: :private) }
 | 
			
		||||
 | 
			
		||||
  let(:json) do
 | 
			
		||||
    {
 | 
			
		||||
@@ -24,6 +24,8 @@ RSpec.describe ActivityPub::Activity::Add do
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    context 'when status was not known before' do
 | 
			
		||||
      let(:service_stub) { double }
 | 
			
		||||
 | 
			
		||||
      let(:json) do
 | 
			
		||||
        {
 | 
			
		||||
          '@context': 'https://www.w3.org/ns/activitystreams',
 | 
			
		||||
@@ -36,12 +38,40 @@ RSpec.describe ActivityPub::Activity::Add do
 | 
			
		||||
      end
 | 
			
		||||
 | 
			
		||||
      before do
 | 
			
		||||
        stub_request(:get, 'https://example.com/unknown').to_return(status: 410)
 | 
			
		||||
        allow(ActivityPub::FetchRemoteStatusService).to receive(:new).and_return(service_stub)
 | 
			
		||||
      end
 | 
			
		||||
 | 
			
		||||
      it 'fetches the status' do
 | 
			
		||||
        subject.perform
 | 
			
		||||
        expect(a_request(:get, 'https://example.com/unknown')).to have_been_made.at_least_once
 | 
			
		||||
      context 'when there is a local follower' do
 | 
			
		||||
        before do
 | 
			
		||||
          account = Fabricate(:account)
 | 
			
		||||
          account.follow!(sender)
 | 
			
		||||
        end
 | 
			
		||||
 | 
			
		||||
        it 'fetches the status and pins it' do
 | 
			
		||||
          allow(service_stub).to receive(:call) do |uri, id: true, on_behalf_of: nil|
 | 
			
		||||
            expect(uri).to eq 'https://example.com/unknown'
 | 
			
		||||
            expect(id).to eq true
 | 
			
		||||
            expect(on_behalf_of&.following?(sender)).to eq true
 | 
			
		||||
            status
 | 
			
		||||
          end
 | 
			
		||||
          subject.perform
 | 
			
		||||
          expect(service_stub).to have_received(:call)
 | 
			
		||||
          expect(sender.pinned?(status)).to be true
 | 
			
		||||
        end
 | 
			
		||||
      end
 | 
			
		||||
 | 
			
		||||
      context 'when there is no local follower' do
 | 
			
		||||
        it 'tries to fetch the status' do
 | 
			
		||||
          allow(service_stub).to receive(:call) do |uri, id: true, on_behalf_of: nil|
 | 
			
		||||
            expect(uri).to eq 'https://example.com/unknown'
 | 
			
		||||
            expect(id).to eq true
 | 
			
		||||
            expect(on_behalf_of).to eq nil
 | 
			
		||||
            nil
 | 
			
		||||
          end
 | 
			
		||||
          subject.perform
 | 
			
		||||
          expect(service_stub).to have_received(:call)
 | 
			
		||||
          expect(sender.pinned?(status)).to be false
 | 
			
		||||
        end
 | 
			
		||||
      end
 | 
			
		||||
    end
 | 
			
		||||
  end
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user