Welcome to mirror list, hosted at ThFree Co, Russian Federation.

gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'app/services/error_tracking/issue_latest_event_service.rb')
-rw-r--r--app/services/error_tracking/issue_latest_event_service.rb27
1 files changed, 26 insertions, 1 deletions
diff --git a/app/services/error_tracking/issue_latest_event_service.rb b/app/services/error_tracking/issue_latest_event_service.rb
index a39f1cde1b2..1bf86c658fc 100644
--- a/app/services/error_tracking/issue_latest_event_service.rb
+++ b/app/services/error_tracking/issue_latest_event_service.rb
@@ -5,7 +5,7 @@ module ErrorTracking
private
def perform
- response = project_error_tracking_setting.issue_latest_event(issue_id: params[:issue_id])
+ response = find_issue_latest_event(params[:issue_id])
compose_response(response)
end
@@ -13,5 +13,30 @@ module ErrorTracking
def parse_response(response)
{ latest_event: response[:latest_event] }
end
+
+ def find_issue_latest_event(issue_id)
+ # There are 2 types of the data source for the error tracking feature:
+ #
+ # * When integrated error tracking is enabled, we use the application database
+ # to read and save error tracking data.
+ #
+ # * When integrated error tracking is disabled we call
+ # project_error_tracking_setting method which works with Sentry API.
+ #
+ # Issue https://gitlab.com/gitlab-org/gitlab/-/issues/329596
+ #
+ if project_error_tracking_setting.integrated_client?
+ error = project.error_tracking_errors.find(issue_id)
+ event = error.events.last
+
+ # We use the same response format as project_error_tracking_setting
+ # method below for compatibility with existing code.
+ {
+ latest_event: event.to_sentry_error_event
+ }
+ else
+ project_error_tracking_setting.issue_latest_event(issue_id: issue_id)
+ end
+ end
end
end