gitlab-org--gitlab-foss/lib/tasks/gitlab/traces.rake

25 lines
710 B
Ruby
Raw Normal View History

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-02-28 04:43:19 -05:00
Ci::Build.finished
.where('NOT EXISTS (?)',
Ci::JobArtifact.select(1).trace.where('ci_builds.id = ci_job_artifacts.job_id'))
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] }
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
end
end
end