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:
Jan Schmidt 2011-01-25 16:09:18 +10:00 committed by Jan Schmidt
parent eea239f47c
commit d38933081e

View file

@ -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);