Commit af301efb authored by Grzegorz Bizon's avatar Grzegorz Bizon

Resolve live trace read race condition using a retry

This commit makes it possible to retry a trace read operation when an
empty chunk data slice is detected, possibly due to a race condition
between a read operation and trace archive worker migrating data.
parent e96a8b53
...@@ -80,11 +80,9 @@ module Gitlab ...@@ -80,11 +80,9 @@ module Gitlab
job.trace_chunks.any? || current_path.present? || old_trace.present? job.trace_chunks.any? || current_path.present? || old_trace.present?
end end
def read(should_retry: true, &block) def read(&block)
read_stream(&block) read_stream(&block)
rescue Errno::ENOENT rescue Errno::ENOENT, ChunkedIO::FailedToGetChunkError
raise unless should_retry
job.reset job.reset
read_stream(&block) read_stream(&block)
end end
......
...@@ -33,6 +33,16 @@ RSpec.describe Gitlab::Ci::Trace, :clean_gitlab_redis_shared_state, factory_defa ...@@ -33,6 +33,16 @@ RSpec.describe Gitlab::Ci::Trace, :clean_gitlab_redis_shared_state, factory_defa
expect(artifact2.job.trace.raw).to eq(test_data) expect(artifact2.job.trace.raw).to eq(test_data)
end end
it 'reloads the trace in case of a chunk error' do
chunk_error = described_class::ChunkedIO::FailedToGetChunkError
allow_any_instance_of(described_class::Stream)
.to receive(:raw).and_raise(chunk_error)
expect(build).to receive(:reset).and_return(build)
expect { trace.raw }.to raise_error(chunk_error)
end
end end
context 'when live trace feature is disabled' do context 'when live trace feature is disabled' do
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment