feat: Delete notification by id API (#8430)

This commit is contained in:
Muhsin Keloth
2023-11-29 22:45:11 +05:30
committed by GitHub
parent 683f9d9a28
commit bc6e3e598f
3 changed files with 33 additions and 2 deletions

View File

@@ -1,7 +1,7 @@
class Api::V1::Accounts::NotificationsController < Api::V1::Accounts::BaseController
RESULTS_PER_PAGE = 15
before_action :fetch_notification, only: [:update]
before_action :fetch_notification, only: [:update, :destroy]
before_action :set_primary_actor, only: [:read_all]
before_action :set_current_page, only: [:index]
@@ -28,6 +28,11 @@ class Api::V1::Accounts::NotificationsController < Api::V1::Accounts::BaseContro
render json: @notification
end
def destroy
@notification.destroy
head :ok
end
def unread_count
@unread_count = current_user.notifications.where(account_id: current_account.id, read_at: nil).count
render json: @unread_count

View File

@@ -166,7 +166,7 @@ Rails.application.routes.draw do
end
end
resources :notifications, only: [:index, :update] do
resources :notifications, only: [:index, :update, :destroy] do
collection do
post :read_all
get :unread_count

View File

@@ -127,4 +127,30 @@ RSpec.describe 'Notifications API', type: :request do
end
end
end
describe 'DELETE /api/v1/accounts/{account.id}/notifications/:id' do
let(:admin) { create(:user, account: account, role: :administrator) }
let!(:notification) { create(:notification, account: account, user: admin) }
context 'when it is an unauthenticated user' do
it 'returns unauthorized' do
delete "/api/v1/accounts/#{account.id}/notifications/#{notification.id}"
expect(response).to have_http_status(:unauthorized)
end
end
context 'when it is an authenticated user' do
let(:admin) { create(:user, account: account, role: :administrator) }
it 'deletes the notification' do
delete "/api/v1/accounts/#{account.id}/notifications/#{notification.id}",
headers: admin.create_new_auth_token,
as: :json
expect(response).to have_http_status(:success)
expect(Notification.count).to eq(0)
end
end
end
end