From 034ae2139d6131e4d2672a484f9a1c14653e526b Mon Sep 17 00:00:00 2001 From: Thomas Vander Stichele Date: Wed, 8 Jun 2005 14:00:21 +0000 Subject: [PATCH] check/: ignore more Original commit message from CVS: * check/gst-libs/.cvsignore: * check/gst/.cvsignore: * check/pipelines/.cvsignore: ignore more * check/pipelines/cleanup.c: (setup_pipeline), (run_pipeline), (START_TEST), (cleanup_suite), (main): add some tests related to cleanup after running pipelines --- ChangeLog | 10 +++ check/gst-libs/.gitignore | 1 + check/gst/.gitignore | 10 ++- check/pipelines/.gitignore | 3 + check/pipelines/cleanup.c | 126 +++++++++++++++++++++++++++++++ tests/check/gst/.gitignore | 10 ++- tests/check/libs/.gitignore | 1 + tests/check/pipelines/.gitignore | 3 + tests/check/pipelines/cleanup.c | 126 +++++++++++++++++++++++++++++++ 9 files changed, 288 insertions(+), 2 deletions(-) create mode 100644 check/pipelines/.gitignore create mode 100644 check/pipelines/cleanup.c create mode 100644 tests/check/pipelines/.gitignore create mode 100644 tests/check/pipelines/cleanup.c diff --git a/ChangeLog b/ChangeLog index 579eed82e5..b8cf3f934b 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,13 @@ +2005-06-08 Thomas Vander Stichele + + * check/gst-libs/.cvsignore: + * check/gst/.cvsignore: + * check/pipelines/.cvsignore: + ignore more + * check/pipelines/cleanup.c: (setup_pipeline), (run_pipeline), + (START_TEST), (cleanup_suite), (main): + add some tests related to cleanup after running pipelines + 2005-06-08 Thomas Vander Stichele * check/gst/gstbuffer.c: (START_TEST), (gst_test_suite), (main): diff --git a/check/gst-libs/.gitignore b/check/gst-libs/.gitignore index 5ad589e106..0c7cfe302d 100644 --- a/check/gst-libs/.gitignore +++ b/check/gst-libs/.gitignore @@ -1 +1,2 @@ +.dirstamp gdp diff --git a/check/gst/.gitignore b/check/gst/.gitignore index 4693cc3916..05e286b28b 100644 --- a/check/gst/.gitignore +++ b/check/gst/.gitignore @@ -1,3 +1,11 @@ -gstobject +.dirstamp +gstbin +gstbuffer +gstbus gstcaps gstdata +gstiterator +gstmessage +gstobject +gstpad +gstsystemclock diff --git a/check/pipelines/.gitignore b/check/pipelines/.gitignore new file mode 100644 index 0000000000..475fc96151 --- /dev/null +++ b/check/pipelines/.gitignore @@ -0,0 +1,3 @@ +.dirstamp +cleanup +simple_launch_lines diff --git a/check/pipelines/cleanup.c b/check/pipelines/cleanup.c new file mode 100644 index 0000000000..d22394cd03 --- /dev/null +++ b/check/pipelines/cleanup.c @@ -0,0 +1,126 @@ +/* GStreamer + * Copyright (C) <2005> Thomas Vander Stichele + * + * cleanup.c: Unit test for cleanup of pipelines + * + * 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. + */ + + +#include "../gstcheck.h" + + +static GstElement * +setup_pipeline (gchar * pipe_descr) +{ + GstElement *pipeline; + + pipeline = gst_parse_launch (pipe_descr, NULL); + g_return_val_if_fail (GST_IS_PIPELINE (pipeline), NULL); + return pipeline; +} + +/* events is a mask of expected events. tevent is the expected terminal event. + the poll call will time out after half a second. + */ +static void +run_pipeline (GstElement * pipe, gchar * descr, + GstMessageType events, GstMessageType tevent) +{ + GstBus *bus; + GstMessageType revent; + + bus = gst_element_get_bus (pipe); + g_assert (bus); + gst_element_set_state (pipe, GST_STATE_PLAYING); + + while (1) { + revent = gst_bus_poll (bus, GST_MESSAGE_ANY, GST_SECOND / 2); + + /* always have to pop the message before getting back into poll */ + if (revent != GST_MESSAGE_UNKNOWN) + gst_message_unref (gst_bus_pop (bus)); + + if (revent == tevent) { + break; + } else if (revent == GST_MESSAGE_UNKNOWN) { + g_critical ("Unexpected timeout in gst_bus_poll, looking for %d: %s", + tevent, descr); + break; + } else if (revent & events) { + continue; + } + g_critical ("Unexpected message received of type %d, looking for %d: %s", + revent, tevent, descr); + } + + gst_element_set_state (pipe, GST_STATE_NULL); + gst_object_unref (GST_OBJECT (pipe)); +} + +START_TEST (test_pipeline_unref) +{ + gchar *s; + gint count; + GstElement *pipeline, *src, *sink; + + s = "fakesrc name=src num-buffers=20 ! fakesink name=sink"; + pipeline = setup_pipeline (s); + /* get_by_name takes a ref */ + src = gst_bin_get_by_name (GST_BIN (pipeline), "src"); + fail_if (src == NULL); + sink = gst_bin_get_by_name (GST_BIN (pipeline), "sink"); + fail_if (sink == NULL); + + run_pipeline (pipeline, s, GST_MESSAGE_STATE_CHANGED, GST_MESSAGE_EOS); + count = GST_OBJECT_REFCOUNT_VALUE (src); + fail_unless (count == 1, "src has a refcount of %d instead of 1", count); + count = GST_OBJECT_REFCOUNT_VALUE (sink); + fail_unless (count == 1, "sink has a refcount of %d instead of 1", count); + gst_object_unref (GST_OBJECT (src)); + gst_object_unref (GST_OBJECT (sink)); +} + +END_TEST Suite * +cleanup_suite (void) +{ + Suite *s = suite_create ("Pipeline cleanup"); + TCase *tc_chain = tcase_create ("linear"); + + /* time out after 20s, not the default 3 */ + tcase_set_timeout (tc_chain, 20); + + suite_add_tcase (s, tc_chain); + tcase_add_test (tc_chain, test_pipeline_unref); + return s; +} + +int +main (int argc, char **argv) +{ + int nf; + + Suite *s = cleanup_suite (); + SRunner *sr = srunner_create (s); + + gst_check_init (&argc, &argv); + + srunner_run_all (sr, CK_NORMAL); + nf = srunner_ntests_failed (sr); + srunner_free (sr); + + return nf; +} diff --git a/tests/check/gst/.gitignore b/tests/check/gst/.gitignore index 4693cc3916..05e286b28b 100644 --- a/tests/check/gst/.gitignore +++ b/tests/check/gst/.gitignore @@ -1,3 +1,11 @@ -gstobject +.dirstamp +gstbin +gstbuffer +gstbus gstcaps gstdata +gstiterator +gstmessage +gstobject +gstpad +gstsystemclock diff --git a/tests/check/libs/.gitignore b/tests/check/libs/.gitignore index 5ad589e106..0c7cfe302d 100644 --- a/tests/check/libs/.gitignore +++ b/tests/check/libs/.gitignore @@ -1 +1,2 @@ +.dirstamp gdp diff --git a/tests/check/pipelines/.gitignore b/tests/check/pipelines/.gitignore new file mode 100644 index 0000000000..475fc96151 --- /dev/null +++ b/tests/check/pipelines/.gitignore @@ -0,0 +1,3 @@ +.dirstamp +cleanup +simple_launch_lines diff --git a/tests/check/pipelines/cleanup.c b/tests/check/pipelines/cleanup.c new file mode 100644 index 0000000000..d22394cd03 --- /dev/null +++ b/tests/check/pipelines/cleanup.c @@ -0,0 +1,126 @@ +/* GStreamer + * Copyright (C) <2005> Thomas Vander Stichele + * + * cleanup.c: Unit test for cleanup of pipelines + * + * 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. + */ + + +#include "../gstcheck.h" + + +static GstElement * +setup_pipeline (gchar * pipe_descr) +{ + GstElement *pipeline; + + pipeline = gst_parse_launch (pipe_descr, NULL); + g_return_val_if_fail (GST_IS_PIPELINE (pipeline), NULL); + return pipeline; +} + +/* events is a mask of expected events. tevent is the expected terminal event. + the poll call will time out after half a second. + */ +static void +run_pipeline (GstElement * pipe, gchar * descr, + GstMessageType events, GstMessageType tevent) +{ + GstBus *bus; + GstMessageType revent; + + bus = gst_element_get_bus (pipe); + g_assert (bus); + gst_element_set_state (pipe, GST_STATE_PLAYING); + + while (1) { + revent = gst_bus_poll (bus, GST_MESSAGE_ANY, GST_SECOND / 2); + + /* always have to pop the message before getting back into poll */ + if (revent != GST_MESSAGE_UNKNOWN) + gst_message_unref (gst_bus_pop (bus)); + + if (revent == tevent) { + break; + } else if (revent == GST_MESSAGE_UNKNOWN) { + g_critical ("Unexpected timeout in gst_bus_poll, looking for %d: %s", + tevent, descr); + break; + } else if (revent & events) { + continue; + } + g_critical ("Unexpected message received of type %d, looking for %d: %s", + revent, tevent, descr); + } + + gst_element_set_state (pipe, GST_STATE_NULL); + gst_object_unref (GST_OBJECT (pipe)); +} + +START_TEST (test_pipeline_unref) +{ + gchar *s; + gint count; + GstElement *pipeline, *src, *sink; + + s = "fakesrc name=src num-buffers=20 ! fakesink name=sink"; + pipeline = setup_pipeline (s); + /* get_by_name takes a ref */ + src = gst_bin_get_by_name (GST_BIN (pipeline), "src"); + fail_if (src == NULL); + sink = gst_bin_get_by_name (GST_BIN (pipeline), "sink"); + fail_if (sink == NULL); + + run_pipeline (pipeline, s, GST_MESSAGE_STATE_CHANGED, GST_MESSAGE_EOS); + count = GST_OBJECT_REFCOUNT_VALUE (src); + fail_unless (count == 1, "src has a refcount of %d instead of 1", count); + count = GST_OBJECT_REFCOUNT_VALUE (sink); + fail_unless (count == 1, "sink has a refcount of %d instead of 1", count); + gst_object_unref (GST_OBJECT (src)); + gst_object_unref (GST_OBJECT (sink)); +} + +END_TEST Suite * +cleanup_suite (void) +{ + Suite *s = suite_create ("Pipeline cleanup"); + TCase *tc_chain = tcase_create ("linear"); + + /* time out after 20s, not the default 3 */ + tcase_set_timeout (tc_chain, 20); + + suite_add_tcase (s, tc_chain); + tcase_add_test (tc_chain, test_pipeline_unref); + return s; +} + +int +main (int argc, char **argv) +{ + int nf; + + Suite *s = cleanup_suite (); + SRunner *sr = srunner_create (s); + + gst_check_init (&argc, &argv); + + srunner_run_all (sr, CK_NORMAL); + nf = srunner_ntests_failed (sr); + srunner_free (sr); + + return nf; +}