forked from mirrors/catstodon
Fix change of status callbacks not setting in_reply_to_account_id and (#3072)
possibly others when expected. Add some tests for it
This commit is contained in:
parent
85c9496340
commit
af706583bd
2 changed files with 14 additions and 4 deletions
|
@ -72,7 +72,7 @@ class Status < ApplicationRecord
|
||||||
cache_associated :account, :application, :media_attachments, :tags, :stream_entry, mentions: :account, reblog: [:account, :application, :stream_entry, :tags, :media_attachments, mentions: :account], thread: :account
|
cache_associated :account, :application, :media_attachments, :tags, :stream_entry, mentions: :account, reblog: [:account, :application, :stream_entry, :tags, :media_attachments, mentions: :account], thread: :account
|
||||||
|
|
||||||
def reply?
|
def reply?
|
||||||
!in_reply_to_id.nil? || super
|
!in_reply_to_id.nil? || attributes['reply']
|
||||||
end
|
end
|
||||||
|
|
||||||
def local?
|
def local?
|
||||||
|
@ -144,9 +144,9 @@ class Status < ApplicationRecord
|
||||||
end
|
end
|
||||||
|
|
||||||
before_validation :prepare_contents
|
before_validation :prepare_contents
|
||||||
before_create :set_reblog
|
before_validation :set_reblog
|
||||||
before_create :set_visibility
|
before_validation :set_visibility
|
||||||
before_create :set_conversation
|
before_validation :set_conversation
|
||||||
|
|
||||||
class << self
|
class << self
|
||||||
def in_allowed_languages(account)
|
def in_allowed_languages(account)
|
||||||
|
|
|
@ -31,6 +31,16 @@ RSpec.describe ProcessFeedService do
|
||||||
expect(Status.find_by(uri: 'tag:kickass.zone,2016-10-10:objectId=2:objectType=Status')).to_not be_nil
|
expect(Status.find_by(uri: 'tag:kickass.zone,2016-10-10:objectId=2:objectType=Status')).to_not be_nil
|
||||||
end
|
end
|
||||||
|
|
||||||
|
it 'marks replies as replies' do
|
||||||
|
status = Status.find_by(uri: 'tag:kickass.zone,2016-10-10:objectId=2:objectType=Status')
|
||||||
|
expect(status.reply?).to be true
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'sets account being replied to when possible' do
|
||||||
|
status = Status.find_by(uri: 'tag:kickass.zone,2016-10-10:objectId=2:objectType=Status')
|
||||||
|
expect(status.in_reply_to_account_id).to eq status.account_id
|
||||||
|
end
|
||||||
|
|
||||||
it 'ignores delete statuses unless they existed before' do
|
it 'ignores delete statuses unless they existed before' do
|
||||||
expect(Status.find_by(uri: 'tag:kickass.zone,2016-10-10:objectId=3:objectType=Status')).to be_nil
|
expect(Status.find_by(uri: 'tag:kickass.zone,2016-10-10:objectId=3:objectType=Status')).to be_nil
|
||||||
expect(Status.find_by(uri: 'tag:kickass.zone,2016-10-10:objectId=12:objectType=Status')).to be_nil
|
expect(Status.find_by(uri: 'tag:kickass.zone,2016-10-10:objectId=12:objectType=Status')).to be_nil
|
||||||
|
|
Loading…
Reference in a new issue