Merge branch 'master' into glitch-soc/merge-upstream
Conflicts: - `app/javascript/mastodon/actions/compose.js`: Not a “real” conflict, but change too close to a change we made to fix the vanilla WebUI locally pushing authored local-only toots in the public TL view.
This commit is contained in:
		@@ -5,6 +5,21 @@ RSpec.describe AccountsController, type: :controller do
 | 
			
		||||
 | 
			
		||||
  let(:account) { Fabricate(:user).account }
 | 
			
		||||
 | 
			
		||||
  shared_examples 'cachable response' do
 | 
			
		||||
    it 'does not set cookies' do
 | 
			
		||||
      expect(response.cookies).to be_empty
 | 
			
		||||
      expect(response.headers['Set-Cookies']).to be nil
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    it 'does not set sessions' do
 | 
			
		||||
      expect(session).to be_empty
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    it 'returns public Cache-Control header' do
 | 
			
		||||
      expect(response.headers['Cache-Control']).to include 'public'
 | 
			
		||||
    end
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  describe 'GET #show' do
 | 
			
		||||
    let(:format) { 'html' }
 | 
			
		||||
 | 
			
		||||
@@ -323,9 +338,7 @@ RSpec.describe AccountsController, type: :controller do
 | 
			
		||||
          expect(response.content_type).to eq 'application/activity+json'
 | 
			
		||||
        end
 | 
			
		||||
 | 
			
		||||
        it 'returns public Cache-Control header' do
 | 
			
		||||
          expect(response.headers['Cache-Control']).to include 'public'
 | 
			
		||||
        end
 | 
			
		||||
        it_behaves_like 'cachable response'
 | 
			
		||||
 | 
			
		||||
        it 'renders account' do
 | 
			
		||||
          json = body_as_json
 | 
			
		||||
@@ -343,9 +356,7 @@ RSpec.describe AccountsController, type: :controller do
 | 
			
		||||
            expect(response.content_type).to eq 'application/activity+json'
 | 
			
		||||
          end
 | 
			
		||||
 | 
			
		||||
          it 'returns public Cache-Control header' do
 | 
			
		||||
            expect(response.headers['Cache-Control']).to include 'public'
 | 
			
		||||
          end
 | 
			
		||||
          it_behaves_like 'cachable response'
 | 
			
		||||
 | 
			
		||||
          it 'returns Vary header with Signature' do
 | 
			
		||||
            expect(response.headers['Vary']).to include 'Signature'
 | 
			
		||||
@@ -401,9 +412,7 @@ RSpec.describe AccountsController, type: :controller do
 | 
			
		||||
          expect(response.content_type).to eq 'application/activity+json'
 | 
			
		||||
        end
 | 
			
		||||
 | 
			
		||||
        it 'returns public Cache-Control header' do
 | 
			
		||||
          expect(response.headers['Cache-Control']).to include 'public'
 | 
			
		||||
        end
 | 
			
		||||
        it_behaves_like 'cachable response'
 | 
			
		||||
 | 
			
		||||
        it 'renders account' do
 | 
			
		||||
          json = body_as_json
 | 
			
		||||
@@ -447,9 +456,7 @@ RSpec.describe AccountsController, type: :controller do
 | 
			
		||||
          expect(response).to have_http_status(200)
 | 
			
		||||
        end
 | 
			
		||||
 | 
			
		||||
        it 'returns public Cache-Control header' do
 | 
			
		||||
          expect(response.headers['Cache-Control']).to include 'public'
 | 
			
		||||
        end
 | 
			
		||||
        it_behaves_like 'cachable response'
 | 
			
		||||
      end
 | 
			
		||||
 | 
			
		||||
      context do
 | 
			
		||||
 
 | 
			
		||||
@@ -6,6 +6,21 @@ RSpec.describe ActivityPub::CollectionsController, type: :controller do
 | 
			
		||||
  let!(:account) { Fabricate(:account) }
 | 
			
		||||
  let(:remote_account) { nil }
 | 
			
		||||
 | 
			
		||||
  shared_examples 'cachable response' do
 | 
			
		||||
    it 'does not set cookies' do
 | 
			
		||||
      expect(response.cookies).to be_empty
 | 
			
		||||
      expect(response.headers['Set-Cookies']).to be nil
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    it 'does not set sessions' do
 | 
			
		||||
      expect(session).to be_empty
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    it 'returns public Cache-Control header' do
 | 
			
		||||
      expect(response.headers['Cache-Control']).to include 'public'
 | 
			
		||||
    end
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  before do
 | 
			
		||||
    allow(controller).to receive(:signed_request_account).and_return(remote_account)
 | 
			
		||||
 | 
			
		||||
