Commit f81ea006 authored by Sean McGivern's avatar Sean McGivern

Merge branch 'fix/gb/extend-chunk-bucket-exception' into 'master'

Extend exception about chunk data not fulfilled in a bucket

See merge request gitlab-org/gitlab!44007
parents 4089bc95 d7c35163
...@@ -140,8 +140,7 @@ module Ci ...@@ -140,8 +140,7 @@ module Ci
# no chunk with higher index in the database. # no chunk with higher index in the database.
# #
def final? def final?
build.pending_state.present? && build.pending_state.present? && chunks_max_index == chunk_index
build.trace_chunks.maximum(:chunk_index).to_i == chunk_index
end end
def <=>(other) def <=>(other)
...@@ -165,7 +164,14 @@ module Ci ...@@ -165,7 +164,14 @@ module Ci
current_size = current_data&.bytesize.to_i current_size = current_data&.bytesize.to_i
unless current_size == CHUNK_SIZE || final? unless current_size == CHUNK_SIZE || final?
raise FailedToPersistDataError, 'Data is not fulfilled in a bucket' raise FailedToPersistDataError, <<~MSG
data is not fulfilled in a bucket
size: #{current_size}
state: #{build.pending_state.present?}
max: #{chunks_max_index}
index: #{chunk_index}
MSG
end end
self.raw_data = nil self.raw_data = nil
...@@ -223,6 +229,10 @@ module Ci ...@@ -223,6 +229,10 @@ module Ci
self.class.get_store_class(data_store) self.class.get_store_class(data_store)
end end
def chunks_max_index
build.trace_chunks.maximum(:chunk_index).to_i
end
def lock_params def lock_params
["trace_write:#{build_id}:chunks:#{chunk_index}", ["trace_write:#{build_id}:chunks:#{chunk_index}",
{ ttl: WRITE_LOCK_TTL, { ttl: WRITE_LOCK_TTL,
......
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