diff --git a/ChangeLog b/ChangeLog index 4299469338..1be0c6ab20 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,10 @@ +2005-02-23 Andy Wingo + + * check/Makefile.am (TESTS): Add pipelines/simple_launch_lines. + + * check/pipelines/simple_launch_lines.c: New test suite for simple + gst-launch lines. Just a beginning right now. + 2005-02-23 Wim Taymans * configure.ac: diff --git a/check/Makefile.am b/check/Makefile.am index 5d1fe03b87..de530da0c7 100644 --- a/check/Makefile.am +++ b/check/Makefile.am @@ -27,7 +27,8 @@ TESTS = \ gst/gstdata \ gst/gstobject \ gst/gstpad \ - gst-libs/gdp + gst-libs/gdp \ + pipelines/simple_launch_lines check_PROGRAMS = $(TESTS) diff --git a/check/pipelines/simple_launch_lines.c b/check/pipelines/simple_launch_lines.c new file mode 100644 index 0000000000..93d6a10ccd --- /dev/null +++ b/check/pipelines/simple_launch_lines.c @@ -0,0 +1,102 @@ +/* GStreamer + * Copyright (C) 2005 Andy Wingo + * + * gstcaps.c: Unit test for GstCaps + * + * 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, 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); + if (revent == tevent) { + break; + } else if (revent == GST_MESSAGE_UNKNOWN) { + g_critical ("Unexpected timeout in gst_bus_poll, looking for %d", tevent); + break; + } else if (revent & events) { + continue; + } + g_critical ("Unexpected message received of type %d!", revent); + } + + gst_element_set_state (pipe, GST_STATE_NULL); + gst_object_unref (GST_OBJECT (pipe)); +} + +START_TEST (test_2_elements) +{ + gchar *s; + + s = "fakesrc ! fakesink"; + run_pipeline (setup_pipeline (s), + GST_MESSAGE_STATE_CHANGED, GST_MESSAGE_UNKNOWN); +} +END_TEST Suite * simple_launch_lines_suite (void) +{ + Suite *s = suite_create ("Pipelines"); + 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_2_elements); + return s; +} + +int +main (int argc, char **argv) +{ + int nf; + + Suite *s = simple_launch_lines_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/Makefile.am b/tests/check/Makefile.am index 5d1fe03b87..de530da0c7 100644 --- a/tests/check/Makefile.am +++ b/tests/check/Makefile.am @@ -27,7 +27,8 @@ TESTS = \ gst/gstdata \ gst/gstobject \ gst/gstpad \ - gst-libs/gdp + gst-libs/gdp \ + pipelines/simple_launch_lines check_PROGRAMS = $(TESTS) diff --git a/tests/check/pipelines/simple-launch-lines.c b/tests/check/pipelines/simple-launch-lines.c new file mode 100644 index 0000000000..93d6a10ccd --- /dev/null +++ b/tests/check/pipelines/simple-launch-lines.c @@ -0,0 +1,102 @@ +/* GStreamer + * Copyright (C) 2005 Andy Wingo + * + * gstcaps.c: Unit test for GstCaps + * + * 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, 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); + if (revent == tevent) { + break; + } else if (revent == GST_MESSAGE_UNKNOWN) { + g_critical ("Unexpected timeout in gst_bus_poll, looking for %d", tevent); + break; + } else if (revent & events) { + continue; + } + g_critical ("Unexpected message received of type %d!", revent); + } + + gst_element_set_state (pipe, GST_STATE_NULL); + gst_object_unref (GST_OBJECT (pipe)); +} + +START_TEST (test_2_elements) +{ + gchar *s; + + s = "fakesrc ! fakesink"; + run_pipeline (setup_pipeline (s), + GST_MESSAGE_STATE_CHANGED, GST_MESSAGE_UNKNOWN); +} +END_TEST Suite * simple_launch_lines_suite (void) +{ + Suite *s = suite_create ("Pipelines"); + 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_2_elements); + return s; +} + +int +main (int argc, char **argv) +{ + int nf; + + Suite *s = simple_launch_lines_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; +}