diff options
Diffstat (limited to 'spec/helpers/projects')
-rw-r--r-- | spec/helpers/projects/alert_management_helper_spec.rb | 32 | ||||
-rw-r--r-- | spec/helpers/projects/terraform_helper_spec.rb | 27 |
2 files changed, 34 insertions, 25 deletions
diff --git a/spec/helpers/projects/alert_management_helper_spec.rb b/spec/helpers/projects/alert_management_helper_spec.rb index f6d0c9ca49a..fd35c1ecab8 100644 --- a/spec/helpers/projects/alert_management_helper_spec.rb +++ b/spec/helpers/projects/alert_management_helper_spec.rb @@ -39,28 +39,6 @@ RSpec.describe Projects::AlertManagementHelper do end end - context 'with alerts service' do - let_it_be(:alerts_service) { create(:alerts_service, project: project) } - - context 'when alerts service is active' do - it 'enables alert management' do - expect(data).to include( - 'alert-management-enabled' => 'true' - ) - end - end - - context 'when alerts service is inactive' do - it 'disables alert management' do - alerts_service.update!(active: false) - - expect(data).to include( - 'alert-management-enabled' => 'false' - ) - end - end - end - context 'with prometheus service' do let_it_be(:prometheus_service) { create(:prometheus_service, project: project) } @@ -105,6 +83,16 @@ RSpec.describe Projects::AlertManagementHelper do end end + context 'with an alert' do + let_it_be(:alert) { create(:alert_management_alert, project: project) } + + it 'enables alert management' do + expect(data).to include( + 'alert-management-enabled' => 'true' + ) + end + end + context 'when user does not have requisite enablement permissions' do let(:user_can_enable_alert_management) { false } diff --git a/spec/helpers/projects/terraform_helper_spec.rb b/spec/helpers/projects/terraform_helper_spec.rb index de363c42d21..70b08f4139b 100644 --- a/spec/helpers/projects/terraform_helper_spec.rb +++ b/spec/helpers/projects/terraform_helper_spec.rb @@ -5,10 +5,11 @@ require 'spec_helper' RSpec.describe Projects::TerraformHelper do describe '#js_terraform_list_data' do let_it_be(:project) { create(:project) } + let(:current_user) { project.creator } - subject { helper.js_terraform_list_data(project) } + subject { helper.js_terraform_list_data(current_user, project) } - it 'displays image path' do + it 'includes image path' do image_path = ActionController::Base.helpers.image_path( 'illustrations/empty-state/empty-serverless-lg.svg' ) @@ -16,8 +17,28 @@ RSpec.describe Projects::TerraformHelper do expect(subject[:empty_state_image]).to eq(image_path) end - it 'displays project path' do + it 'includes project path' do expect(subject[:project_path]).to eq(project.full_path) end + + it 'indicates the user is a terraform admin' do + expect(subject[:terraform_admin]).to eq(true) + end + + context 'when current_user is not a terraform admin' do + let(:current_user) { create(:user) } + + it 'indicates the user is not an admin' do + expect(subject[:terraform_admin]).to eq(false) + end + end + + context 'when current_user is missing' do + let(:current_user) { nil } + + it 'indicates the user is not an admin' do + expect(subject[:terraform_admin]).to be_nil + end + end end end |