@@ -31,9 +46,7 @@ RSpec.describe ActivityPub::CollectionsController, type: :controller do
 | 
			
		||||
          expect(response.content_type).to eq 'application/activity+json'
 | 
			
		||||
        end
 | 
			
		||||
 | 
			
		||||
        it 'returns public Cache-Control header' do
 | 
			
		||||
          expect(response.headers['Cache-Control']).to include 'public'
 | 
			
		||||
        end
 | 
			
		||||
        it_behaves_like 'cachable response'
 | 
			
		||||
 | 
			
		||||
        it 'returns orderedItems with pinned statuses' do
 | 
			
		||||
          json = body_as_json
 | 
			
		||||
@@ -58,9 +71,7 @@ RSpec.describe ActivityPub::CollectionsController, type: :controller do
 | 
			
		||||
            expect(response.content_type).to eq 'application/activity+json'
 | 
			
		||||
          end
 | 
			
		||||
 | 
			
		||||
          it 'returns public Cache-Control header' do
 | 
			
		||||
            expect(response.headers['Cache-Control']).to include 'public'
 | 
			
		||||
          end
 | 
			
		||||
          it_behaves_like 'cachable response'
 | 
			
		||||
 | 
			
		||||
          it 'returns orderedItems with pinned statuses' do
 | 
			
		||||
            json = body_as_json
 | 
			
		||||
 
 | 
			
		||||
@@ -3,6 +3,21 @@ require 'rails_helper'
 | 
			
		||||
RSpec.describe ActivityPub::OutboxesController, type: :controller do
 | 
			
		||||
  let!(:account) { Fabricate(:account) }
 | 
			
		||||
 | 
			
		||||
  shared_examples 'cachable response' do
 | 
			
		||||
    it 'does not set cookies' do
 | 
			
		||||
      expect(response.cookies).to be_empty
 | 
			
		||||
      expect(response.headers['Set-Cookies']).to be nil
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    it 'does not set sessions' do
 | 
			
		||||
      expect(session).to be_empty
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    it 'returns public Cache-Control header' do
 | 
			
		||||
      expect(response.headers['Cache-Control']).to include 'public'
 | 
			
		||||
    end
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  before do
 | 
			
		||||
    Fabricate(:status, account: account, visibility: :public)
 | 
			
		||||
    Fabricate(:status, account: account, visibility: :unlisted)
 | 
			
		||||
@@ -39,9 +54,7 @@ RSpec.describe ActivityPub::OutboxesController, type: :controller do
 | 
			
		||||
          expect(json[:totalItems]).to eq 4
 | 
			
		||||
        end
 | 
			
		||||
 | 
			
		||||
        it 'returns public Cache-Control header' do
 | 
			
		||||
          expect(response.headers['Cache-Control']).to include 'public'
 | 
			
		||||
        end
 | 
			
		||||
        it_behaves_like 'cachable response'
 | 
			
		||||
      end
 | 
			
		||||
 | 
			
		||||
      context 'with page requested' do
 | 
			
		||||
@@ -62,9 +75,7 @@ RSpec.describe ActivityPub::OutboxesController, type: :controller do
 | 
			
		||||
          expect(json[:orderedItems].all? { |item| item[:to].include?(ActivityPub::TagManager::COLLECTIONS[:public]) || item[:cc].include?(ActivityPub::TagManager::COLLECTIONS[:public]) }).to be true
 | 
			
		||||
        end
 | 
			
		||||
 | 
			
		||||
        it 'returns public Cache-Control header' do
 | 
			
		||||
          expect(response.headers['Cache-Control']).to include 'public'
 | 
			
		||||
        end
 | 
			
		||||
        it_behaves_like 'cachable response'
 | 
			
		||||
      end
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -7,6 +7,21 @@ RSpec.describe ActivityPub::RepliesController, type: :controller do
 | 
			
		||||
  let(:remote_reply_id) { nil }
 | 
			
		||||
  let(:remote_account) { nil }
 | 
			
		||||
 | 
			
		||||
  shared_examples 'cachable response' do
 | 
			
		||||
    it 'does not set cookies' do
 | 
			
		||||
      expect(response.cookies).to be_empty
 | 
			
		||||
      expect(response.headers['Set-Cookies']).to be nil
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    it 'does not set sessions' do
 | 
			
		||||
      expect(session).to be_empty
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    it 'returns public Cache-Control header' do
 | 
			
		||||
      expect(response.headers['Cache-Control']).to include 'public'
 | 
			
		||||
    end
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  before do
 | 
			
		||||
    allow(controller).to receive(:signed_request_account).and_return(remote_account)
 | 
			
		||||
 | 
			
		||||
