Add test for FanOutOnWriteService

This commit is contained in:
Eugen Rochko 2016-11-06 15:56:34 +01:00
parent 7bb28bf780
commit 93212bc2c4
3 changed files with 45 additions and 2 deletions

View file

@ -15,10 +15,13 @@ class FanOutOnWriteService < BaseService
private
def deliver_to_self(status)
Rails.logger.debug "Delivering status #{status.id} to author"
FeedManager.instance.push(:home, status.account, status)
end
def deliver_to_followers(status)
Rails.logger.debug "Delivering status #{status.id} to followers"
status.account.followers.find_each do |follower|
next if !follower.local? || FeedManager.instance.filter?(:home, status, follower)
FeedManager.instance.push(:home, follower, status)
@ -26,7 +29,9 @@ class FanOutOnWriteService < BaseService
end
def deliver_to_mentioned(status)
status.mentions.find_each do |mention|
Rails.logger.debug "Delivering status #{status.id} to mentioned accounts"
status.mentions.includes(:account).each do |mention|
mentioned_account = mention.account
next if !mentioned_account.local? || mentioned_account.id == status.account_id || FeedManager.instance.filter?(:mentions, status, mentioned_account)
FeedManager.instance.push(:mentions, mentioned_account, status)
@ -34,12 +39,15 @@ class FanOutOnWriteService < BaseService
end
def deliver_to_hashtags(status)
Rails.logger.debug "Delivering status #{status.id} to hashtags"
status.tags.find_each do |tag|
FeedManager.instance.broadcast("hashtag:#{tag.name}", id: status.id)
end
end
def deliver_to_public(status)
Rails.logger.debug "Delivering status #{status.id} to public timeline"
FeedManager.instance.broadcast(:public, id: status.id)
end
end

View file

@ -9,7 +9,7 @@ class FetchRemoteStatusService < BaseService
private
def process_atom(url, body)
Rails.logger.debug 'Processing Atom for remote status'
Rails.logger.debug "Processing Atom for remote status at #{url}"
xml = Nokogiri::XML(body)
account = extract_author(url, xml)