mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-07 16:05:47 +00:00
bdbc069348
Improve GstSegment, rename some fields. The idea is to have the GstSegment structure represent the timing structure of the buffers as they are generated by the source or demuxer element. gst_segment_set_seek() -> gst_segment_do_seek() Rename the NEWSEGMENT event to SEGMENT. Make parsing of the SEGMENT event into a GstSegment structure. Pass a GstSegment structure when making a new SEGMENT event. This allows us to pass the timing info directly to the next element. No accumulation is needed in the receiving element, all the info is inside the element. Remove gst_segment_set_newsegment(): This function as used to accumulate segments received from upstream, which is now not needed anymore because the segment event contains the complete timing information.
266 lines
7.2 KiB
C
266 lines
7.2 KiB
C
/* GStreamer
|
|
*
|
|
* Unit tests for GstInfo
|
|
*
|
|
* Copyright (C) 2006 Tim-Philipp Müller <tim centricular net>
|
|
*
|
|
* 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>
|
|
|
|
#ifndef GST_DISABLE_GST_DEBUG
|
|
|
|
static void
|
|
printf_extension_log_func (GstDebugCategory * category,
|
|
GstDebugLevel level, const gchar * file, const gchar * function,
|
|
gint line, GObject * object, GstDebugMessage * message, gpointer unused)
|
|
{
|
|
const gchar *dbg_msg;
|
|
|
|
dbg_msg = gst_debug_message_get (message);
|
|
fail_unless (dbg_msg != NULL);
|
|
|
|
/* g_print ("%s\n", dbg_msg); */
|
|
|
|
/* quick hack to still get stuff to show if GST_DEBUG is set */
|
|
if (g_getenv ("GST_DEBUG")) {
|
|
gst_debug_log_default (category, level, file, function, line, object,
|
|
message, unused);
|
|
}
|
|
}
|
|
|
|
/* check our GST_PTR_FORMAT printf extension stuff */
|
|
GST_START_TEST (info_ptr_format_printf_extension)
|
|
{
|
|
/* set up our own log function to make sure the code in gstinfo is actually
|
|
* executed without GST_DEBUG being set or it being output to stdout */
|
|
gst_debug_remove_log_function (gst_debug_log_default);
|
|
gst_debug_add_log_function (printf_extension_log_func, NULL);
|
|
|
|
gst_debug_set_default_threshold (GST_LEVEL_LOG);
|
|
|
|
/* NULL object */
|
|
GST_LOG ("NULL: %" GST_PTR_FORMAT, (gpointer) NULL);
|
|
|
|
/* structure */
|
|
{
|
|
GstStructure *s;
|
|
|
|
s = gst_structure_new ("foo/bar", "number", G_TYPE_INT, 1,
|
|
"string", G_TYPE_STRING, "s", "float-number", G_TYPE_DOUBLE,
|
|
(gdouble) 424242.42, NULL);
|
|
|
|
GST_LOG ("STRUCTURE: %" GST_PTR_FORMAT, s);
|
|
gst_structure_free (s);
|
|
}
|
|
|
|
/* message */
|
|
{
|
|
GstMessage *msg;
|
|
|
|
msg = gst_message_new_element (NULL,
|
|
gst_structure_new ("redirect", "new-location", G_TYPE_STRING,
|
|
"http://foobar.com/r0x0r.ogg", "minimum-bitrate", G_TYPE_INT,
|
|
56000, NULL));
|
|
|
|
GST_LOG ("MESSAGE: %" GST_PTR_FORMAT, msg);
|
|
gst_message_unref (msg);
|
|
}
|
|
|
|
#if 0
|
|
/* TODO: GObject */
|
|
{
|
|
GST_LOG ("GOBJECT: %" GST_PTR_FORMAT, obj);
|
|
}
|
|
|
|
/* TODO: GstObject */
|
|
{
|
|
GST_LOG ("GSTOBJECT: %" GST_PTR_FORMAT, obj);
|
|
}
|
|
|
|
/* TODO: GstPad */
|
|
{
|
|
GST_LOG ("PAD: %" GST_PTR_FORMAT, pad);
|
|
}
|
|
|
|
/* TODO: GstCaps */
|
|
{
|
|
GST_LOG ("PAD: %" GST_PTR_FORMAT, pad);
|
|
}
|
|
#endif
|
|
|
|
/* clean up */
|
|
gst_debug_set_default_threshold (GST_LEVEL_NONE);
|
|
gst_debug_add_log_function (gst_debug_log_default, NULL);
|
|
gst_debug_remove_log_function (printf_extension_log_func);
|
|
}
|
|
|
|
GST_END_TEST;
|
|
|
|
/* check our GST_SEGMENT_FORMAT printf extension stuff */
|
|
GST_START_TEST (info_segment_format_printf_extension)
|
|
{
|
|
/* set up our own log function to make sure the code in gstinfo is actually
|
|
* executed without GST_DEBUG being set or it being output to stdout */
|
|
gst_debug_remove_log_function (gst_debug_log_default);
|
|
gst_debug_add_log_function (printf_extension_log_func, NULL);
|
|
|
|
gst_debug_set_default_threshold (GST_LEVEL_LOG);
|
|
|
|
/* TIME segment */
|
|
{
|
|
GstSegment segment;
|
|
|
|
gst_segment_init (&segment, GST_FORMAT_TIME);
|
|
|
|
segment.rate = 1.0;
|
|
segment.applied_rate = 2.0;
|
|
segment.start = 0;
|
|
segment.stop = 5 * 60 * GST_SECOND;
|
|
segment.time = 0;
|
|
|
|
segment.position = 2 * GST_SECOND;
|
|
segment.duration = 90 * 60 * GST_SECOND;
|
|
|
|
GST_LOG ("TIME: %" GST_SEGMENT_FORMAT, &segment);
|
|
}
|
|
|
|
/* BYTE segment */
|
|
{
|
|
GstSegment segment;
|
|
|
|
gst_segment_init (&segment, GST_FORMAT_BYTES);
|
|
|
|
segment.rate = 1.0;
|
|
segment.applied_rate = 1.0;
|
|
segment.start = 0;
|
|
segment.stop = 9999999;
|
|
segment.time = 0;
|
|
|
|
GST_LOG ("BYTE: %" GST_SEGMENT_FORMAT, &segment);
|
|
}
|
|
|
|
/* UNKNOWN format segment (format numbers are consecutive from 0) */
|
|
{
|
|
GstSegment segment;
|
|
|
|
gst_segment_init (&segment, 98765432);
|
|
|
|
segment.rate = 1.0;
|
|
segment.applied_rate = 1.0;
|
|
segment.start = 0;
|
|
segment.stop = 987654321;
|
|
segment.time = 0;
|
|
|
|
GST_LOG ("UNKNOWN: %" GST_SEGMENT_FORMAT, &segment);
|
|
}
|
|
|
|
/* UNDEFINED format segment */
|
|
{
|
|
GstSegment segment;
|
|
|
|
gst_segment_init (&segment, GST_FORMAT_UNDEFINED);
|
|
|
|
GST_LOG ("UNDEFINED: %" GST_SEGMENT_FORMAT, &segment);
|
|
}
|
|
|
|
/* NULL segment */
|
|
GST_LOG ("NULL: %" GST_SEGMENT_FORMAT, (GstSegment *) NULL);
|
|
|
|
/* clean up */
|
|
gst_debug_set_default_threshold (GST_LEVEL_NONE);
|
|
gst_debug_add_log_function (gst_debug_log_default, NULL);
|
|
gst_debug_remove_log_function (printf_extension_log_func);
|
|
}
|
|
|
|
GST_END_TEST;
|
|
|
|
GST_START_TEST (info_log_handler)
|
|
{
|
|
guint removed;
|
|
|
|
removed = gst_debug_remove_log_function (gst_debug_log_default);
|
|
fail_unless (removed == 1);
|
|
}
|
|
|
|
GST_END_TEST;
|
|
|
|
GST_START_TEST (info_dump_mem)
|
|
{
|
|
GstDebugCategory *cat = NULL;
|
|
GstElement *e;
|
|
|
|
const guint8 data[] = { 0x00, 0x00, 0x00, 0x20, 0x66, 0x74, 0x79, 0x70,
|
|
0x71, 0x74, 0x20, 0x20, 0x20, 0x05, 0x03, 0x00, 0x71, 0x74, 0x20, 0x20,
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
0x00, 0x00, 0xef, 0xe1, 0x6d, 0x6f, 0x6f, 0x76, 0x00, 0x00, 0x00, 0x6c,
|
|
0x6d, 0x76, 0x68, 0x64, 0x00, 0x00, 0x00, 0x00, 0xbf, 0xd1, 0x00, 0x1d,
|
|
0xbf, 0xd1, 0x00, 0x1e, 0x00, 0x00, 0x0b, 0xb5, 0x00, 0x04, 0x59, 0xc5,
|
|
0x00, 0x01, 0x00, 0x00, 0x00, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x01, '%', 's', '%', 's'
|
|
};
|
|
|
|
e = gst_element_factory_make ("fakesink", NULL);
|
|
GST_DEBUG_CATEGORY_INIT (cat, "dumpcat", 0, "data dump debug category");
|
|
GST_MEMDUMP ("quicktime header", data, sizeof (data));
|
|
GST_MEMDUMP (NULL, data, sizeof (data));
|
|
GST_CAT_MEMDUMP (cat, "quicktime header", data, sizeof (data));
|
|
GST_MEMDUMP_OBJECT (e, "object stuff", data, sizeof (data));
|
|
GST_CAT_MEMDUMP_OBJECT (cat, e, "object/cat stuff", data, sizeof (data));
|
|
gst_object_unref (e);
|
|
}
|
|
|
|
GST_END_TEST;
|
|
|
|
GST_START_TEST (info_fixme)
|
|
{
|
|
GstDebugCategory *cat = NULL;
|
|
GstElement *e;
|
|
|
|
e = gst_element_factory_make ("fakesink", NULL);
|
|
GST_DEBUG_CATEGORY_INIT (cat, "fixcat", 0, "FIXME debug category");
|
|
GST_FIXME ("fix %s thing", "this");
|
|
GST_FIXME_OBJECT (e, "fix %s object", "this");
|
|
GST_CAT_FIXME (cat, "fix some%s in this category", "thing");
|
|
GST_CAT_FIXME_OBJECT (cat, e, "fix some%s in this cat and object", "thing");
|
|
gst_object_unref (e);
|
|
}
|
|
|
|
GST_END_TEST;
|
|
#endif
|
|
|
|
static Suite *
|
|
gst_info_suite (void)
|
|
{
|
|
Suite *s = suite_create ("GstInfo");
|
|
TCase *tc_chain = tcase_create ("info");
|
|
|
|
tcase_set_timeout (tc_chain, 30);
|
|
|
|
suite_add_tcase (s, tc_chain);
|
|
#ifndef GST_DISABLE_GST_DEBUG
|
|
tcase_add_test (tc_chain, info_segment_format_printf_extension);
|
|
tcase_add_test (tc_chain, info_ptr_format_printf_extension);
|
|
tcase_add_test (tc_chain, info_log_handler);
|
|
tcase_add_test (tc_chain, info_dump_mem);
|
|
tcase_add_test (tc_chain, info_fixme);
|
|
#endif
|
|
|
|
return s;
|
|
}
|
|
|
|
GST_CHECK_MAIN (gst_info);
|