Skip to content

Commit

Permalink
Change '>=' back to '>' to fix recycling of blobs/packets (#1192)
Browse files Browse the repository at this point in the history
Recycler will have a strong ref to the item so it will be at
least 1, >= will always prevent recycling.
  • Loading branch information
sakridge authored Sep 11, 2018
1 parent 5d19b79 commit 297f859
Showing 1 changed file with 18 additions and 1 deletion.
19 changes: 18 additions & 1 deletion src/packet.rs
Original file line number Diff line number Diff line change
Expand Up @@ -210,7 +210,7 @@ impl<T: Default + Reset> Recycler<T> {
// be passed across threads ('alloc' is a nightly-only API), and so our
// reference-counted recyclables are awkwardly being recycled by hand,
// which allows this race condition to exist.
if Arc::strong_count(&x) >= 1 {
if Arc::strong_count(&x) > 1 {
// Commenting out this message, is annoying for known use case of
// validator hanging onto a blob in the window, but also sending it over
// to retransmmit_request
Expand Down Expand Up @@ -557,6 +557,23 @@ mod tests {
assert_eq!(r.gc.lock().unwrap().len(), 0);
}

#[test]
pub fn test_recycling_is_happening() {
// Test the case in allocate() which should return a re-used object and not allocate a new
// one.
let r = PacketRecycler::default();
let x0 = r.allocate();
{
x0.write().unwrap().packets.resize(1, Packet::default());
}
r.recycle(x0, "recycle");
let x1 = r.allocate();
assert_ne!(
x1.read().unwrap().packets.len(),
Packets::default().packets.len()
);
}

#[test]
pub fn blob_recycler_test() {
let r = BlobRecycler::default();
Expand Down

0 comments on commit 297f859

Please sign in to comment.