]> cat aescling's git repositories - mastodon.git/commitdiff
Fix NoMethodError in StatusUpdateDistributionWorker (#17499)
authorClaire <claire.github-309c@sitedethib.com>
Thu, 10 Feb 2022 13:57:10 +0000 (14:57 +0100)
committerGitHub <noreply@github.com>
Thu, 10 Feb 2022 13:57:10 +0000 (14:57 +0100)
* Add tests

* Fix NoMethodError in StatusUpdateDistributionWorker

* Fix tests

app/workers/activitypub/status_update_distribution_worker.rb
spec/workers/activitypub/status_update_distribution_worker_spec.rb [new file with mode: 0644]

index 261aaa0cc8a18baf8d4eeb1dd8a07e186a0ff63d..a79ede2bf61104e0348b06a79bcb986c7e6042e5 100644 (file)
@@ -6,6 +6,7 @@ class ActivityPub::StatusUpdateDistributionWorker < ActivityPub::DistributionWor
   def perform(status_id, options = {})
     @options = options.with_indifferent_access
     @status  = Status.find(status_id)
+    @account = @status.account
 
     distribute!
   rescue ActiveRecord::RecordNotFound
diff --git a/spec/workers/activitypub/status_update_distribution_worker_spec.rb b/spec/workers/activitypub/status_update_distribution_worker_spec.rb
new file mode 100644 (file)
index 0000000..6633b60
--- /dev/null
@@ -0,0 +1,48 @@
+require 'rails_helper'
+
+describe ActivityPub::StatusUpdateDistributionWorker do
+  subject { described_class.new }
+
+  let(:status)   { Fabricate(:status, text: 'foo') }
+  let(:follower) { Fabricate(:account, protocol: :activitypub, inbox_url: 'http://example.com') }
+
+  describe '#perform' do
+    before do
+      follower.follow!(status.account)
+
+      status.snapshot!
+      status.text = 'bar'
+      status.edited_at = Time.now.utc
+      status.snapshot!
+      status.save!
+    end
+
+    context 'with public status' do
+      before do
+        status.update(visibility: :public)
+      end
+
+      it 'delivers to followers' do
+        expect(ActivityPub::DeliveryWorker).to receive(:push_bulk) do |items, &block|
+          expect(items.map(&block)).to match([[kind_of(String), status.account.id, 'http://example.com', anything]])
+        end
+
+        subject.perform(status.id)
+      end
+    end
+
+    context 'with private status' do
+      before do
+        status.update(visibility: :private)
+      end
+
+      it 'delivers to followers' do
+        expect(ActivityPub::DeliveryWorker).to receive(:push_bulk) do |items, &block|
+          expect(items.map(&block)).to match([[kind_of(String), status.account.id, 'http://example.com', anything]])
+        end
+
+        subject.perform(status.id)
+      end
+    end
+  end
+end