2018-02-26 09:06:04 -05:00
|
|
|
require 'logger'
|
|
|
|
require 'resolv-replace'
|
|
|
|
|
|
|
|
desc "GitLab | Archive legacy traces to trace artifacts"
|
|
|
|
namespace :gitlab do
|
|
|
|
namespace :traces do
|
|
|
|
task archive: :environment do
|
|
|
|
logger = Logger.new(STDOUT)
|
|
|
|
logger.info('Archiving legacy traces')
|
|
|
|
|
2018-06-03 01:21:50 -04:00
|
|
|
Ci::Build.finished.without_archived_trace
|
2018-02-27 11:24:23 -05:00
|
|
|
.order(id: :asc)
|
|
|
|
.find_in_batches(batch_size: 1000) do |jobs|
|
|
|
|
job_ids = jobs.map { |job| [job.id] }
|
2018-02-26 09:06:04 -05:00
|
|
|
|
2018-03-06 06:20:36 -05:00
|
|
|
ArchiveTraceWorker.bulk_perform_async(job_ids)
|
2018-02-27 11:24:23 -05:00
|
|
|
|
2018-02-28 04:43:19 -05:00
|
|
|
logger.info("Scheduled #{job_ids.count} jobs. From #{job_ids.min} to #{job_ids.max}")
|
2018-02-27 11:24:23 -05:00
|
|
|
end
|
2018-02-26 09:06:04 -05:00
|
|
|
end
|
2018-08-16 10:28:47 -04:00
|
|
|
|
|
|
|
task migrate: :environment do
|
|
|
|
logger = Logger.new(STDOUT)
|
|
|
|
logger.info('Starting transfer of job traces')
|
|
|
|
|
|
|
|
Ci::Build.joins(:project)
|
|
|
|
.with_archived_trace_stored_locally
|
|
|
|
.find_each(batch_size: 10) do |build|
|
|
|
|
|
2019-03-13 09:42:43 -04:00
|
|
|
build.job_artifacts_trace.file.migrate!(ObjectStorage::Store::REMOTE)
|
|
|
|
|
|
|
|
logger.info("Transferred job trace of #{build.id} to object storage")
|
|
|
|
rescue => e
|
|
|
|
logger.error("Failed to transfer artifacts of #{build.id} with error: #{e.message}")
|
2018-08-16 10:28:47 -04:00
|
|
|
end
|
|
|
|
end
|
2018-02-26 09:06:04 -05:00
|
|
|
end
|
|
|
|
end
|