123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105 |
- # frozen_string_literal: true
- require 'rails_helper'
- describe 'API V1 Statuses Reblogs' do
- let(:user) { Fabricate(:user) }
- let(:token) { Fabricate(:accessible_access_token, resource_owner_id: user.id, scopes: scopes) }
- let(:scopes) { 'write:statuses' }
- let(:headers) { { 'Authorization' => "Bearer #{token.token}" } }
- context 'with an oauth token' do
- describe 'POST /api/v1/statuses/:status_id/reblog' do
- let(:status) { Fabricate(:status, account: user.account) }
- before do
- post "/api/v1/statuses/#{status.id}/reblog", headers: headers
- end
- context 'with public status' do
- it 'reblogs the status', :aggregate_failures do
- expect(response).to have_http_status(200)
- expect(status.reblogs.count).to eq 1
- expect(user.account.reblogged?(status)).to be true
- hash_body = body_as_json
- expect(hash_body[:reblog][:id]).to eq status.id.to_s
- expect(hash_body[:reblog][:reblogs_count]).to eq 1
- expect(hash_body[:reblog][:reblogged]).to be true
- end
- end
- context 'with private status of not-followed account' do
- let(:status) { Fabricate(:status, visibility: :private) }
- it 'returns http not found' do
- expect(response).to have_http_status(404)
- end
- end
- end
- describe 'POST /api/v1/statuses/:status_id/unreblog', :sidekiq_inline do
- context 'with public status' do
- let(:status) { Fabricate(:status, account: user.account) }
- before do
- ReblogService.new.call(user.account, status)
- post "/api/v1/statuses/#{status.id}/unreblog", headers: headers
- end
- it 'destroys the reblog', :aggregate_failures do
- expect(response).to have_http_status(200)
- expect(status.reblogs.count).to eq 0
- expect(user.account.reblogged?(status)).to be false
- hash_body = body_as_json
- expect(hash_body[:id]).to eq status.id.to_s
- expect(hash_body[:reblogs_count]).to eq 0
- expect(hash_body[:reblogged]).to be false
- end
- end
- context 'with public status when blocked by its author' do
- let(:status) { Fabricate(:status, account: user.account) }
- before do
- ReblogService.new.call(user.account, status)
- status.account.block!(user.account)
- post "/api/v1/statuses/#{status.id}/unreblog", headers: headers
- end
- it 'destroys the reblog', :aggregate_failures do
- expect(response).to have_http_status(200)
- expect(status.reblogs.count).to eq 0
- expect(user.account.reblogged?(status)).to be false
- hash_body = body_as_json
- expect(hash_body[:id]).to eq status.id.to_s
- expect(hash_body[:reblogs_count]).to eq 0
- expect(hash_body[:reblogged]).to be false
- end
- end
- context 'with private status that was not reblogged' do
- let(:status) { Fabricate(:status, visibility: :private) }
- before do
- post "/api/v1/statuses/#{status.id}/unreblog", headers: headers
- end
- it 'returns http not found' do
- expect(response).to have_http_status(404)
- end
- end
- end
- end
- end
|