diff options
author | GitLab Bot <gitlab-bot@gitlab.com> | 2022-12-20 17:22:11 +0300 |
---|---|---|
committer | GitLab Bot <gitlab-bot@gitlab.com> | 2022-12-20 17:22:11 +0300 |
commit | 0c872e02b2c822e3397515ec324051ff540f0cd5 (patch) | |
tree | ce2fb6ce7030e4dad0f4118d21ab6453e5938cdd /app/workers/bulk_imports/export_request_worker.rb | |
parent | f7e05a6853b12f02911494c4b3fe53d9540d74fc (diff) |
Add latest changes from gitlab-org/gitlab@15-7-stable-eev15.7.0-rc42
Diffstat (limited to 'app/workers/bulk_imports/export_request_worker.rb')
-rw-r--r-- | app/workers/bulk_imports/export_request_worker.rb | 62 |
1 files changed, 27 insertions, 35 deletions
diff --git a/app/workers/bulk_imports/export_request_worker.rb b/app/workers/bulk_imports/export_request_worker.rb index 1a5f6250429..530419dac26 100644 --- a/app/workers/bulk_imports/export_request_worker.rb +++ b/app/workers/bulk_imports/export_request_worker.rb @@ -4,11 +4,15 @@ module BulkImports class ExportRequestWorker include ApplicationWorker - data_consistency :always - idempotent! - worker_has_external_dependencies! + data_consistency :always feature_category :importers + sidekiq_options dead: false, retry: 5 + worker_has_external_dependencies! + + sidekiq_retries_exhausted do |msg, exception| + new.perform_failure(exception, msg['args'].first) + end def perform(entity_id) entity = BulkImports::Entity.find(entity_id) @@ -18,26 +22,12 @@ module BulkImports request_export(entity) BulkImports::EntityWorker.perform_async(entity_id) - rescue BulkImports::NetworkError => e - if e.retriable?(entity) - retry_request(e, entity) - else - log_exception(e, - { - bulk_import_entity_id: entity.id, - bulk_import_id: entity.bulk_import_id, - bulk_import_entity_type: entity.source_type, - source_full_path: entity.source_full_path, - message: "Request to export #{entity.source_type} failed", - source_version: entity.bulk_import.source_version_info.to_s, - importer: 'gitlab_migration' - } - ) - - BulkImports::Failure.create(failure_attributes(e, entity)) - - entity.fail_op! - end + end + + def perform_failure(exception, entity_id) + entity = BulkImports::Entity.find(entity_id) + + log_and_fail(exception, entity) end private @@ -104,30 +94,32 @@ module BulkImports end end - def retry_request(exception, entity) + def logger + @logger ||= Gitlab::Import::Logger.build + end + + def log_exception(exception, payload) + Gitlab::ExceptionLogFormatter.format!(exception, payload) + + logger.error(structured_payload(payload)) + end + + def log_and_fail(exception, entity) log_exception(exception, { - message: 'Retrying export request', bulk_import_entity_id: entity.id, bulk_import_id: entity.bulk_import_id, bulk_import_entity_type: entity.source_type, source_full_path: entity.source_full_path, + message: "Request to export #{entity.source_type} failed", source_version: entity.bulk_import.source_version_info.to_s, importer: 'gitlab_migration' } ) - self.class.perform_in(2.seconds, entity.id) - end - - def logger - @logger ||= Gitlab::Import::Logger.build - end - - def log_exception(exception, payload) - Gitlab::ExceptionLogFormatter.format!(exception, payload) + BulkImports::Failure.create(failure_attributes(exception, entity)) - logger.error(structured_payload(payload)) + entity.fail_op! end end end |