diff options
Diffstat (limited to 'spec/helpers/broadcast_messages_helper_spec.rb')
-rw-r--r-- | spec/helpers/broadcast_messages_helper_spec.rb | 187 |
1 files changed, 0 insertions, 187 deletions
diff --git a/spec/helpers/broadcast_messages_helper_spec.rb b/spec/helpers/broadcast_messages_helper_spec.rb deleted file mode 100644 index 05e745e249e..00000000000 --- a/spec/helpers/broadcast_messages_helper_spec.rb +++ /dev/null @@ -1,187 +0,0 @@ -# frozen_string_literal: true - -require 'spec_helper' - -RSpec.describe BroadcastMessagesHelper, feature_category: :onboarding do - include Gitlab::Routing.url_helpers - - let_it_be(:user) { create(:user) } - - before do - allow(helper).to receive(:current_user).and_return(user) - end - - shared_examples 'returns role-targeted broadcast message when in project, group, or sub-group URL' do - before do - allow(helper).to receive(:cookies).and_return({}) - end - - context 'when in a project page' do - let_it_be(:project) { create(:project) } - - before do - project.add_developer(user) - - assign(:project, project) - allow(helper).to receive(:controller) { ProjectsController.new } - end - - it { is_expected.to eq message } - end - - context 'when in a group page' do - let_it_be(:group) { create(:group) } - - before do - group.add_developer(user) - - assign(:group, group) - allow(helper).to receive(:controller) { GroupsController.new } - end - - it { is_expected.to eq message } - end - - context 'when not in a project, group, or sub-group page' do - it { is_expected.to be_nil } - end - end - - describe '#current_broadcast_notification_message' do - subject { helper.current_broadcast_notification_message } - - context 'with available broadcast notification messages' do - let!(:broadcast_message_1) do - create(:broadcast_message, broadcast_type: 'notification', starts_at: Time.now - 1.day) - end - - let!(:broadcast_message_2) { create(:broadcast_message, broadcast_type: 'notification', starts_at: Time.now) } - - it { is_expected.to eq broadcast_message_2 } - - context 'when last broadcast message is hidden' do - before do - helper.request.cookies["hide_broadcast_message_#{broadcast_message_2.id}"] = 'true' - end - - it { is_expected.to eq broadcast_message_1 } - end - end - - context 'without broadcast notification messages' do - it { is_expected.to be_nil } - end - - describe 'user access level targeted messages' do - let_it_be(:message) do - create(:broadcast_message, - broadcast_type: 'notification', - starts_at: Time.now, - target_access_levels: [Gitlab::Access::DEVELOPER] - ) - end - - include_examples 'returns role-targeted broadcast message when in project, group, or sub-group URL' - end - end - - describe '#current_broadcast_banner_messages' do - describe 'user access level targeted messages' do - let_it_be(:message) do - create(:broadcast_message, - broadcast_type: 'banner', - starts_at: Time.now, - target_access_levels: [Gitlab::Access::DEVELOPER] - ) - end - - subject { helper.current_broadcast_banner_messages.first } - - include_examples 'returns role-targeted broadcast message when in project, group, or sub-group URL' - end - end - - describe '#broadcast_message' do - let(:current_broadcast_message) { BroadcastMessage.new(message: 'Current Message') } - - it 'returns nil when no current message' do - expect(helper.broadcast_message(nil)).to be_nil - end - - it 'includes the current message' do - expect(helper.broadcast_message(current_broadcast_message)).to include 'Current Message' - end - end - - describe '#broadcast_message_status' do - it 'returns Active' do - message = build(:broadcast_message) - - expect(helper.broadcast_message_status(message)).to eq 'Active' - end - - it 'returns Expired' do - message = build(:broadcast_message, :expired) - - expect(helper.broadcast_message_status(message)).to eq 'Expired' - end - - it 'returns Pending' do - message = build(:broadcast_message, :future) - - expect(helper.broadcast_message_status(message)).to eq 'Pending' - end - end - - describe '#admin_broadcast_messages_data' do - let(:starts_at) { 1.day.ago } - let(:ends_at) { 1.day.from_now } - let(:message) { build(:broadcast_message, id: non_existing_record_id, starts_at: starts_at, ends_at: ends_at) } - - subject(:single_broadcast_message) { Gitlab::Json.parse(admin_broadcast_messages_data([message])).first } - - it 'returns the expected messages data attributes' do - keys = %w[ - id - status - message - theme - broadcast_type - dismissable - starts_at - ends_at - target_roles - target_path - type edit_path - delete_path - ] - - expect(single_broadcast_message.keys).to match(keys) - end - - it 'has the correct iso formatted date', time_travel_to: '2020-01-01 00:00:00 +0000' do - expect(single_broadcast_message['starts_at']).to eq('2019-12-31T00:00:00Z') - expect(single_broadcast_message['ends_at']).to eq('2020-01-02T00:00:00Z') - end - end - - describe '#broadcast_message_data' do - let(:starts_at) { 1.day.ago } - let(:ends_at) { 1.day.from_now } - let(:message) { build(:broadcast_message, id: non_existing_record_id, starts_at: starts_at, ends_at: ends_at) } - - it 'returns the expected message data attributes' do - keys = [ - :id, :message, :broadcast_type, :theme, :dismissable, :target_access_levels, :messages_path, - :preview_path, :target_path, :starts_at, :ends_at, :target_access_level_options, :show_in_cli - ] - - expect(broadcast_message_data(message).keys).to match(keys) - end - - it 'has the correct iso formatted date', time_travel_to: '2020-01-01 00:00:00 +0000' do - expect(broadcast_message_data(message)[:starts_at]).to eq('2019-12-31T00:00:00Z') - expect(broadcast_message_data(message)[:ends_at]).to eq('2020-01-02T00:00:00Z') - end - end -end |