summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorKamil Trzciński <ayufan@ayufan.eu>2018-06-06 12:45:41 +0000
committerKamil Trzciński <ayufan@ayufan.eu>2018-06-06 12:45:41 +0000
commit96747556e70470caed4175730f9342af2f0f593d (patch)
tree7e81c63f3b644ee45fd3a328d35c486c2f21b3ad /lib
parent75ed8a091a2d0d781fcafbc948eb87677fef5ced (diff)
parentdfb0d45ddb0747f5b72e7188d930737d57dabc4c (diff)
downloadgitlab-ce-96747556e70470caed4175730f9342af2f0f593d.tar.gz
Merge branch 'live-trace-v2-persist-data' into 'master'
Live trace: Rescue stale live trace See merge request gitlab-org/gitlab-ce!18680
Diffstat (limited to 'lib')
-rw-r--r--lib/gitlab/ci/trace.rb24
1 files changed, 22 insertions, 2 deletions
diff --git a/lib/gitlab/ci/trace.rb b/lib/gitlab/ci/trace.rb
index fe15fabc2e8..a52d71225bb 100644
--- a/lib/gitlab/ci/trace.rb
+++ b/lib/gitlab/ci/trace.rb
@@ -1,6 +1,10 @@
module Gitlab
module Ci
class Trace
+ include ExclusiveLeaseGuard
+
+ LEASE_TIMEOUT = 1.hour
+
ArchiveError = Class.new(StandardError)
attr_reader :job
@@ -105,6 +109,14 @@ module Gitlab
end
def archive!
+ try_obtain_lease do
+ unsafe_archive!
+ end
+ end
+
+ private
+
+ def unsafe_archive!
raise ArchiveError, 'Already archived' if trace_artifact
raise ArchiveError, 'Job is not finished yet' unless job.complete?
@@ -126,8 +138,6 @@ module Gitlab
end
end
- private
-
def archive_stream!(stream)
clone_file!(stream, JobArtifactUploader.workhorse_upload_path) do |clone_path|
create_build_trace!(job, clone_path)
@@ -206,6 +216,16 @@ module Gitlab
def trace_artifact
job.job_artifacts_trace
end
+
+ # For ExclusiveLeaseGuard concern
+ def lease_key
+ @lease_key ||= "trace:archive:#{job.id}"
+ end
+
+ # For ExclusiveLeaseGuard concern
+ def lease_timeout
+ LEASE_TIMEOUT
+ end
end
end
end