From a6457e165d6567e4f5fbd9e007da33d7743ac35a Mon Sep 17 00:00:00 2001 From: Thomas Vander Stichele Date: Tue, 27 Mar 2007 09:37:42 +0000 Subject: [PATCH] commit new file Original commit message from CVS: commit new file --- tests/check/pipelines/vorbisdec.c | 125 ++++++++++++++++++++++++++++++ 1 file changed, 125 insertions(+) create mode 100644 tests/check/pipelines/vorbisdec.c diff --git a/tests/check/pipelines/vorbisdec.c b/tests/check/pipelines/vorbisdec.c new file mode 100644 index 0000000000..cd8bd06bbd --- /dev/null +++ b/tests/check/pipelines/vorbisdec.c @@ -0,0 +1,125 @@ +/* GStreamer + * + * unit test for vorbisdec + * + * Copyright (C) 2007 Thomas Vander Stichele + * + * 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 +#include + +#ifndef GST_DISABLE_PARSE + +GMainLoop *loop; +gint messages = 0; + +void +element_message_cb (GstBus * bus, GstMessage * message, gpointer user_data) +{ + gchar *s; + + s = gst_structure_to_string (gst_message_get_structure (message)); + GST_DEBUG ("Received message: %s", s); + g_free (s); + + messages++; +} + +void +eos_message_cb (GstBus * bus, GstMessage * message, gpointer user_data) +{ + GST_DEBUG ("Received eos"); + g_main_loop_quit (loop); +} + +GST_START_TEST (test_timestamps) +{ + GstElement *pipeline; + gchar *pipe_str; + GstBus *bus; + GError *error = NULL; + + pipe_str = g_strdup_printf ("audiotestsrc num-buffers=100" + " ! audio/x-raw-int,rate=44100 ! audioconvert ! vorbisenc ! vorbisdec" + " ! identity check-imperfect-timestamp=TRUE ! fakesink"); + + pipeline = gst_parse_launch (pipe_str, &error); + fail_unless (pipeline != NULL, "Error parsing pipeline: %s", + error ? error->message : "(invalid error)"); + g_free (pipe_str); + + bus = gst_element_get_bus (pipeline); + fail_if (bus == NULL); + gst_bus_add_signal_watch (bus); + g_signal_connect (bus, "message::element", (GCallback) element_message_cb, + NULL); + g_signal_connect (bus, "message::eos", (GCallback) eos_message_cb, NULL); + + gst_element_set_state (pipeline, GST_STATE_PLAYING); + + /* run until we receive EOS */ + loop = g_main_loop_new (NULL, FALSE); + + g_main_loop_run (loop); + + gst_element_set_state (pipeline, GST_STATE_NULL); + + /* FIXME: there seems to be a bug in vorbisdec on decoding the last packet + * where it calculates the timestamp based on the granulepos of the incoming + * packet and subtracting the number of samples it can decode, which can + * result in a discontinuity in timestamps. + * See http://bugzilla.gnome.org/show_bug.cgi?id=423086 + * Fix that bug and drop this number to 0. + */ + fail_if (messages > 1, "Received imperfect timestamp messages"); + gst_object_unref (pipeline); +} + +GST_END_TEST; +#endif /* #ifndef GST_DISABLE_PARSE */ + +Suite * +vorbisenc_suite (void) +{ + Suite *s = suite_create ("vorbisenc"); + TCase *tc_chain = tcase_create ("general"); + + suite_add_tcase (s, tc_chain); +#ifndef GST_DISABLE_PARSE + tcase_add_test (tc_chain, test_timestamps); +#endif + + return s; +} + +int +main (int argc, char **argv) +{ + int nf; + + Suite *s = vorbisenc_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; +} -- 2.34.1