@@ -36,9 +51,7 @@ RSpec.describe ActivityPub::RepliesController, type: :controller do
 | 
			
		||||
          expect(response.content_type).to eq 'application/activity+json'
 | 
			
		||||
        end
 | 
			
		||||
 | 
			
		||||
        it 'returns public Cache-Control header' do
 | 
			
		||||
          expect(response.headers['Cache-Control']).to include 'public'
 | 
			
		||||
        end
 | 
			
		||||
        it_behaves_like 'cachable response'
 | 
			
		||||
 | 
			
		||||
        it 'returns items with account\'s own replies' do
 | 
			
		||||
          json = body_as_json
 | 
			
		||||
@@ -87,9 +100,7 @@ RSpec.describe ActivityPub::RepliesController, type: :controller do
 | 
			
		||||
            expect(response.content_type).to eq 'application/activity+json'
 | 
			
		||||
          end
 | 
			
		||||
 | 
			
		||||
          it 'returns public Cache-Control header' do
 | 
			
		||||
            expect(response.headers['Cache-Control']).to include 'public'
 | 
			
		||||
          end
 | 
			
		||||
          it_behaves_like 'cachable response'
 | 
			
		||||
 | 
			
		||||
          context 'without only_other_accounts' do
 | 
			
		||||
            it 'returns items with account\'s own replies' do
 | 
			
		||||
 
 | 
			
		||||
@@ -5,6 +5,21 @@ require 'rails_helper'
 | 
			
		||||
describe StatusesController do
 | 
			
		||||
  render_views
 | 
			
		||||
 | 
			
		||||
  shared_examples 'cachable response' do
 | 
			
		||||
    it 'does not set cookies' do
 | 
			
		||||
      expect(response.cookies).to be_empty
 | 
			
		||||
      expect(response.headers['Set-Cookies']).to be nil
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    it 'does not set sessions' do
 | 
			
		||||
      expect(session).to be_empty
 | 
			
		||||
    end
 | 
			
		||||
 | 
			
		||||
    it 'returns public Cache-Control header' do
 | 
			
		||||
      expect(response.headers['Cache-Control']).to include 'public'
 | 
			
		||||
    end
 | 
			
		||||
  end
 | 
			
		||||
 | 
			
		||||
  describe 'GET #show' do
 | 
			
		||||
    let(:account) { Fabricate(:account) }
 | 
			
		||||
    let(:status)  { Fabricate(:status, account: account) }
 | 
			
		||||
@@ -80,9 +95,7 @@ describe StatusesController do
 | 
			
		||||
          expect(response.headers['Vary']).to eq 'Accept'
 | 
			
		||||
        end
 | 
			
		||||
 | 
			
		||||
        it 'returns public Cache-Control header' do
 | 
			
		||||
          expect(response.headers['Cache-Control']).to include 'public'
 | 
			
		||||
        end
 | 
			
		||||
        it_behaves_like 'cachable response'
 | 
			
		||||
 | 
			
		||||
        it 'returns Content-Type header' do
 | 
			
		||||
          expect(response.headers['Content-Type']).to include 'application/activity+json'
 | 
			
		||||
@@ -470,9 +483,7 @@ describe StatusesController do
 | 
			
		||||
            expect(response.headers['Vary']).to eq 'Accept'
 | 
			
		||||
          end
 | 
			
		||||
 | 
			
		||||
          it 'returns public Cache-Control header' do
 | 
			
		||||
            expect(response.headers['Cache-Control']).to include 'public'
 | 
			
		||||
          end
 | 
			
		||||
          it_behaves_like 'cachable response'
 | 
			
		||||
 | 
			
		||||
          it 'returns Content-Type header' do
 | 
			
		||||
            expect(response.headers['Content-Type']).to include 'application/activity+json'
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user