2014-08-21 09:51:31 -04:00
|
|
|
namespace :gitlab do
|
|
|
|
namespace :sidekiq do
|
2017-02-22 13:18:40 -05:00
|
|
|
QUEUE = 'queue:post_receive'.freeze
|
2014-08-21 09:51:31 -04:00
|
|
|
|
|
|
|
desc 'Drop all Sidekiq PostReceive jobs for a given project'
|
2017-02-22 13:18:40 -05:00
|
|
|
task :drop_post_receive, [:project] => :environment do |t, args|
|
2014-08-21 09:51:31 -04:00
|
|
|
unless args.project.present?
|
|
|
|
abort "Please specify the project you want to drop PostReceive jobs for:\n rake gitlab:sidekiq:drop_post_receive[group/project]"
|
|
|
|
end
|
2017-02-02 18:43:19 -05:00
|
|
|
project_path = Project.find_by_full_path(args.project).repository.path_to_repo
|
2014-08-21 09:51:31 -04:00
|
|
|
|
|
|
|
Sidekiq.redis do |redis|
|
|
|
|
unless redis.exists(QUEUE)
|
|
|
|
abort "Queue #{QUEUE} is empty"
|
|
|
|
end
|
|
|
|
|
|
|
|
temp_queue = "#{QUEUE}_#{Time.now.to_i}"
|
|
|
|
redis.rename(QUEUE, temp_queue)
|
|
|
|
|
|
|
|
# At this point, then post_receive queue is empty. It may be receiving
|
|
|
|
# new jobs already. We will repopulate it with the old jobs, skipping the
|
|
|
|
# ones we want to drop.
|
|
|
|
dropped = 0
|
2017-02-22 13:18:40 -05:00
|
|
|
while (job = redis.lpop(temp_queue))
|
2014-08-21 09:51:31 -04:00
|
|
|
if repo_path(job) == project_path
|
|
|
|
dropped += 1
|
|
|
|
else
|
|
|
|
redis.rpush(QUEUE, job)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
# The temp_queue will delete itself after we have popped all elements
|
|
|
|
# from it
|
|
|
|
|
|
|
|
puts "Dropped #{dropped} jobs containing #{project_path} from #{QUEUE}"
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def repo_path(job)
|
|
|
|
job_args = JSON.parse(job)['args']
|
|
|
|
if job_args
|
|
|
|
job_args.first
|
|
|
|
else
|
|
|
|
nil
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|