From c414f782488e8f09bb2ddb5022a11a1e5130b134 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Fran=C3=A7ois=20Laignel?= Date: Tue, 28 Apr 2020 20:29:14 +0200 Subject: [PATCH] threadshare: fix race condition in tcpclientsrc test --- generic/threadshare/tests/tcpclientsrc.rs | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/generic/threadshare/tests/tcpclientsrc.rs b/generic/threadshare/tests/tcpclientsrc.rs index f545861c..899d8f7f 100644 --- a/generic/threadshare/tests/tcpclientsrc.rs +++ b/generic/threadshare/tests/tcpclientsrc.rs @@ -20,6 +20,7 @@ use glib::prelude::*; use gst::prelude::*; use std::io::Write; +use std::sync::mpsc; use std::sync::{Arc, Mutex}; use std::{thread, time}; @@ -37,10 +38,12 @@ fn init() { fn test_push() { init(); + let (listening_tx, listening_rx) = mpsc::channel(); let handler = thread::spawn(move || { use std::net; let listener = net::TcpListener::bind("0.0.0.0:5000").unwrap(); + listening_tx.send(()).unwrap(); let stream = listener.incoming().next().unwrap(); let buffer = [0; 160]; let mut socket = stream.unwrap(); @@ -84,6 +87,8 @@ fn test_push() { Ok(gst::FlowSuccess::Ok) }); + // Wait for the server to listen + listening_rx.recv().unwrap(); pipeline.set_state(gst::State::Playing).unwrap(); let mut eos = false; @@ -95,7 +100,7 @@ fn test_push() { eos = true; break; } - MessageView::Error(..) => unreachable!(), + MessageView::Error(err) => panic!("{:?}", err), _ => (), } }