Skip to content

Commit

Permalink
Fix PutPayloadMut::push not updating content_length (#5743)
Browse files Browse the repository at this point in the history
  • Loading branch information
tustvold committed May 10, 2024
1 parent b25c441 commit 08de94c
Show file tree
Hide file tree
Showing 2 changed files with 25 additions and 1 deletion.
10 changes: 10 additions & 0 deletions object_store/src/integration.rs
Original file line number Diff line number Diff line change
Expand Up @@ -789,6 +789,16 @@ pub async fn stream_get(storage: &DynObjectStore) {
let bytes_written = storage.get(&location).await.unwrap().bytes().await.unwrap();
assert_eq!(bytes_expected, bytes_written);

let location = Path::from("test_dir/test_put_part.txt");
let upload = storage.put_multipart(&location).await.unwrap();
let mut write = WriteMultipart::new(upload);
write.put(vec![0; 2].into());
write.put(vec![3; 4].into());
write.finish().await.unwrap();

let meta = storage.head(&location).await.unwrap();
assert_eq!(meta.size, 6);

// We can abort an empty write
let location = Path::from("test_dir/test_abort_upload.txt");
let mut upload = storage.put_multipart(&location).await.unwrap();
Expand Down
16 changes: 15 additions & 1 deletion object_store/src/payload.rs
Original file line number Diff line number Diff line change
Expand Up @@ -252,7 +252,8 @@ impl PutPayloadMut {
let completed = std::mem::take(&mut self.in_progress);
self.completed.push(completed.into())
}
self.completed.push(bytes)
self.len += bytes.len();
self.completed.push(bytes);
}

/// Returns `true` if this [`PutPayloadMut`] contains no bytes
Expand Down Expand Up @@ -311,4 +312,17 @@ mod test {
assert_eq!(chunks[4].len(), 20);
assert_eq!(chunks[5].len(), 6);
}

#[test]
fn test_content_length() {
let mut chunk = PutPayloadMut::new();
chunk.push(vec![0; 23].into());
assert_eq!(chunk.content_length(), 23);
chunk.extend_from_slice(&[0; 4]);
assert_eq!(chunk.content_length(), 27);
chunk.push(vec![0; 121].into());
assert_eq!(chunk.content_length(), 148);
let payload = chunk.freeze();
assert_eq!(payload.content_length(), 148);
}
}

0 comments on commit 08de94c

Please sign in to comment.