Commit af4ec86a authored by Mehmet Emin INAC's avatar Mehmet Emin INAC

Handle not existing training ID for securityTrainingUpdate mutation

Changelog: fixed
EE: true
parent e2d52c82
...@@ -8,6 +8,8 @@ module Security ...@@ -8,6 +8,8 @@ module Security
end end
def execute def execute
return error('Updating security training failed! Provider not found.') unless provider
delete? ? delete_training : upsert_training delete? ? delete_training : upsert_training
service_response service_response
...@@ -36,7 +38,10 @@ module Security ...@@ -36,7 +38,10 @@ module Security
end end
def provider def provider
@provider ||= GlobalID::Locator.locate(params[:provider_id]) @provider ||= begin
GlobalID::Locator.locate(params[:provider_id])
rescue ActiveRecord::RecordNotFound
end
end end
def service_response def service_response
......
...@@ -8,14 +8,22 @@ RSpec.describe Security::UpdateTrainingService do ...@@ -8,14 +8,22 @@ RSpec.describe Security::UpdateTrainingService do
let_it_be(:training_provider) { create(:security_training_provider) } let_it_be(:training_provider) { create(:security_training_provider) }
let(:is_primary) { false } let(:is_primary) { false }
let(:params) { { provider_id: training_provider.to_global_id, is_enabled: is_enabled, is_primary: is_primary } } let(:is_enabled) { false }
let(:provider_id) { training_provider.to_global_id }
let(:params) { { provider_id: provider_id, is_enabled: is_enabled, is_primary: is_primary } }
let(:service_object) { described_class.new(project, params) } let(:service_object) { described_class.new(project, params) }
subject(:update_training) { service_object.execute } subject(:update_training) { service_object.execute }
context 'when `is_enabled` argument is false' do context 'when there is no provider with the given id' do
let(:is_enabled) { false } let(:provider_id) { 'gid://gitlab/Security::TrainingProvider/0' }
it 'does not raise error' do
expect { update_training }.not_to raise_error
end
end
context 'when `is_enabled` argument is false' do
context 'when the deletion fails' do context 'when the deletion fails' do
before do before do
allow_next_instance_of(Security::Training) do |training_instance| allow_next_instance_of(Security::Training) do |training_instance|
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment