123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134 |
- # frozen_string_literal: true
- require 'rails_helper'
- describe Api::V1::Statuses::ReblogsController do
- render_views
- let(:user) { Fabricate(:user) }
- let(:app) { Fabricate(:application, name: 'Test app', website: 'http://testapp.com') }
- let(:token) { Fabricate(:accessible_access_token, resource_owner_id: user.id, scopes: 'write:statuses', application: app) }
- context 'with an oauth token' do
- around do |example|
- Sidekiq::Testing.fake! do
- example.run
- end
- end
- before do
- allow(controller).to receive(:doorkeeper_token) { token }
- end
- describe 'POST #create' do
- let(:status) { Fabricate(:status, account: user.account) }
- before do
- post :create, params: { status_id: status.id }
- end
- context 'with public status' do
- it 'returns http success' do
- expect(response).to have_http_status(200)
- end
- it 'updates the reblogs count' do
- expect(status.reblogs.count).to eq 1
- end
- it 'updates the reblogged attribute' do
- expect(user.account.reblogged?(status)).to be true
- end
- it 'returns json with updated attributes' do
- 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 #destroy' do
- context 'with public status' do
- let(:status) { Fabricate(:status, account: user.account) }
- before do
- ReblogService.new.call(user.account, status)
- post :destroy, params: { status_id: status.id }
- end
- it 'returns http success' do
- expect(response).to have_http_status(200)
- end
- it 'updates the reblogs count' do
- expect(status.reblogs.count).to eq 0
- end
- it 'updates the reblogged attribute' do
- expect(user.account.reblogged?(status)).to be false
- end
- it 'returns json with updated attributes' do
- 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 :destroy, params: { status_id: status.id }
- end
- it 'returns http success' do
- expect(response).to have_http_status(200)
- end
- it 'updates the reblogs count' do
- expect(status.reblogs.count).to eq 0
- end
- it 'updates the reblogged attribute' do
- expect(user.account.reblogged?(status)).to be false
- end
- it 'returns json with updated attributes' do
- 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 :destroy, params: { status_id: status.id }
- end
- it 'returns http not found' do
- expect(response).to have_http_status(404)
- end
- end
- end
- end
- end
|