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/workers/packages')
-rw-r--r--app/workers/packages/composer/cache_cleanup_worker.rb5
-rw-r--r--app/workers/packages/composer/cache_update_worker.rb5
-rw-r--r--app/workers/packages/debian/process_changes_worker.rb50
-rw-r--r--app/workers/packages/go/sync_packages_worker.rb3
-rw-r--r--app/workers/packages/maven/metadata/sync_worker.rb7
-rw-r--r--app/workers/packages/nuget/extraction_worker.rb7
-rw-r--r--app/workers/packages/rubygems/extraction_worker.rb9
7 files changed, 75 insertions, 11 deletions
diff --git a/app/workers/packages/composer/cache_cleanup_worker.rb b/app/workers/packages/composer/cache_cleanup_worker.rb
index 638e50e18c4..1d47ef87962 100644
--- a/app/workers/packages/composer/cache_cleanup_worker.rb
+++ b/app/workers/packages/composer/cache_cleanup_worker.rb
@@ -4,9 +4,12 @@ module Packages
module Composer
class CacheCleanupWorker
include ApplicationWorker
+
+ sidekiq_options retry: 3
include CronjobQueue # rubocop:disable Scalability/CronWorkerContext
feature_category :package_registry
+ tags :exclude_from_kubernetes
idempotent!
@@ -22,7 +25,7 @@ module Packages
rescue ActiveRecord::RecordNotFound
# ignore. likely due to object already being deleted.
end
- rescue => e
+ rescue StandardError => e
Gitlab::ErrorTracking.log_exception(e)
end
end
diff --git a/app/workers/packages/composer/cache_update_worker.rb b/app/workers/packages/composer/cache_update_worker.rb
index 664fb23284f..d87abf2e256 100644
--- a/app/workers/packages/composer/cache_update_worker.rb
+++ b/app/workers/packages/composer/cache_update_worker.rb
@@ -5,7 +5,10 @@ module Packages
class CacheUpdateWorker
include ApplicationWorker
+ sidekiq_options retry: 3
+
feature_category :package_registry
+ tags :exclude_from_kubernetes
idempotent!
@@ -15,7 +18,7 @@ module Packages
return unless project
Gitlab::Composer::Cache.new(project: project, name: package_name, last_page_sha: last_page_sha).execute
- rescue => e
+ rescue StandardError => e
Gitlab::ErrorTracking.log_exception(e, project_id: project_id)
end
end
diff --git a/app/workers/packages/debian/process_changes_worker.rb b/app/workers/packages/debian/process_changes_worker.rb
new file mode 100644
index 00000000000..edc366a7597
--- /dev/null
+++ b/app/workers/packages/debian/process_changes_worker.rb
@@ -0,0 +1,50 @@
+# frozen_string_literal: true
+
+module Packages
+ module Debian
+ class ProcessChangesWorker
+ include ApplicationWorker
+ include Gitlab::Utils::StrongMemoize
+
+ deduplicate :until_executed
+ idempotent!
+
+ queue_namespace :package_repositories
+ feature_category :package_registry
+ tags :exclude_from_kubernetes
+
+ def perform(package_file_id, user_id)
+ @package_file_id = package_file_id
+ @user_id = user_id
+
+ return unless package_file && user
+
+ ::Packages::Debian::ProcessChangesService.new(package_file, user).execute
+ rescue ArgumentError,
+ Packages::Debian::ExtractChangesMetadataService::ExtractionError,
+ Packages::Debian::ExtractDebMetadataService::CommandFailedError,
+ Packages::Debian::ExtractMetadataService::ExtractionError,
+ Packages::Debian::ParseDebian822Service::InvalidDebian822Error,
+ ActiveRecord::RecordNotFound => e
+ Gitlab::ErrorTracking.log_exception(e, package_file_id: @package_file_id, user_id: @user_id)
+ package_file.destroy!
+ end
+
+ private
+
+ attr_reader :package_file_id, :user_id
+
+ def package_file
+ strong_memoize(:package_file) do
+ ::Packages::PackageFile.find_by_id(package_file_id)
+ end
+ end
+
+ def user
+ strong_memoize(:user) do
+ ::User.find_by_id(user_id)
+ end
+ end
+ end
+ end
+end
diff --git a/app/workers/packages/go/sync_packages_worker.rb b/app/workers/packages/go/sync_packages_worker.rb
index e41f27f2252..c5f631c47db 100644
--- a/app/workers/packages/go/sync_packages_worker.rb
+++ b/app/workers/packages/go/sync_packages_worker.rb
@@ -4,10 +4,13 @@ module Packages
module Go
class SyncPackagesWorker
include ApplicationWorker
+
+ sidekiq_options retry: 3
include Gitlab::Golang
queue_namespace :package_repositories
feature_category :package_registry
+ tags :exclude_from_kubernetes
deduplicate :until_executing
idempotent!
diff --git a/app/workers/packages/maven/metadata/sync_worker.rb b/app/workers/packages/maven/metadata/sync_worker.rb
index eb7abf4cdd0..c53117a08c5 100644
--- a/app/workers/packages/maven/metadata/sync_worker.rb
+++ b/app/workers/packages/maven/metadata/sync_worker.rb
@@ -5,10 +5,13 @@ module Packages
module Metadata
class SyncWorker
include ApplicationWorker
+
+ sidekiq_options retry: 3
include Gitlab::Utils::StrongMemoize
queue_namespace :package_repositories
feature_category :package_registry
+ tags :exclude_from_kubernetes
deduplicate :until_executing
idempotent!
@@ -30,10 +33,10 @@ module Packages
if result.success?
log_extra_metadata_on_done(:message, result.message)
else
- raise SyncError.new(result.message)
+ raise SyncError, result.message
end
- raise SyncError.new(result.message) unless result.success?
+ raise SyncError, result.message unless result.success?
end
private
diff --git a/app/workers/packages/nuget/extraction_worker.rb b/app/workers/packages/nuget/extraction_worker.rb
index 820304a9f3b..4128b229ebe 100644
--- a/app/workers/packages/nuget/extraction_worker.rb
+++ b/app/workers/packages/nuget/extraction_worker.rb
@@ -5,6 +5,8 @@ module Packages
class ExtractionWorker # rubocop:disable Scalability/IdempotentWorker
include ApplicationWorker
+ sidekiq_options retry: 3
+
queue_namespace :package_repositories
feature_category :package_registry
@@ -15,10 +17,9 @@ module Packages
::Packages::Nuget::UpdatePackageFromMetadataService.new(package_file).execute
- rescue ::Packages::Nuget::MetadataExtractionService::ExtractionError,
- ::Packages::Nuget::UpdatePackageFromMetadataService::InvalidMetadataError => e
+ rescue StandardError => e
Gitlab::ErrorTracking.log_exception(e, project_id: package_file.project_id)
- package_file.package.destroy!
+ package_file.package.update_column(:status, :error)
end
end
end
diff --git a/app/workers/packages/rubygems/extraction_worker.rb b/app/workers/packages/rubygems/extraction_worker.rb
index 1e5cd0b54ce..fc32654a2c1 100644
--- a/app/workers/packages/rubygems/extraction_worker.rb
+++ b/app/workers/packages/rubygems/extraction_worker.rb
@@ -5,12 +5,13 @@ module Packages
class ExtractionWorker # rubocop:disable Scalability/IdempotentWorker
include ApplicationWorker
+ sidekiq_options retry: 3
+
queue_namespace :package_repositories
feature_category :package_registry
+ tags :exclude_from_kubernetes
deduplicate :until_executing
- idempotent!
-
def perform(package_file_id)
package_file = ::Packages::PackageFile.find_by_id(package_file_id)
@@ -18,9 +19,9 @@ module Packages
::Packages::Rubygems::ProcessGemService.new(package_file).execute
- rescue ::Packages::Rubygems::ProcessGemService::ExtractionError => e
+ rescue StandardError => e
Gitlab::ErrorTracking.log_exception(e, project_id: package_file.project_id)
- package_file.package.destroy!
+ package_file.package.update_column(:status, :error)
end
end
end