diff options
author | Dave Robillard <dave@drobilla.net> | 2009-08-12 01:09:07 -0400 |
---|---|---|
committer | Dave Robillard <dave@drobilla.net> | 2009-08-12 01:09:07 -0400 |
commit | e46ff7bda0f7996b456476dccb4a822688a690fb (patch) | |
tree | 72f36b99c236a9a042c82702f99351456762de78 /tests/check | |
parent | dd5afbf0c6557ad89994cbfd91e4117e8503b81a (diff) | |
parent | 7c7b82e7141b83e987be2142e7334d21407529fe (diff) | |
download | gst-plugins-bad-e46ff7bda0f7996b456476dccb4a822688a690fb.tar.gz gst-plugins-bad-e46ff7bda0f7996b456476dccb4a822688a690fb.tar.bz2 gst-plugins-bad-e46ff7bda0f7996b456476dccb4a822688a690fb.zip |
Merge branch 'master' of git://anongit.freedesktop.org/gstreamer/gst-plugins-bad into fdo
Diffstat (limited to 'tests/check')
-rw-r--r-- | tests/check/Makefile.am | 20 | ||||
-rw-r--r-- | tests/check/elements/.gitignore | 3 | ||||
-rw-r--r-- | tests/check/elements/kate.c | 6 | ||||
-rw-r--r-- | tests/check/elements/rtpbin.c | 421 | ||||
-rw-r--r-- | tests/check/elements/rtpbin_buffer_list.c | 331 |
5 files changed, 16 insertions, 765 deletions
diff --git a/tests/check/Makefile.am b/tests/check/Makefile.am index 1fc64c54..3a2d92ff 100644 --- a/tests/check/Makefile.am +++ b/tests/check/Makefile.am @@ -78,22 +78,27 @@ VALGRIND_TO_FIX = \ VALGRIND_TESTS_DISABLE = \ $(VALGRIND_TO_FIX) +# these tests don't even pass +# camerabin: temporarily disabled because it fails with current core -git +# (which will be release before the next -bad release though, and chances are +# changes to fix this are needed in the camerabin test) +# neon: too flaky (almost always fails 'the first time') +noinst_PROGRAMS = \ + $(check_neon) \ + elements/camerabin + check_PROGRAMS = \ generic/states \ $(check_mpeg2enc) \ $(check_mplex) \ - $(check_neon) \ $(check_ofa) \ $(check_timidity) \ $(check_kate) \ elements/aacparse \ elements/amrparse \ elements/asfmux \ - elements/camerabin \ elements/legacyresample \ elements/qtmux \ - elements/rtpbin \ - elements/rtpbin_buffer_list \ elements/selector \ elements/shapewipe \ elements/mxfdemux \ @@ -118,13 +123,6 @@ elements_camerabin_LDADD = \ -lgstinterfaces-@GST_MAJORMINOR@ elements_camerabin_SOURCES = elements/camerabin.c -elements_rtpbin_buffer_list_CFLAGS = $(GST_PLUGINS_BASE_CFLAGS) $(GST_CFLAGS) \ - $(ERROR_CFLAGS) $(GST_CHECK_CFLAGS) -elements_rtpbin_buffer_list_LDADD = $(GST_PLUGINS_BASE_LIBS) \ - -lgstnetbuffer-@GST_MAJORMINOR@ -lgstrtp-@GST_MAJORMINOR@ \ - $(GST_BASE_LIBS) $(GST_LIBS_LIBS) $(GST_CHECK_LIBS) -elements_rtpbin_buffer_list_SOURCES = elements/rtpbin_buffer_list.c - elements_timidity_CFLAGS = $(GST_BASE_CFLAGS) $(AM_CFLAGS) elements_timidity_LDADD = $(GST_BASE_LIBS) $(LDADD) diff --git a/tests/check/elements/.gitignore b/tests/check/elements/.gitignore index df2bb15d..30c67fe8 100644 --- a/tests/check/elements/.gitignore +++ b/tests/check/elements/.gitignore @@ -1,6 +1,7 @@ .dirstamp aacparse amrparse +asfmux camerabin deinterleave gdpdepay @@ -19,8 +20,6 @@ souphttpsrc rganalysis rglimiter rgvolume -rtpbin -rtpbin_buffer_list selector shapewipe spectrum diff --git a/tests/check/elements/kate.c b/tests/check/elements/kate.c index c848cc5c..9eed574d 100644 --- a/tests/check/elements/kate.c +++ b/tests/check/elements/kate.c @@ -447,6 +447,8 @@ GST_START_TEST (test_kate_encode_simple) GstCaps *caps; kateenc = setup_kateenc (); + g_object_set (kateenc, "category", "subtitles", NULL); + fail_unless (gst_element_set_state (kateenc, GST_STATE_PLAYING) == GST_STATE_CHANGE_SUCCESS, "could not set to playing"); @@ -498,6 +500,8 @@ GST_START_TEST (test_kate_encode_spu) GstCaps *caps; kateenc = setup_kateenc (); + g_object_set (kateenc, "category", "spu-subtitles", NULL); + fail_unless (gst_element_set_state (kateenc, GST_STATE_PLAYING) == GST_STATE_CHANGE_SUCCESS, "could not set to playing"); @@ -560,6 +564,8 @@ GST_START_TEST (test_kate_encode_keepalives) for (round = 0; round < 3; ++round) { kateenc = setup_kateenc (); + /* doesn't matter here, since we never send a packet */ + g_object_set (kateenc, "category", "subtitles", NULL); fail_unless (gst_element_set_state (kateenc, GST_STATE_PLAYING) == GST_STATE_CHANGE_SUCCESS, "could not set to playing"); diff --git a/tests/check/elements/rtpbin.c b/tests/check/elements/rtpbin.c deleted file mode 100644 index 8764da54..00000000 --- a/tests/check/elements/rtpbin.c +++ /dev/null @@ -1,421 +0,0 @@ -/* GStreamer - * - * unit test for gstrtpbin - * - * Copyright (C) <2009> Wim Taymans <wim.taymans@gmail.com> - * - * 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 <gst/check/gstcheck.h> - -GST_START_TEST (test_cleanup_send) -{ - GstElement *rtpbin; - GstPad *rtp_sink, *rtp_src, *rtcp_src; - GObject *session; - gint count = 2; - - rtpbin = gst_element_factory_make ("gstrtpbin", "rtpbin"); - - while (count--) { - /* request session 0 */ - rtp_sink = gst_element_get_request_pad (rtpbin, "send_rtp_sink_0"); - fail_unless (rtp_sink != NULL); - ASSERT_OBJECT_REFCOUNT (rtp_sink, "rtp_sink", 2); - - /* request again */ - rtp_sink = gst_element_get_request_pad (rtpbin, "send_rtp_sink_0"); - fail_unless (rtp_sink != NULL); - ASSERT_OBJECT_REFCOUNT (rtp_sink, "rtp_sink", 3); - gst_object_unref (rtp_sink); - - /* this static pad should be created automatically now */ - rtp_src = gst_element_get_static_pad (rtpbin, "send_rtp_src_0"); - fail_unless (rtp_src != NULL); - ASSERT_OBJECT_REFCOUNT (rtp_src, "rtp_src", 2); - - /* we should be able to get an internal session 0 now */ - g_signal_emit_by_name (rtpbin, "get-internal-session", 0, &session); - fail_unless (session != NULL); - g_object_unref (session); - - /* get the send RTCP pad too */ - rtcp_src = gst_element_get_request_pad (rtpbin, "send_rtcp_src_0"); - fail_unless (rtcp_src != NULL); - ASSERT_OBJECT_REFCOUNT (rtcp_src, "rtcp_src", 2); - - /* second time */ - rtcp_src = gst_element_get_request_pad (rtpbin, "send_rtcp_src_0"); - fail_unless (rtcp_src != NULL); - ASSERT_OBJECT_REFCOUNT (rtcp_src, "rtcp_src", 3); - gst_object_unref (rtcp_src); - - gst_element_release_request_pad (rtpbin, rtp_sink); - /* we should only have our refs to the pads now */ - ASSERT_OBJECT_REFCOUNT (rtp_sink, "rtp_sink", 1); - ASSERT_OBJECT_REFCOUNT (rtp_src, "rtp_src", 1); - ASSERT_OBJECT_REFCOUNT (rtcp_src, "rtp_src", 2); - - /* the other pad should be gone now */ - fail_unless (gst_element_get_static_pad (rtpbin, "send_rtp_src_0") == NULL); - - /* internal session should still be there */ - g_signal_emit_by_name (rtpbin, "get-internal-session", 0, &session); - fail_unless (session != NULL); - g_object_unref (session); - - /* release the RTCP pad */ - gst_element_release_request_pad (rtpbin, rtcp_src); - /* we should only have our refs to the pads now */ - ASSERT_OBJECT_REFCOUNT (rtp_sink, "rtp_sink", 1); - ASSERT_OBJECT_REFCOUNT (rtp_src, "rtp_src", 1); - ASSERT_OBJECT_REFCOUNT (rtcp_src, "rtp_src", 1); - - /* the session should be gone now */ - g_signal_emit_by_name (rtpbin, "get-internal-session", 0, &session); - fail_unless (session == NULL); - - /* unref the request pad and the static pad */ - gst_object_unref (rtp_sink); - gst_object_unref (rtp_src); - gst_object_unref (rtcp_src); - } - - gst_object_unref (rtpbin); -} - -GST_END_TEST; - -typedef struct -{ - guint16 seqnum; - gboolean pad_added; - GstPad *pad; - GMutex *lock; - GCond *cond; - GstPad *sinkpad; - GList *pads; -} CleanupData; - -static void -init_data (CleanupData * data) -{ - data->seqnum = 10; - data->pad_added = FALSE; - data->lock = g_mutex_new (); - data->cond = g_cond_new (); - data->pads = NULL; -} - -static void -clean_data (CleanupData * data) -{ - g_list_foreach (data->pads, (GFunc) gst_object_unref, NULL); - g_list_free (data->pads); - g_mutex_free (data->lock); - g_cond_free (data->cond); -} - -static guint8 rtp_packet[] = { 0x80, 0x60, 0x94, 0xbc, 0x8f, 0x37, 0x4e, 0xb8, - 0x44, 0xa8, 0xf3, 0x7c, 0x06, 0x6a, 0x0c, 0xce, - 0x13, 0x25, 0x19, 0x69, 0x1f, 0x93, 0x25, 0x9d, - 0x2b, 0x82, 0x31, 0x3b, 0x36, 0xc1, 0x3c, 0x13 -}; - -static GstBuffer * -make_rtp_packet (CleanupData * data) -{ - static GstCaps *caps = NULL; - GstBuffer *result; - guint8 *datap; - - if (caps == NULL) { - caps = gst_caps_from_string ("application/x-rtp," - "media=(string)audio, clock-rate=(int)44100, " - "encoding-name=(string)L16, encoding-params=(string)1, channels=(int)1"); - data->seqnum = 0; - } - - result = gst_buffer_new_and_alloc (sizeof (rtp_packet)); - datap = GST_BUFFER_DATA (result); - memcpy (datap, rtp_packet, sizeof (rtp_packet)); - - datap[2] = (data->seqnum >> 8) & 0xff; - datap[3] = data->seqnum & 0xff; - - data->seqnum++; - - gst_buffer_set_caps (result, caps); - - return result; -} - -static GstFlowReturn -dummy_chain (GstPad * pad, GstBuffer * buffer) -{ - gst_buffer_unref (buffer); - - return GST_FLOW_OK; -} - -static GstStaticPadTemplate sink_factory = GST_STATIC_PAD_TEMPLATE ("sink", - GST_PAD_SINK, - GST_PAD_ALWAYS, - GST_STATIC_CAPS ("application/x-rtp")); - - -static GstPad * -make_sinkpad (CleanupData * data) -{ - GstPad *pad; - - pad = gst_pad_new_from_static_template (&sink_factory, "sink"); - - gst_pad_set_chain_function (pad, dummy_chain); - gst_pad_set_active (pad, TRUE); - - data->pads = g_list_prepend (data->pads, pad); - - return pad; -} - -static void -pad_added_cb (GstElement * rtpbin, GstPad * pad, CleanupData * data) -{ - GstPad *sinkpad; - - GST_DEBUG ("pad added %s:%s\n", GST_DEBUG_PAD_NAME (pad)); - - if (GST_PAD_IS_SINK (pad)) - return; - - fail_unless (data->pad_added == FALSE); - - sinkpad = make_sinkpad (data); - fail_unless (gst_pad_link (pad, sinkpad) == GST_PAD_LINK_OK); - - g_mutex_lock (data->lock); - data->pad_added = TRUE; - data->pad = pad; - g_cond_signal (data->cond); - g_mutex_unlock (data->lock); -} - -static void -pad_removed_cb (GstElement * rtpbin, GstPad * pad, CleanupData * data) -{ - GST_DEBUG ("pad removed %s:%s\n", GST_DEBUG_PAD_NAME (pad)); - - if (data->pad != pad) - return; - - fail_unless (data->pad_added == TRUE); - - g_mutex_lock (data->lock); - data->pad_added = FALSE; - g_cond_signal (data->cond); - g_mutex_unlock (data->lock); -} - -GST_START_TEST (test_cleanup_recv) -{ - GstElement *rtpbin; - GstPad *rtp_sink; - CleanupData data; - GstStateChangeReturn ret; - GstFlowReturn res; - GstBuffer *buffer; - gint count = 2; - - init_data (&data); - - rtpbin = gst_element_factory_make ("gstrtpbin", "rtpbin"); - - g_signal_connect (rtpbin, "pad-added", (GCallback) pad_added_cb, &data); - g_signal_connect (rtpbin, "pad-removed", (GCallback) pad_removed_cb, &data); - - ret = gst_element_set_state (rtpbin, GST_STATE_PLAYING); - fail_unless (ret == GST_STATE_CHANGE_SUCCESS); - - while (count--) { - /* request session 0 */ - rtp_sink = gst_element_get_request_pad (rtpbin, "recv_rtp_sink_0"); - fail_unless (rtp_sink != NULL); - ASSERT_OBJECT_REFCOUNT (rtp_sink, "rtp_sink", 2); - - /* no sourcepads are created yet */ - fail_unless (rtpbin->numsinkpads == 1); - fail_unless (rtpbin->numsrcpads == 0); - - buffer = make_rtp_packet (&data); - res = gst_pad_chain (rtp_sink, buffer); - GST_DEBUG ("res %d, %s\n", res, gst_flow_get_name (res)); - fail_unless (res == GST_FLOW_OK); - - buffer = make_rtp_packet (&data); - res = gst_pad_chain (rtp_sink, buffer); - GST_DEBUG ("res %d, %s\n", res, gst_flow_get_name (res)); - fail_unless (res == GST_FLOW_OK); - - /* we wait for the new pad to appear now */ - g_mutex_lock (data.lock); - while (!data.pad_added) - g_cond_wait (data.cond, data.lock); - g_mutex_unlock (data.lock); - - /* sourcepad created now */ - fail_unless (rtpbin->numsinkpads == 1); - fail_unless (rtpbin->numsrcpads == 1); - - /* remove the session */ - gst_element_release_request_pad (rtpbin, rtp_sink); - gst_object_unref (rtp_sink); - - /* pad should be gone now */ - g_mutex_lock (data.lock); - while (data.pad_added) - g_cond_wait (data.cond, data.lock); - g_mutex_unlock (data.lock); - - /* nothing left anymore now */ - fail_unless (rtpbin->numsinkpads == 0); - fail_unless (rtpbin->numsrcpads == 0); - } - - ret = gst_element_set_state (rtpbin, GST_STATE_NULL); - fail_unless (ret == GST_STATE_CHANGE_SUCCESS); - - gst_object_unref (rtpbin); - - clean_data (&data); -} - -GST_END_TEST; - -GST_START_TEST (test_cleanup_recv2) -{ - GstElement *rtpbin; - GstPad *rtp_sink; - CleanupData data; - GstStateChangeReturn ret; - GstFlowReturn res; - GstBuffer *buffer; - gint count = 2; - - init_data (&data); - - rtpbin = gst_element_factory_make ("gstrtpbin", "rtpbin"); - - g_signal_connect (rtpbin, "pad-added", (GCallback) pad_added_cb, &data); - g_signal_connect (rtpbin, "pad-removed", (GCallback) pad_removed_cb, &data); - - ret = gst_element_set_state (rtpbin, GST_STATE_PLAYING); - fail_unless (ret == GST_STATE_CHANGE_SUCCESS); - - /* request session 0 */ - rtp_sink = gst_element_get_request_pad (rtpbin, "recv_rtp_sink_0"); - fail_unless (rtp_sink != NULL); - ASSERT_OBJECT_REFCOUNT (rtp_sink, "rtp_sink", 2); - - while (count--) { - /* no sourcepads are created yet */ - fail_unless (rtpbin->numsinkpads == 1); - fail_unless (rtpbin->numsrcpads == 0); - - buffer = make_rtp_packet (&data); - res = gst_pad_chain (rtp_sink, buffer); - GST_DEBUG ("res %d, %s\n", res, gst_flow_get_name (res)); - fail_unless (res == GST_FLOW_OK); - - buffer = make_rtp_packet (&data); - res = gst_pad_chain (rtp_sink, buffer); - GST_DEBUG ("res %d, %s\n", res, gst_flow_get_name (res)); - fail_unless (res == GST_FLOW_OK); - - /* we wait for the new pad to appear now */ - g_mutex_lock (data.lock); - while (!data.pad_added) - g_cond_wait (data.cond, data.lock); - g_mutex_unlock (data.lock); - - /* sourcepad created now */ - fail_unless (rtpbin->numsinkpads == 1); - fail_unless (rtpbin->numsrcpads == 1); - - /* change state */ - ret = gst_element_set_state (rtpbin, GST_STATE_NULL); - fail_unless (ret == GST_STATE_CHANGE_SUCCESS); - - /* pad should be gone now */ - g_mutex_lock (data.lock); - while (data.pad_added) - g_cond_wait (data.cond, data.lock); - g_mutex_unlock (data.lock); - - /* back to playing for the next round */ - ret = gst_element_set_state (rtpbin, GST_STATE_PLAYING); - fail_unless (ret == GST_STATE_CHANGE_SUCCESS); - } - - /* remove the session */ - gst_element_release_request_pad (rtpbin, rtp_sink); - gst_object_unref (rtp_sink); - - /* nothing left anymore now */ - fail_unless (rtpbin->numsinkpads == 0); - fail_unless (rtpbin->numsrcpads == 0); - - ret = gst_element_set_state (rtpbin, GST_STATE_NULL); - fail_unless (ret == GST_STATE_CHANGE_SUCCESS); - - gst_object_unref (rtpbin); - - clean_data (&data); -} - -GST_END_TEST; - -Suite * -gstrtpbin_suite (void) -{ - Suite *s = suite_create ("gstrtpbin"); - TCase *tc_chain = tcase_create ("general"); - - suite_add_tcase (s, tc_chain); - tcase_add_test (tc_chain, test_cleanup_send); - tcase_add_test (tc_chain, test_cleanup_recv); - tcase_add_test (tc_chain, test_cleanup_recv2); - - return s; -} - -int -main (int argc, char **argv) -{ - int nf; - - Suite *s = gstrtpbin_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/elements/rtpbin_buffer_list.c b/tests/check/elements/rtpbin_buffer_list.c deleted file mode 100644 index af4003dd..00000000 --- a/tests/check/elements/rtpbin_buffer_list.c +++ /dev/null @@ -1,331 +0,0 @@ -/* GStreamer - * - * Unit test for gstrtpbin sending rtp packets using GstBufferList. - * Copyright (C) 2009 Branko Subasic <branko dot subasic at axis dot com> - * - * 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 <gst/check/gstcheck.h> - -#include <gst/rtp/gstrtpbuffer.h> - - - -/* This test makes sure that RTP packets sent as buffer lists are sent through - * the rtpbin as they are supposed to, and not corrupted in any way. - */ - - -#define TEST_CAPS \ - "application/x-rtp, " \ - "media=(string)video, " \ - "clock-rate=(int)90000, " \ - "encoding-name=(string)H264, " \ - "profile-level-id=(string)4d4015, " \ - "payload=(int)96, " \ - "ssrc=(guint)2633237432, " \ - "clock-base=(guint)1868267015, " \ - "seqnum-base=(guint)54229" - - -/* RTP headers and the first 2 bytes of the payload (FU indicator and FU header) - */ -static const guint8 rtp_header[2][14] = { - {0x80, 0x60, 0xbb, 0xb7, 0x5c, 0xe9, 0x09, - 0x0d, 0xf5, 0x9c, 0x43, 0x55, 0x1c, 0x86}, - {0x80, 0x60, 0xbb, 0xb8, 0x5c, 0xe9, 0x09, - 0x0d, 0xf5, 0x9c, 0x43, 0x55, 0x1c, 0x46} -}; - -static const guint rtp_header_len[] = { - sizeof rtp_header[0], - sizeof rtp_header[1] -}; - -static GstBuffer *header_buffer[2] = { NULL, NULL }; - - -/* Some payload. - */ -static char *payload = - "0123456789ABSDEF0123456789ABSDEF0123456789ABSDEF0123456789ABSDEF0123456789ABSDEF" - "0123456789ABSDEF0123456789ABSDEF0123456789ABSDEF0123456789ABSDEF0123456789ABSDEF" - "0123456789ABSDEF0123456789ABSDEF0123456789ABSDEF0123456789ABSDEF0123456789ABSDEF" - "0123456789ABSDEF0123456789ABSDEF0123456789ABSDEF0123456789ABSDEF0123456789ABSDEF" - "0123456789ABSDEF0123456789ABSDEF0123456789ABSDEF0123456789ABSDEF0123456789ABSDEF" - "0123456789ABSDEF0123456789ABSDEF0123456789ABSDEF0123456789ABSDEF0123456789ABSDEF" - "0123456789ABSDEF0123456"; - -static const guint payload_offset[] = { - 0, 498 -}; - -static const guint payload_len[] = { - 498, 5 -}; - - -static GstBuffer *original_buffer = NULL; - -static GstStaticPadTemplate sinktemplate = GST_STATIC_PAD_TEMPLATE ("sink", - GST_PAD_SINK, - GST_PAD_ALWAYS, - GST_STATIC_CAPS ("application/x-rtp")); - -static GstStaticPadTemplate srctemplate = GST_STATIC_PAD_TEMPLATE ("src", - GST_PAD_SRC, - GST_PAD_ALWAYS, - GST_STATIC_CAPS ("application/x-rtp")); - - -static GstBuffer * -_create_original_buffer (void) -{ - GstCaps *caps; - - if (original_buffer != NULL) - return original_buffer; - - original_buffer = gst_buffer_new (); - fail_unless (original_buffer != NULL); - - gst_buffer_set_data (original_buffer, (guint8 *) payload, strlen (payload)); - GST_BUFFER_TIMESTAMP (original_buffer) = - gst_clock_get_internal_time (gst_system_clock_obtain ()); - - caps = gst_caps_from_string (TEST_CAPS); - fail_unless (caps != NULL); - gst_buffer_set_caps (original_buffer, caps); - gst_caps_unref (caps); - - return original_buffer; -} - -static GstBufferList * -_create_buffer_list (void) -{ - GstBufferList *list; - GstBufferListIterator *it; - GstBuffer *orig_buffer; - GstBuffer *buffer; - - orig_buffer = _create_original_buffer (); - fail_if (orig_buffer == NULL); - - list = gst_buffer_list_new (); - fail_if (list == NULL); - - it = gst_buffer_list_iterate (list); - fail_if (it == NULL); - - /*** First group, i.e. first packet. **/ - gst_buffer_list_iterator_add_group (it); - - /* Create buffer with RTP header and add it to the 1st group */ - buffer = gst_buffer_new (); - GST_BUFFER_MALLOCDATA (buffer) = g_memdup (&rtp_header[0], rtp_header_len[0]); - GST_BUFFER_DATA (buffer) = GST_BUFFER_MALLOCDATA (buffer); - GST_BUFFER_SIZE (buffer) = rtp_header_len[0]; - gst_buffer_copy_metadata (buffer, orig_buffer, GST_BUFFER_COPY_ALL); - header_buffer[0] = buffer; - gst_buffer_list_iterator_add (it, buffer); - - /* Create the payload buffer and add it to the 1st group - */ - buffer = - gst_buffer_create_sub (orig_buffer, payload_offset[0], payload_len[0]); - fail_if (buffer == NULL); - gst_buffer_list_iterator_add (it, buffer); - - - /*** Second group, i.e. second packet. ***/ - - /* Create a new group to hold the rtp header and the payload */ - gst_buffer_list_iterator_add_group (it); - - /* Create buffer with RTP header and add it to the 2nd group */ - buffer = gst_buffer_new (); - GST_BUFFER_MALLOCDATA (buffer) = g_memdup (&rtp_header[1], rtp_header_len[1]); - GST_BUFFER_DATA (buffer) = GST_BUFFER_MALLOCDATA (buffer); - GST_BUFFER_SIZE (buffer) = rtp_header_len[1]; - gst_buffer_copy_metadata (buffer, orig_buffer, GST_BUFFER_COPY_ALL); - header_buffer[1] = buffer; - - /* Add the rtp header to the buffer list */ - gst_buffer_list_iterator_add (it, buffer); - - /* Create the payload buffer and add it to the 2d group - */ - buffer = - gst_buffer_create_sub (orig_buffer, payload_offset[1], payload_len[1]); - fail_if (buffer == NULL); - gst_buffer_list_iterator_add (it, buffer); - - gst_buffer_list_iterator_free (it); - - return list; -} - - -static void -_check_header (GstBuffer * buffer, guint index) -{ - guint8 *data; - - fail_if (buffer == NULL); - fail_unless (index < 2); - - fail_unless (GST_BUFFER_SIZE (buffer) == rtp_header_len[index]); - - /* Can't do a memcmp() on the whole header, cause the SSRC (bytes 8-11) will - * most likely be changed in gstrtpbin. - */ - fail_unless ((data = GST_BUFFER_DATA (buffer)) != NULL); - fail_unless_equals_uint64 (*(guint64 *) data, *(guint64 *) rtp_header[index]); - fail_unless (*(guint16 *) (data + 12) == - *(guint16 *) (rtp_header[index] + 12)); -} - - -static void -_check_payload (GstBuffer * buffer, guint index) -{ - fail_if (buffer == NULL); - fail_unless (index < 2); - - fail_unless (GST_BUFFER_SIZE (buffer) == payload_len[index]); - fail_if (GST_BUFFER_DATA (buffer) != - (gpointer) (payload + payload_offset[index])); - fail_if (memcmp (GST_BUFFER_DATA (buffer), payload + payload_offset[index], - payload_len[index])); -} - - -static void -_check_group (GstBufferListIterator * it, guint index, GstCaps * caps) -{ - GstBuffer *buffer; - - fail_unless (it != NULL); - fail_unless (gst_buffer_list_iterator_n_buffers (it) == 2); - fail_unless (caps != NULL); - - fail_unless ((buffer = gst_buffer_list_iterator_next (it)) != NULL); - - fail_unless (GST_BUFFER_TIMESTAMP (buffer) == - GST_BUFFER_TIMESTAMP (original_buffer)); - - fail_unless (gst_caps_is_equal (GST_BUFFER_CAPS (original_buffer), - GST_BUFFER_CAPS (buffer))); - - _check_header (buffer, index); - - fail_unless ((buffer = gst_buffer_list_iterator_next (it)) != NULL); - _check_payload (buffer, index); -} - - -static GstFlowReturn -_sink_chain_list (GstPad * pad, GstBufferList * list) -{ - GstCaps *caps; - GstBufferListIterator *it; - - caps = gst_caps_from_string (TEST_CAPS); - fail_unless (caps != NULL); - - fail_unless (GST_IS_BUFFER_LIST (list)); - fail_unless (gst_buffer_list_n_groups (list) == 2); - - it = gst_buffer_list_iterate (list); - fail_if (it == NULL); - - fail_unless (gst_buffer_list_iterator_next_group (it)); - _check_group (it, 0, caps); - - fail_unless (gst_buffer_list_iterator_next_group (it)); - _check_group (it, 1, caps); - - gst_caps_unref (caps); - gst_buffer_list_iterator_free (it); - - gst_buffer_list_unref (list); - - return GST_FLOW_OK; -} - - -static void -_set_chain_functions (GstPad * pad) -{ - gst_pad_set_chain_list_function (pad, _sink_chain_list); -} - - -GST_START_TEST (test_bufferlist) -{ - GstElement *rtpbin; - GstPad *sinkpad; - GstPad *srcpad; - GstBufferList *list; - - list = _create_buffer_list (); - fail_unless (list != NULL); - - rtpbin = gst_check_setup_element ("gstrtpbin"); - - srcpad = - gst_check_setup_src_pad_by_name (rtpbin, &srctemplate, "send_rtp_sink_0"); - fail_if (srcpad == NULL); - sinkpad = - gst_check_setup_sink_pad_by_name (rtpbin, &sinktemplate, - "send_rtp_src_0"); - fail_if (sinkpad == NULL); - - _set_chain_functions (sinkpad); - - gst_pad_set_active (sinkpad, TRUE); - gst_element_set_state (rtpbin, GST_STATE_PLAYING); - fail_unless (gst_pad_push_list (srcpad, list) == GST_FLOW_OK); - gst_pad_set_active (sinkpad, FALSE); - - gst_check_teardown_pad_by_name (rtpbin, "send_rtp_src_0"); - gst_check_teardown_pad_by_name (rtpbin, "send_rtp_sink_0"); - gst_check_teardown_element (rtpbin); -} - -GST_END_TEST; - - - -static Suite * -bufferlist_suite (void) -{ - Suite *s = suite_create ("BufferList"); - - TCase *tc_chain = tcase_create ("general"); - - /* time out after 30s. */ - tcase_set_timeout (tc_chain, 10); - - suite_add_tcase (s, tc_chain); - tcase_add_test (tc_chain, test_bufferlist); - - return s; -} - -GST_CHECK_MAIN (bufferlist); |