reactions_controller_spec.rb 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. # frozen_string_literal: true
  2. require 'rails_helper'
  3. RSpec.describe Api::V1::Announcements::ReactionsController do
  4. render_views
  5. let(:user) { Fabricate(:user) }
  6. let(:scopes) { 'write:favourites' }
  7. let(:token) { Fabricate(:accessible_access_token, resource_owner_id: user.id, scopes: scopes) }
  8. let!(:announcement) { Fabricate(:announcement) }
  9. describe 'PUT #update' do
  10. context 'without token' do
  11. it 'returns http unauthorized' do
  12. put :update, params: { announcement_id: announcement.id, id: '😂' }
  13. expect(response).to have_http_status 401
  14. end
  15. end
  16. context 'with token' do
  17. before do
  18. allow(controller).to receive(:doorkeeper_token) { token }
  19. put :update, params: { announcement_id: announcement.id, id: '😂' }
  20. end
  21. it 'creates reaction', :aggregate_failures do
  22. expect(response).to have_http_status(200)
  23. expect(announcement.announcement_reactions.find_by(name: '😂', account: user.account)).to_not be_nil
  24. end
  25. end
  26. end
  27. describe 'DELETE #destroy' do
  28. before do
  29. announcement.announcement_reactions.create!(account: user.account, name: '😂')
  30. end
  31. context 'without token' do
  32. it 'returns http unauthorized' do
  33. delete :destroy, params: { announcement_id: announcement.id, id: '😂' }
  34. expect(response).to have_http_status 401
  35. end
  36. end
  37. context 'with token' do
  38. before do
  39. allow(controller).to receive(:doorkeeper_token) { token }
  40. delete :destroy, params: { announcement_id: announcement.id, id: '😂' }
  41. end
  42. it 'creates reaction', :aggregate_failures do
  43. expect(response).to have_http_status(200)
  44. expect(announcement.announcement_reactions.find_by(name: '😂', account: user.account)).to be_nil
  45. end
  46. end
  47. end
  48. end