123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183 |
- # frozen_string_literal: true
- require 'rails_helper'
- RSpec.describe ActivityPub::Activity::Update do
- subject { described_class.new(json, sender) }
- let!(:sender) { Fabricate(:account, domain: 'example.com', inbox_url: 'https://example.com/foo/inbox', outbox_url: 'https://example.com/foo/outbox') }
- describe '#perform' do
- context 'with an Actor object' do
- let(:actor_json) do
- {
- '@context': [
- 'https://www.w3.org/ns/activitystreams',
- 'https://w3id.org/security/v1',
- {
- manuallyApprovesFollowers: 'as:manuallyApprovesFollowers',
- toot: 'http://joinmastodon.org/ns#',
- featured: { '@id': 'toot:featured', '@type': '@id' },
- featuredTags: { '@id': 'toot:featuredTags', '@type': '@id' },
- },
- ],
- id: sender.uri,
- type: 'Person',
- following: 'https://example.com/users/dfsdf/following',
- followers: 'https://example.com/users/dfsdf/followers',
- inbox: sender.inbox_url,
- outbox: sender.outbox_url,
- featured: 'https://example.com/users/dfsdf/featured',
- featuredTags: 'https://example.com/users/dfsdf/tags',
- preferredUsername: sender.username,
- name: 'Totally modified now',
- publicKey: {
- id: "#{sender.uri}#main-key",
- owner: sender.uri,
- publicKeyPem: sender.public_key,
- },
- }
- end
- let(:json) do
- {
- '@context': 'https://www.w3.org/ns/activitystreams',
- id: 'foo',
- type: 'Update',
- actor: sender.uri,
- object: actor_json,
- }.with_indifferent_access
- end
- before do
- stub_request(:get, actor_json[:outbox]).to_return(status: 404)
- stub_request(:get, actor_json[:followers]).to_return(status: 404)
- stub_request(:get, actor_json[:following]).to_return(status: 404)
- stub_request(:get, actor_json[:featured]).to_return(status: 404)
- stub_request(:get, actor_json[:featuredTags]).to_return(status: 404)
- subject.perform
- end
- it 'updates profile' do
- expect(sender.reload.display_name).to eq 'Totally modified now'
- end
- end
- context 'with a Question object' do
- let!(:at_time) { Time.now.utc }
- let!(:status) { Fabricate(:status, uri: 'https://example.com/statuses/poll', account: sender, poll: Poll.new(account: sender, options: %w(Bar Baz), cached_tallies: [0, 0], expires_at: at_time + 5.days)) }
- let(:json) do
- {
- '@context': 'https://www.w3.org/ns/activitystreams',
- id: 'foo',
- type: 'Update',
- actor: sender.uri,
- object: {
- type: 'Question',
- id: status.uri,
- content: 'Foo',
- endTime: (at_time + 5.days).iso8601,
- oneOf: [
- {
- type: 'Note',
- name: 'Bar',
- replies: {
- type: 'Collection',
- totalItems: 0,
- },
- },
- {
- type: 'Note',
- name: 'Baz',
- replies: {
- type: 'Collection',
- totalItems: 12,
- },
- },
- ],
- },
- }.with_indifferent_access
- end
- before do
- status.update!(uri: ActivityPub::TagManager.instance.uri_for(status))
- subject.perform
- end
- it 'updates poll numbers' do
- expect(status.preloadable_poll.cached_tallies).to eq [0, 12]
- end
- it 'does not set status as edited' do
- expect(status.edited_at).to be_nil
- end
- end
- context 'with a Note object' do
- let(:updated) { nil }
- let(:favourites) { 50 }
- let(:reblogs) { 100 }
- let!(:status) { Fabricate(:status, uri: 'https://example.com/statuses/poll', account: sender) }
- let(:json) do
- {
- '@context': 'https://www.w3.org/ns/activitystreams',
- id: 'foo',
- type: 'Update',
- actor: sender.uri,
- object: {
- type: 'Note',
- id: status.uri,
- content: 'Foo',
- updated: updated,
- likes: {
- id: "#{status.uri}/likes",
- type: 'Collection',
- totalItems: favourites,
- },
- shares: {
- id: "#{status.uri}/shares",
- type: 'Collection',
- totalItems: reblogs,
- },
- },
- }.with_indifferent_access
- end
- shared_examples 'updates counts' do
- it 'updates the reblog count' do
- expect(status.untrusted_reblogs_count).to eq reblogs
- end
- it 'updates the favourites count' do
- expect(status.untrusted_favourites_count).to eq favourites
- end
- end
- context 'with an implicit update' do
- before do
- status.update!(uri: ActivityPub::TagManager.instance.uri_for(status))
- subject.perform
- end
- it_behaves_like 'updates counts'
- end
- context 'with an explicit update' do
- let(:favourites) { 150 }
- let(:reblogs) { 200 }
- let(:updated) { Time.now.utc.iso8601 }
- before do
- status.update!(uri: ActivityPub::TagManager.instance.uri_for(status))
- subject.perform
- end
- it_behaves_like 'updates counts'
- end
- end
- end
- end
|