debian-mirror-gitlab/spec/requests/admin/broadcast_messages_controller_spec.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

108 lines
3.8 KiB
Ruby
Raw Normal View History

2022-08-27 11:52:29 +05:30
# frozen_string_literal: true
require 'spec_helper'
RSpec.describe Admin::BroadcastMessagesController, :enable_admin_mode do
2023-01-13 00:05:48 +05:30
let(:broadcast_message) { build(:broadcast_message) }
let(:broadcast_message_params) { broadcast_message.as_json(root: true, only: [:message, :starts_at, :ends_at]) }
let_it_be(:invalid_broadcast_message) { { broadcast_message: { message: '' } } }
let_it_be(:test_message) { 'you owe me a new acorn' }
2022-08-27 11:52:29 +05:30
before do
sign_in(create(:admin))
end
2023-01-13 00:05:48 +05:30
describe 'GET #index' do
it 'renders index template' do
get admin_broadcast_messages_path
expect(response).to have_gitlab_http_status(:ok)
expect(response.body).to render_template(:index)
end
end
2022-08-27 11:52:29 +05:30
describe 'POST /preview' do
it 'renders preview partial' do
post preview_admin_broadcast_messages_path, params: { broadcast_message: { message: "Hello, world!" } }
expect(response).to have_gitlab_http_status(:ok)
expect(response.body).to render_template(:_preview)
end
end
2023-01-13 00:05:48 +05:30
describe 'POST #create' do
context 'when format json' do
it 'persists the message and returns ok on success' do
post admin_broadcast_messages_path(format: :json), params: broadcast_message_params
expect(response).to have_gitlab_http_status(:ok)
expect(Gitlab::Json.parse(response.body)['message']).to eq(broadcast_message.message)
end
it 'does not persist the message on failure' do
post admin_broadcast_messages_path(format: :json), params: invalid_broadcast_message
expect(response).to have_gitlab_http_status(:bad_request)
expect(Gitlab::Json.parse(response.body)['errors']).to be_present
end
end
context 'when format html' do
it 'persists the message and redirects to broadcast_messages on success' do
post admin_broadcast_messages_path(format: :html), params: broadcast_message_params
expect(response).to redirect_to(admin_broadcast_messages_path)
end
it 'does not persist and renders the index page on failure' do
post admin_broadcast_messages_path(format: :html), params: invalid_broadcast_message
expect(response.body).to render_template(:index)
end
end
end
describe 'PATCH #update' do
context 'when format json' do
it 'persists the message and returns ok on success' do
broadcast_message.save!
patch admin_broadcast_message_path(format: :json, id: broadcast_message.id), params: {
broadcast_message: { message: test_message }
}
expect(response).to have_gitlab_http_status(:ok)
expect(Gitlab::Json.parse(response.body)['message']).to eq(test_message)
end
it 'does not persist the message on failure' do
broadcast_message.message = test_message
broadcast_message.save!
patch admin_broadcast_message_path(format: :json, id: broadcast_message.id), params: {
broadcast_message: { message: '' }
}
expect(response).to have_gitlab_http_status(:bad_request)
expect(Gitlab::Json.parse(response.body)['errors']).to be_present
end
end
context 'when format html' do
it 'persists the message and redirects to broadcast_messages on success' do
broadcast_message.save!
patch admin_broadcast_message_path(id: broadcast_message.id), params: {
broadcast_message: { message: test_message }
}
expect(response).to redirect_to(admin_broadcast_messages_path)
end
it 'does not persist and renders the edit page on failure' do
broadcast_message.message = test_message
broadcast_message.save!
patch admin_broadcast_message_path(id: broadcast_message.id), params: {
**invalid_broadcast_message
}
expect(response.body).to render_template(:edit)
end
end
end
2022-08-27 11:52:29 +05:30
end