Browse Source

Add specs for media attachment validations

There are currently not specs for the two media validations that are performed
by `PostStatusService`. This adds specs for the validations that ensure that you
cannot attach more than four files, and that a status cannot have both image and
video attachments.
master
Chad Pytel 7 years ago
parent
commit
38bec79811
2 changed files with 42 additions and 1 deletions
  1. +1
    -1
      spec/fabricators/media_attachment_fabricator.rb
  2. +41
    -0
      spec/services/post_status_service_spec.rb

+ 1
- 1
spec/fabricators/media_attachment_fabricator.rb View File

@ -1,3 +1,3 @@
Fabricator(:media_attachment) do
account
end

+ 41
- 0
spec/services/post_status_service_spec.rb View File

@ -7,4 +7,45 @@ RSpec.describe PostStatusService do
it 'creates a new response status'
it 'processes mentions'
it 'pings PuSH hubs'
it 'does not allow attaching more than 4 files' do
account = Fabricate(:account)
expect do
PostStatusService.new.call(
account,
"test status update",
nil,
media_ids: [
Fabricate(:media_attachment, account: account),
Fabricate(:media_attachment, account: account),
Fabricate(:media_attachment, account: account),
Fabricate(:media_attachment, account: account),
Fabricate(:media_attachment, account: account),
].map(&:id),
)
end.to raise_error(
Mastodon::ValidationError,
'Cannot attach more than 4 files',
)
end
it 'does not allow attaching both videos and images' do
account = Fabricate(:account)
expect do
PostStatusService.new.call(
account,
"test status update",
nil,
media_ids: [
Fabricate(:media_attachment, type: :video, account: account),
Fabricate(:media_attachment, type: :image, account: account),
].map(&:id),
)
end.to raise_error(
Mastodon::ValidationError,
'Cannot attach a video to a toot that already contains images',
)
end
end

Loading…
Cancel
Save