From 4cda565a393e4b45d304f093949ebeabc6311fbe Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Tim-Philipp=20M=C3=BCller?= Date: Tue, 21 May 2024 19:31:38 +0100 Subject: [PATCH] gstreamer: bufferlist: add another test for foreach_mut Part-of: --- gstreamer/src/bufferlist.rs | 27 +++++++++++++++++++++++++++ 1 file changed, 27 insertions(+) diff --git a/gstreamer/src/bufferlist.rs b/gstreamer/src/bufferlist.rs index e2eaca2e1..98d6c5bf8 100644 --- a/gstreamer/src/bufferlist.rs +++ b/gstreamer/src/bufferlist.rs @@ -474,5 +474,32 @@ mod tests { res, &[(Some(ClockTime::ZERO), 0), (Some(3 * ClockTime::SECOND), 1)] ); + + // Try removing buffers from inside foreach_mut + let mut buffer_list = BufferList::new(); + for i in 0..10 { + let buffer_list = buffer_list.get_mut().unwrap(); + let mut buffer = Buffer::new(); + buffer.get_mut().unwrap().set_pts(i * ClockTime::SECOND); + buffer_list.add(buffer); + } + + assert_eq!(buffer_list.len(), 10); + + let buffer_list_ref = buffer_list.make_mut(); + + buffer_list_ref.foreach_mut(|buf, _n| { + let keep_packet = (buf.pts().unwrap() / ClockTime::SECOND) % 3 != 0; + ControlFlow::Continue(keep_packet.then_some(buf)) + }); + + assert_eq!(buffer_list.len(), 6); + + let res = buffer_list + .iter() + .map(|buf| buf.pts().unwrap() / ClockTime::SECOND) + .collect::>(); + + assert_eq!(res, &[1, 2, 4, 5, 7, 8]); } }