/* GStreamer unit test for the autodetect elements * * Copyright (C) <2006> Tim-Philipp Müller * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Library General Public * License as published by the Free Software Foundation; either * version 2 of the License, or (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Library General Public License for more details. * * You should have received a copy of the GNU Library General Public * License along with this library; if not, write to the * Free Software Foundation, Inc., 59 Temple Place - Suite 330, * Boston, MA 02111-1307, USA. */ #ifdef HAVE_CONFIG_H # include #endif #include GST_START_TEST (test_autovideosink_ghostpad_error_case) { GstStateChangeReturn state_ret; GstElement *pipeline, *src, *filter, *sink; GstCaps *caps; /* check that there's a usable video sink (think of build bot case) */ sink = gst_element_factory_make ("autovideosink", NULL); state_ret = gst_element_set_state (sink, GST_STATE_READY); /* need to set state back to NULL, or our test won't work since we * already have detected the real caps in ready and then linking fails */ gst_element_set_state (sink, GST_STATE_NULL); if (state_ret != GST_STATE_CHANGE_SUCCESS) { GST_WARNING ("No usable video sink, skipping test"); gst_object_unref (sink); return; } pipeline = gst_pipeline_new ("pipeline"); src = gst_element_factory_make ("fakesrc", NULL); filter = gst_element_factory_make ("capsfilter", NULL); caps = gst_caps_new_simple ("video/x-raw-yuv", "format", GST_TYPE_FOURCC, GST_MAKE_FOURCC ('A', 'C', 'D', 'C'), NULL); g_object_set (filter, "caps", caps, NULL); gst_caps_unref (caps); gst_bin_add_many (GST_BIN (pipeline), src, filter, sink, NULL); fail_unless (gst_element_link (src, filter)); fail_unless (gst_element_link (filter, sink)); /* this should fail, there's no such format */ state_ret = gst_element_set_state (pipeline, GST_STATE_PAUSED); fail_unless (state_ret == GST_STATE_CHANGE_FAILURE, "pipeline _set_state() to PAUSED succeeded but should have failed"); /* so, we hit an error and try to shut down the pipeline; this shouldn't * deadlock or block anywhere when autovideosink resets the ghostpad * targets etc. */ state_ret = gst_element_set_state (pipeline, GST_STATE_NULL); fail_unless (state_ret == GST_STATE_CHANGE_SUCCESS); /* clean up */ gst_object_unref (pipeline); } GST_END_TEST; /* disable this for now, too many valgrind suppressions needed for libasound */ #if 0 GST_START_TEST (test_autoaudiosink_ghostpad_error_case) { GstStateChangeReturn state_ret; GstElement *pipeline, *src, *filter, *sink; GstCaps *caps; /* check that there's a usable audio sink (think of build bot case) */ sink = gst_element_factory_make ("autoaudiosink", NULL); state_ret = gst_element_set_state (sink, GST_STATE_READY); /* need to set state back to NULL, or our test won't work since we * already have detected the real caps in ready and then linking fails */ gst_element_set_state (sink, GST_STATE_NULL); if (state_ret != GST_STATE_CHANGE_SUCCESS) { GST_WARNING ("No usable audio sink, skipping test"); gst_object_unref (sink); return; } pipeline = gst_pipeline_new ("pipeline"); src = gst_element_factory_make ("fakesrc", NULL); filter = gst_element_factory_make ("capsfilter", NULL); caps = gst_caps_new_simple ("audio/x-raw-int", "width", G_TYPE_INT, 42, NULL); g_object_set (filter, "caps", caps, NULL); gst_caps_unref (caps); gst_bin_add_many (GST_BIN (pipeline), src, filter, sink, NULL); fail_unless (gst_element_link (src, filter)); fail_unless (gst_element_link (filter, sink)); /* this should fail, there's no such width (hopefully) */ state_ret = gst_element_set_state (pipeline, GST_STATE_PAUSED); fail_unless (state_ret == GST_STATE_CHANGE_FAILURE, "pipeline _set_state() to PAUSED succeeded but should have failed"); /* so, we hit an error and try to shut down the pipeline; this shouldn't * deadlock or block anywhere when autoaudiosink resets the ghostpad * targets etc. */ state_ret = gst_element_set_state (pipeline, GST_STATE_NULL); fail_unless (state_ret == GST_STATE_CHANGE_SUCCESS); /* clean up */ gst_object_unref (pipeline); } GST_END_TEST; #endif static Suite * autodetect_suite (void) { guint maj, min, mic, nano; Suite *s = suite_create ("autodetect"); TCase *tc_chain = tcase_create ("general"); suite_add_tcase (s, tc_chain); gst_version (&maj, &min, &mic, &nano); /* requires fixes from 0.10.10.1, but don't want to add a hard dependency * in configure.ac just for this yet */ if (maj > 0 || min > 10 || mic > 10 || (mic == 10 && nano > 0)) { tcase_add_test (tc_chain, test_autovideosink_ghostpad_error_case); /* tcase_add_test (tc_chain, test_autoaudiosink_ghostpad_error_case); */ } return s; } GST_CHECK_MAIN (autodetect);