mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-18 05:16:05 +00:00
multiqueue test: Remove workaround for pad_task hangs
Remove code that isn't needed any longer, which sets the multiqueue to PLAYING and back before unreffing, in order to avoid a deadlock waiting for gstpad tasks that were never started. The problem seems to have been fixed long ago.
This commit is contained in:
parent
eea239f47c
commit
d38933081e
1 changed files with 0 additions and 22 deletions
|
@ -188,12 +188,9 @@ GST_END_TEST;
|
||||||
|
|
||||||
GST_START_TEST (test_request_pads)
|
GST_START_TEST (test_request_pads)
|
||||||
{
|
{
|
||||||
gboolean change_state_before_cleanup = TRUE;
|
|
||||||
GstElement *mq;
|
GstElement *mq;
|
||||||
GstPad *sink1, *sink2;
|
GstPad *sink1, *sink2;
|
||||||
|
|
||||||
again:
|
|
||||||
|
|
||||||
mq = gst_element_factory_make ("multiqueue", NULL);
|
mq = gst_element_factory_make ("multiqueue", NULL);
|
||||||
|
|
||||||
sink1 = gst_element_get_request_pad (mq, "foo%d");
|
sink1 = gst_element_get_request_pad (mq, "foo%d");
|
||||||
|
@ -218,28 +215,10 @@ again:
|
||||||
|
|
||||||
fail_unless (sink1 != sink2);
|
fail_unless (sink1 != sink2);
|
||||||
|
|
||||||
if (change_state_before_cleanup) {
|
|
||||||
/* FIXME: if we don't change state, it will deadlock forever when unref'ing
|
|
||||||
* the queue (waiting for pad tasks to join) */
|
|
||||||
GST_LOG ("Changing state to PLAYING");
|
|
||||||
gst_element_set_state (mq, GST_STATE_PLAYING);
|
|
||||||
g_usleep (G_USEC_PER_SEC);
|
|
||||||
GST_LOG ("Changing state to NULL");
|
|
||||||
gst_element_set_state (mq, GST_STATE_NULL);
|
|
||||||
}
|
|
||||||
|
|
||||||
GST_LOG ("Cleaning up");
|
GST_LOG ("Cleaning up");
|
||||||
gst_object_unref (sink1);
|
gst_object_unref (sink1);
|
||||||
gst_object_unref (sink2);
|
gst_object_unref (sink2);
|
||||||
gst_object_unref (mq);
|
gst_object_unref (mq);
|
||||||
|
|
||||||
/* FIXME: this should work without state change before cleanup as well,
|
|
||||||
* but currently doesn't, see above, so disable this for now */
|
|
||||||
if (change_state_before_cleanup && 0) {
|
|
||||||
change_state_before_cleanup = FALSE;
|
|
||||||
goto again;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
GST_END_TEST;
|
GST_END_TEST;
|
||||||
|
@ -672,7 +651,6 @@ multiqueue_suite (void)
|
||||||
tcase_add_test (tc_chain, test_simple_pipeline);
|
tcase_add_test (tc_chain, test_simple_pipeline);
|
||||||
tcase_add_test (tc_chain, test_simple_shutdown_while_running);
|
tcase_add_test (tc_chain, test_simple_shutdown_while_running);
|
||||||
|
|
||||||
/* FIXME: test_request_pads() needs some more fixes, see comments there */
|
|
||||||
tcase_add_test (tc_chain, test_request_pads);
|
tcase_add_test (tc_chain, test_request_pads);
|
||||||
|
|
||||||
tcase_add_test (tc_chain, test_output_order);
|
tcase_add_test (tc_chain, test_output_order);
|
||||||
|
|
Loading…
Reference in a new issue