summaryrefslogtreecommitdiff
path: root/app
diff options
context:
space:
mode:
authorKamil Trzciński <ayufan@ayufan.eu>2015-11-03 13:56:43 +0000
committerKamil Trzciński <ayufan@ayufan.eu>2015-11-03 13:56:43 +0000
commit77ef4855e0b69fa9e7f5501b64d08d3fc0fe1205 (patch)
tree1a373db3309564b59fa85ce9d7615c5d79b7a738 /app
parentb12e17ff5574dd960550a7a4cdf92f22a6e67fb1 (diff)
parent8d2758e02d634fd8518893f39dcc3359284e890f (diff)
downloadgitlab-ce-77ef4855e0b69fa9e7f5501b64d08d3fc0fe1205.tar.gz
Merge branch 'drop-old-builds' into 'master'
Cleanup stuck CI builds Fixes #3143 /cc @dzaporozhets @jacobvosmaer See merge request !1655
Diffstat (limited to 'app')
-rw-r--r--app/workers/stuck_ci_builds_worker.rb18
1 files changed, 18 insertions, 0 deletions
diff --git a/app/workers/stuck_ci_builds_worker.rb b/app/workers/stuck_ci_builds_worker.rb
new file mode 100644
index 00000000000..ad02a3b16d9
--- /dev/null
+++ b/app/workers/stuck_ci_builds_worker.rb
@@ -0,0 +1,18 @@
+class StuckCiBuildsWorker
+ include Sidekiq::Worker
+ include Sidetiq::Schedulable
+
+ BUILD_STUCK_TIMEOUT = 1.day
+
+ recurrence { daily }
+
+ def perform
+ Rails.logger.info 'Cleaning stuck builds'
+
+ builds = Ci::Build.running_or_pending.where('updated_at < ?', BUILD_STUCK_TIMEOUT.ago)
+ builds.find_each(batch_size: 50).each do |build|
+ Rails.logger.debug "Dropping stuck #{build.status} build #{build.id} for runner #{build.runner_id}"
+ build.drop
+ end
+ end
+end