enum type: [:image, :gifv, :video, :unknown, :audio]
+ MAX_DESCRIPTION_LENGTH = 1_500
+
IMAGE_FILE_EXTENSIONS = %w(.jpg .jpeg .png .gif).freeze
VIDEO_FILE_EXTENSIONS = %w(.webm .mp4 .m4v .mov).freeze
AUDIO_FILE_EXTENSIONS = %w(.ogg .oga .mp3 .wav .flac .opus .aac .m4a .3gp .wma).freeze
include Attachmentable
validates :account, presence: true
- validates :description, length: { maximum: 1_500 }, if: :local?
+ validates :description, length: { maximum: MAX_DESCRIPTION_LENGTH }, if: :local?
scope :attached, -> { where.not(status_id: nil).or(where.not(scheduled_status_id: nil)) }
scope :unattached, -> { where(status_id: nil, scheduled_status_id: nil) }
end
def prepare_description
- self.description = description.strip[0...420] unless description.nil?
+ self.description = description.strip[0...MAX_DESCRIPTION_LENGTH] unless description.nil?
end
def set_type_and_extension
end
end
+
+ context 'with media attachments with long description' do
+ let(:object_json) do
+ {
+ id: [ActivityPub::TagManager.instance.uri_for(sender), '#bar'].join,
+ type: 'Note',
+ content: 'Lorem ipsum',
+ attachment: [
+ {
+ type: 'Document',
+ mediaType: 'image/png',
+ url: 'http://example.com/attachment.png',
+ name: '*' * 1500,
+ },
+ ],
+ }
+ end
+
+ it 'creates status' do
+ status = sender.statuses.first
+
+ expect(status).to_not be_nil
+ expect(status.media_attachments.map(&:description)).to include('*' * 1500)
+ end
+ end
+
context 'with media attachments with focal points' do
let(:object_json) do
{
end
describe 'descriptions for remote attachments' do
- it 'are cut off at 140 characters' do
+ it 'are cut off at 1500 characters' do
media = Fabricate(:media_attachment, description: 'foo' * 1000, remote_url: 'http://example.com/blah.jpg')
- expect(media.description.size).to be <= 420
+ expect(media.description.size).to be <= 1_500
end
end
end