diff options
author | Kamil Trzciński <ayufan@ayufan.eu> | 2018-06-06 12:45:41 +0000 |
---|---|---|
committer | Kamil Trzciński <ayufan@ayufan.eu> | 2018-06-06 12:45:41 +0000 |
commit | 96747556e70470caed4175730f9342af2f0f593d (patch) | |
tree | 7e81c63f3b644ee45fd3a328d35c486c2f21b3ad /lib | |
parent | 75ed8a091a2d0d781fcafbc948eb87677fef5ced (diff) | |
parent | dfb0d45ddb0747f5b72e7188d930737d57dabc4c (diff) | |
download | gitlab-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.rb | 24 |
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 |