reqwesthttpsrc: Allow a server error after a seek

There might be a server error because a seek would immediately close the
old connection without allowing for clean shutdown.

Fixes https://gitlab.freedesktop.org/gstreamer/gst-plugins-rs/-/issues/527

Part-of: <https://gitlab.freedesktop.org/gstreamer/gst-plugins-rs/-/merge_requests/1861>
This commit is contained in:
Sebastian Dröge 2024-10-18 17:20:31 +03:00 committed by GStreamer Marge Bot
parent 50a48f4b85
commit 3e040c65f1

View file

@ -254,12 +254,17 @@ impl Harness {
fn wait_for_segment(
&mut self,
allow_buffer: bool,
mut allow_server_error: bool,
) -> gst::FormattedSegment<gst::format::Bytes> {
loop {
match self.receiver.as_mut().unwrap().recv().unwrap() {
Message::ServerError(err) => {
if allow_server_error {
allow_server_error = false;
} else {
panic!("Got server error: {err}");
}
}
Message::Event(ev) => {
use gst::EventView;
@ -939,7 +944,7 @@ fn test_seek_after_ready() {
src.set_state(gst::State::Playing).unwrap();
});
let segment = h.wait_for_segment(false);
let segment = h.wait_for_segment(false, true);
assert_eq!(segment.start(), Some(123.bytes()));
let mut expected_output = vec![0; 8192 - 123];
@ -1015,7 +1020,7 @@ fn test_seek_after_buffer_received() {
src.seek_simple(gst::SeekFlags::FLUSH, 123.bytes()).unwrap();
});
let segment = h.wait_for_segment(true);
let segment = h.wait_for_segment(true, true);
assert_eq!(segment.start(), Some(123.bytes()));
let mut expected_output = vec![0; 8192 - 123];
@ -1101,7 +1106,7 @@ fn test_seek_with_stop_position() {
.unwrap();
});
let segment = h.wait_for_segment(true);
let segment = h.wait_for_segment(true, true);
assert_eq!(segment.start(), Some(start));
assert_eq!(segment.stop(), Some(stop));