123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051 |
- # frozen_string_literal: true
- require 'rails_helper'
- describe ActivityPub::NoteSerializer do
- subject { JSON.parse(@serialization.to_json) }
- let!(:account) { Fabricate(:account) }
- let!(:other) { Fabricate(:account) }
- let!(:parent) { Fabricate(:status, account: account, visibility: :public, language: 'zh-TW') }
- let!(:reply_by_account_first) { Fabricate(:status, account: account, thread: parent, visibility: :public) }
- let!(:reply_by_account_next) { Fabricate(:status, account: account, thread: parent, visibility: :public) }
- let!(:reply_by_other_first) { Fabricate(:status, account: other, thread: parent, visibility: :public) }
- let!(:reply_by_account_third) { Fabricate(:status, account: account, thread: parent, visibility: :public) }
- let!(:reply_by_account_visibility_direct) { Fabricate(:status, account: account, thread: parent, visibility: :direct) }
- before(:each) do
- @serialization = ActiveModelSerializers::SerializableResource.new(parent, serializer: described_class, adapter: ActivityPub::Adapter)
- end
- it 'has the expected shape' do
- expect(subject).to include({
- '@context' => include('https://www.w3.org/ns/activitystreams'),
- 'type' => 'Note',
- 'attributedTo' => ActivityPub::TagManager.instance.uri_for(account),
- 'contentMap' => include({
- 'zh-TW' => a_kind_of(String),
- }),
- })
- end
- it 'has a replies collection' do
- expect(subject['replies']['type']).to eql('Collection')
- end
- it 'has a replies collection with a first Page' do
- expect(subject['replies']['first']['type']).to eql('CollectionPage')
- end
- it 'includes public self-replies in its replies collection' do
- expect(subject['replies']['first']['items']).to include(reply_by_account_first.uri, reply_by_account_next.uri, reply_by_account_third.uri)
- end
- it 'does not include replies from others in its replies collection' do
- expect(subject['replies']['first']['items']).to_not include(reply_by_other_first.uri)
- end
- it 'does not include replies with direct visibility in its replies collection' do
- expect(subject['replies']['first']['items']).to_not include(reply_by_account_visibility_direct.uri)
- end
- end
|