add sizetype tests for fakesrc

Original commit message from CVS:
add sizetype tests for fakesrc
This commit is contained in:
Thomas Vander Stichele 2005-08-05 06:55:03 +00:00
parent e20ed97cb2
commit e8007886c1
62 changed files with 301 additions and 193 deletions

View file

@ -1,3 +1,9 @@
2005-08-05 Thomas Vander Stichele <thomas at apestaart dot org>
* check/elements/gstfakesrc.c: (setup_fakesrc), (cleanup_fakesrc),
(GST_START_TEST), (fakesrc_suite):
add tests for sizetype
2005-08-04 Andy Wingo <wingo@pobox.com> 2005-08-04 Andy Wingo <wingo@pobox.com>
* gst/elements/gstcapsfilter.c: Reimplement using basetransform, * gst/elements/gstcapsfilter.c: Reimplement using basetransform,

View file

@ -57,7 +57,8 @@ event_func (GstPad * pad, GstEvent * event)
return FALSE; return FALSE;
} }
GST_START_TEST (test_num_buffers) GstElement *
setup_fakesrc ()
{ {
GstElement *src; GstElement *src;
GstPad *srcpad, *sinkpad; GstPad *srcpad, *sinkpad;
@ -70,8 +71,6 @@ GST_START_TEST (test_num_buffers)
"sink"); "sink");
fail_if (sinkpad == NULL, "Could not create a sinkpad"); fail_if (sinkpad == NULL, "Could not create a sinkpad");
g_object_set (G_OBJECT (src), "num-buffers", 3, NULL);
srcpad = gst_element_get_pad (src, "src"); srcpad = gst_element_get_pad (src, "src");
fail_if (srcpad == NULL, "Could not get source pad from fakesrc"); fail_if (srcpad == NULL, "Could not get source pad from fakesrc");
gst_pad_set_caps (sinkpad, NULL); gst_pad_set_caps (sinkpad, NULL);
@ -80,7 +79,41 @@ GST_START_TEST (test_num_buffers)
fail_unless (gst_pad_link (srcpad, sinkpad) == GST_PAD_LINK_OK, fail_unless (gst_pad_link (srcpad, sinkpad) == GST_PAD_LINK_OK,
"Could not link source and sink pads"); "Could not link source and sink pads");
return src;
}
void
cleanup_fakesrc (GstElement * src)
{
GstPad *srcpad, *sinkpad;
fail_unless (gst_element_set_state (src, GST_STATE_NULL) == GST_STATE_SUCCESS,
"could not set to null");
srcpad = gst_element_get_pad (src, "src");
sinkpad = gst_pad_get_peer (srcpad);
ASSERT_OBJECT_REFCOUNT (src, "src", 1);
gst_object_unref (src);
gst_pad_unlink (srcpad, sinkpad);
/* pad refs held by both creator and this function (through _get) */
ASSERT_OBJECT_REFCOUNT (srcpad, "srcpad", 2);
gst_object_unref (srcpad);
gst_object_unref (srcpad);
ASSERT_OBJECT_REFCOUNT (sinkpad, "sinkpad", 2);
gst_object_unref (sinkpad);
gst_object_unref (sinkpad);
}
GST_START_TEST (test_num_buffers)
{
GstElement *src;
src = setup_fakesrc ();
g_object_set (G_OBJECT (src), "num-buffers", 3, NULL);
fail_unless (gst_element_set_state (src, fail_unless (gst_element_set_state (src,
GST_STATE_PLAYING) == GST_STATE_SUCCESS, "could not set to playing"); GST_STATE_PLAYING) == GST_STATE_SUCCESS, "could not set to playing");
@ -93,15 +126,118 @@ GST_START_TEST (test_num_buffers)
g_list_free (buffers); g_list_free (buffers);
/* cleanup */ /* cleanup */
fail_unless (gst_element_set_state (src, GST_STATE_NULL) == GST_STATE_SUCCESS, cleanup_fakesrc (src);
"could not set to null");
gst_object_unref (src);
gst_object_unref (sinkpad);
} }
GST_END_TEST; GST_END_TEST;
GST_START_TEST (test_sizetype_empty)
{
GstElement *src;
GList *l;
src = setup_fakesrc ();
g_object_set (G_OBJECT (src), "sizetype", 1, NULL);
g_object_set (G_OBJECT (src), "num-buffers", 100, NULL);
fail_unless (gst_element_set_state (src,
GST_STATE_PLAYING) == GST_STATE_SUCCESS, "could not set to playing");
while (!have_eos) {
g_usleep (1000);
}
fail_unless (g_list_length (buffers) == 100);
l = buffers;
while (l) {
GstBuffer *buf = l->data;
fail_unless (GST_BUFFER_SIZE (buf) == 0);
l = l->next;
}
g_list_foreach (buffers, (GFunc) gst_mini_object_unref, NULL);
g_list_free (buffers);
/* cleanup */
cleanup_fakesrc (src);
}
GST_END_TEST;
GST_START_TEST (test_sizetype_fixed)
{
GstElement *src;
GList *l;
src = setup_fakesrc ();
g_object_set (G_OBJECT (src), "sizetype", 2, NULL);
g_object_set (G_OBJECT (src), "sizemax", 8192, NULL);
g_object_set (G_OBJECT (src), "num-buffers", 100, NULL);
fail_unless (gst_element_set_state (src,
GST_STATE_PLAYING) == GST_STATE_SUCCESS, "could not set to playing");
while (!have_eos) {
g_usleep (1000);
}
fail_unless (g_list_length (buffers) == 100);
l = buffers;
while (l) {
GstBuffer *buf = l->data;
fail_unless (GST_BUFFER_SIZE (buf) == 8192);
l = l->next;
}
g_list_foreach (buffers, (GFunc) gst_mini_object_unref, NULL);
g_list_free (buffers);
/* cleanup */
cleanup_fakesrc (src);
}
GST_END_TEST;
GST_START_TEST (test_sizetype_random)
{
GstElement *src;
GList *l;
src = setup_fakesrc ();
g_object_set (G_OBJECT (src), "sizetype", 3, NULL);
g_object_set (G_OBJECT (src), "sizemin", 4096, NULL);
g_object_set (G_OBJECT (src), "sizemax", 8192, NULL);
g_object_set (G_OBJECT (src), "num-buffers", 100, NULL);
fail_unless (gst_element_set_state (src,
GST_STATE_PLAYING) == GST_STATE_SUCCESS, "could not set to playing");
while (!have_eos) {
g_usleep (1000);
}
fail_unless (g_list_length (buffers) == 100);
l = buffers;
while (l) {
GstBuffer *buf = l->data;
fail_if (GST_BUFFER_SIZE (buf) > 8192);
fail_if (GST_BUFFER_SIZE (buf) < 4096);
l = l->next;
}
g_list_foreach (buffers, (GFunc) gst_mini_object_unref, NULL);
g_list_free (buffers);
/* cleanup */
cleanup_fakesrc (src);
}
GST_END_TEST;
Suite * Suite *
fakesrc_suite (void) fakesrc_suite (void)
{ {
@ -110,6 +246,9 @@ fakesrc_suite (void)
suite_add_tcase (s, tc_chain); suite_add_tcase (s, tc_chain);
tcase_add_test (tc_chain, test_num_buffers); tcase_add_test (tc_chain, test_num_buffers);
tcase_add_test (tc_chain, test_sizetype_empty);
tcase_add_test (tc_chain, test_sizetype_fixed);
tcase_add_test (tc_chain, test_sizetype_random);
return s; return s;
} }

View file

@ -87,9 +87,6 @@ Check out both <ulink url="http://www.cse.ogi.edu/sysl/">OGI's
pipeline</ulink> and Microsoft's DirectShow for some background. pipeline</ulink> and Microsoft's DirectShow for some background.
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### FUNCTION gst_init ##### --> <!-- ##### FUNCTION gst_init ##### -->
<para> <para>

View file

@ -14,9 +14,6 @@ GstBaseSink
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### STRUCT GstBaseSink ##### --> <!-- ##### STRUCT GstBaseSink ##### -->
<para> <para>

View file

@ -14,9 +14,6 @@ GstBaseSrc
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### STRUCT GstBaseSrc ##### --> <!-- ##### STRUCT GstBaseSrc ##### -->
<para> <para>

View file

@ -14,9 +14,6 @@ GstBaseTransform
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### STRUCT GstBaseTransform ##### --> <!-- ##### STRUCT GstBaseTransform ##### -->
<para> <para>

View file

@ -55,9 +55,6 @@ clock providers in the bin.
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### STRUCT GstBin ##### --> <!-- ##### STRUCT GstBin ##### -->
<para> <para>

View file

@ -85,9 +85,6 @@ Last reviewed on August 12th, 2004 (0.8.5)
#GstPad, #GstMiniObject #GstPad, #GstMiniObject
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### STRUCT GstBuffer ##### --> <!-- ##### STRUCT GstBuffer ##### -->
<para> <para>
The basic structure of a buffer. The basic structure of a buffer.

View file

@ -14,9 +14,6 @@ Structure describing sets of media formats
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### STRUCT GstCaps ##### --> <!-- ##### STRUCT GstCaps ##### -->
<para> <para>

View file

@ -22,9 +22,6 @@ a good measure of the current playback time in the pipeline.
#GstSystemClock #GstSystemClock
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### STRUCT GstClock ##### --> <!-- ##### STRUCT GstClock ##### -->
<para> <para>

View file

@ -16,6 +16,3 @@ This can be done in CFLAGS for compiling old code.
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->

View file

@ -37,9 +37,6 @@ If a subsystem is disabled in GStreamer, a value is defined in
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### MACRO GST_DISABLE_LOADSAVE_REGISTRY ##### --> <!-- ##### MACRO GST_DISABLE_LOADSAVE_REGISTRY ##### -->
<para> <para>

View file

@ -65,9 +65,6 @@ and gst_element_set_clock(). You can wait for the clock to reach a given
<!-- basic object functions --> <!-- basic object functions -->
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### STRUCT GstElement ##### --> <!-- ##### STRUCT GstElement ##### -->
<para> <para>

View file

@ -14,9 +14,6 @@ Defines public information about a #GstElement
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### STRUCT GstElementDetails ##### --> <!-- ##### STRUCT GstElementDetails ##### -->
<para> <para>
This struct is used to define public information about the element. It This struct is used to define public information about the element. It

View file

@ -54,9 +54,6 @@ so that the autopluggers can select a plugin more appropriatly
#GstElement, #GstPlugin, #GstPluginFeature, #GstPadTemplate. #GstElement, #GstPlugin, #GstPluginFeature, #GstPadTemplate.
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### STRUCT GstElementFactory ##### --> <!-- ##### STRUCT GstElementFactory ##### -->
<para> <para>

View file

@ -14,6 +14,3 @@ all gstreamer core related enumerations
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->

View file

@ -14,9 +14,6 @@ Categorized error messages
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### ENUM GstCoreError ##### --> <!-- ##### ENUM GstCoreError ##### -->
<para> <para>

View file

@ -27,9 +27,6 @@ gst_event_new_flush() creates a new flush event.
#GstPad, #GstElement #GstPad, #GstElement
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### STRUCT GstEvent ##### --> <!-- ##### STRUCT GstEvent ##### -->
<para> <para>

View file

@ -14,9 +14,6 @@ GstFakeSink
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### STRUCT GstFakeSink ##### --> <!-- ##### STRUCT GstFakeSink ##### -->
<para> <para>

View file

@ -14,9 +14,6 @@ GstFakeSrc
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### STRUCT GstFakeSrc ##### --> <!-- ##### STRUCT GstFakeSrc ##### -->
<para> <para>
@ -42,6 +39,7 @@ GstFakeSrc
@: @:
@: @:
@: @:
@:
<!-- ##### ARG GstFakeSrc:data ##### --> <!-- ##### ARG GstFakeSrc:data ##### -->
<para> <para>

View file

@ -14,9 +14,6 @@ GstFileSink
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### STRUCT GstFileSink ##### --> <!-- ##### STRUCT GstFileSink ##### -->
<para> <para>

View file

@ -14,9 +14,6 @@ GstFileSrc
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### STRUCT GstFileSrc ##### --> <!-- ##### STRUCT GstFileSrc ##### -->
<para> <para>

View file

@ -17,9 +17,6 @@ on its own.
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### USER_FUNCTION GstFilterFunc ##### --> <!-- ##### USER_FUNCTION GstFilterFunc ##### -->
<para> <para>

View file

@ -15,9 +15,6 @@ formats can be used to perform seeking or conversions/query operations.
#GstPad, #GstElement #GstPad, #GstElement
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### ENUM GstFormat ##### --> <!-- ##### ENUM GstFormat ##### -->
<para> <para>
Standard predefined formats Standard predefined formats

View file

@ -14,9 +14,6 @@ Pseudo link pads
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### STRUCT GstGhostPad ##### --> <!-- ##### STRUCT GstGhostPad ##### -->
<para> <para>

View file

@ -14,9 +14,6 @@ Core interface implemented by #GstElements that allows runtime querying of inter
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### STRUCT GstImplementsInterface ##### --> <!-- ##### STRUCT GstImplementsInterface ##### -->
<para> <para>

View file

@ -15,9 +15,6 @@ in a pipeline.
#GstIndexFactory #GstIndexFactory
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### STRUCT GstIndex ##### --> <!-- ##### STRUCT GstIndex ##### -->
<para> <para>

View file

@ -14,9 +14,6 @@ GstIndexFactory is used to dynamically create GstIndex implementations.
#GstIndex #GstIndex
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### STRUCT GstIndexFactory ##### --> <!-- ##### STRUCT GstIndexFactory ##### -->
<para> <para>
The GstIndexFactory object The GstIndexFactory object

View file

@ -68,9 +68,6 @@ categories. These are explained at GST_DEBUG_CATEGORY_INIT().
and environment variables that affect the debugging output. and environment variables that affect the debugging output.
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### ENUM GstDebugLevel ##### --> <!-- ##### ENUM GstDebugLevel ##### -->
<para> <para>
The level defines the importance of a debugging message. The more important a The level defines the importance of a debugging message. The more important a

View file

@ -14,9 +14,6 @@ GstIterator
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### STRUCT GstIterator ##### --> <!-- ##### STRUCT GstIterator ##### -->
<para> <para>

View file

@ -14,6 +14,3 @@ various portabillity helper macros
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->

View file

@ -21,9 +21,6 @@ The GstMemChunk is used to allocate critical resources for #GstBuffer and
#GstBuffer, #GstEvent, #GstData #GstBuffer, #GstEvent, #GstData
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### STRUCT GstMemChunk ##### --> <!-- ##### STRUCT GstMemChunk ##### -->
<para> <para>
The memchunk structure The memchunk structure

View file

@ -14,9 +14,6 @@ GstMiniObject
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### STRUCT GstMiniObject ##### --> <!-- ##### STRUCT GstMiniObject ##### -->
<para> <para>

View file

@ -67,9 +67,6 @@ object.
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### STRUCT GstObject ##### --> <!-- ##### STRUCT GstObject ##### -->
<para> <para>

View file

@ -57,9 +57,6 @@ Last reviewed on December 13th, 2002 (0.5.0.1)
#GstPadTemplate, #GstElement, #GstEvent #GstPadTemplate, #GstElement, #GstEvent
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### STRUCT GstPad ##### --> <!-- ##### STRUCT GstPad ##### -->
<para> <para>

View file

@ -73,9 +73,6 @@ The following example shows you how to add the padtemplate to an elementfactory:
#GstPad, #GstElementFactory #GstPad, #GstElementFactory
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### STRUCT GstPadTemplate ##### --> <!-- ##### STRUCT GstPadTemplate ##### -->
<para> <para>
The padtemplate object. The padtemplate object.

View file

@ -14,9 +14,6 @@ get a pipeline from a text pipeline description
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### FUNCTION gst_parse_error_quark ##### --> <!-- ##### FUNCTION gst_parse_error_quark ##### -->
<para> <para>

View file

@ -21,9 +21,6 @@ the pipeline, use gst_object_unref() to free its resources.
#GstBin #GstBin
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### STRUCT GstPipeline ##### --> <!-- ##### STRUCT GstPipeline ##### -->
<para> <para>

View file

@ -35,9 +35,6 @@ to bring the plugin into memory.
#GstPluginFeature, #GstType, #GstAutoplug, #GstElementFactory #GstPluginFeature, #GstType, #GstAutoplug, #GstElementFactory
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### FUNCTION gst_plugin_error_quark ##### --> <!-- ##### FUNCTION gst_plugin_error_quark ##### -->
<para> <para>
Get the error quark Get the error quark

View file

@ -14,9 +14,6 @@ This is a base class for anything that can be added to a #GstPlugin.
#GstPlugin #GstPlugin
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### STRUCT GstPluginFeature ##### --> <!-- ##### STRUCT GstPluginFeature ##### -->
<para> <para>

View file

@ -15,9 +15,6 @@ Query types can be used to perform queries on pads and elements.
#GstPad, #GstElement #GstPad, #GstElement
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### ENUM GstQueryType ##### --> <!-- ##### ENUM GstQueryType ##### -->
<para> <para>
Standard predefined Query types Standard predefined Query types

View file

@ -25,9 +25,6 @@ The queue blocks by default.
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### STRUCT GstQueue ##### --> <!-- ##### STRUCT GstQueue ##### -->
<para> <para>

View file

@ -15,6 +15,3 @@ All registries build the #GstRegistryPool.
#GstPlugin, #GstPluginFeature #GstPlugin, #GstPluginFeature
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->

View file

@ -15,9 +15,6 @@ the system.
GstRegistry GstRegistry
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### FUNCTION gst_registry_pool_list ##### --> <!-- ##### FUNCTION gst_registry_pool_list ##### -->
<para> <para>

View file

@ -14,9 +14,6 @@ Generic structure containing fields of names and values
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### STRUCT GstStructure ##### --> <!-- ##### STRUCT GstStructure ##### -->
<para> <para>

View file

@ -15,9 +15,6 @@ system time.
#GstClock #GstClock
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### STRUCT GstSystemClock ##### --> <!-- ##### STRUCT GstSystemClock ##### -->
<para> <para>

View file

@ -14,9 +14,6 @@ List of tags and values used to describe media metadata
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### TYPEDEF GstTagList ##### --> <!-- ##### TYPEDEF GstTagList ##### -->
<para> <para>

View file

@ -14,9 +14,6 @@ Element interface that allows setting and retrieval of media metadata
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### STRUCT GstTagSetter ##### --> <!-- ##### STRUCT GstTagSetter ##### -->
<para> <para>

View file

@ -14,9 +14,6 @@ Tracing functionality
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### STRUCT GstTrace ##### --> <!-- ##### STRUCT GstTrace ##### -->
<para> <para>

View file

@ -14,9 +14,6 @@ gsttrashstack
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### STRUCT GstTrashStack ##### --> <!-- ##### STRUCT GstTrashStack ##### -->
<para> <para>

View file

@ -14,9 +14,6 @@ typefinding subsystem
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### STRUCT GstTypeFind ##### --> <!-- ##### STRUCT GstTypeFind ##### -->
<para> <para>

View file

@ -67,9 +67,6 @@ the given data. You can get quite a bit more complicated than that though.
<link linkend="gstreamer-Writing-typefind-functions">Writing typefind functions</link> <link linkend="gstreamer-Writing-typefind-functions">Writing typefind functions</link>
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### STRUCT GstTypeFindFactory ##### --> <!-- ##### STRUCT GstTypeFindFactory ##### -->
<para> <para>
Object that stores information about a typefind function Object that stores information about a typefind function

View file

@ -14,9 +14,6 @@ various global enums and constants
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### ENUM GstElementState ##### --> <!-- ##### ENUM GstElementState ##### -->
<para> <para>
These contants describe the state a #GstElement is in and transition scheduled for the #GstElement (the pending state). These contants describe the state a #GstElement is in and transition scheduled for the #GstElement (the pending state).

View file

@ -15,9 +15,6 @@ and the element property that can handle a given URI.
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### STRUCT GstURIHandler ##### --> <!-- ##### STRUCT GstURIHandler ##### -->
<para> <para>

View file

@ -14,9 +14,6 @@ describes URI types
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### ENUM GstURIType ##### --> <!-- ##### ENUM GstURIType ##### -->
<para> <para>

View file

@ -14,9 +14,6 @@ various utility functions
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### FUNCTION gst_util_set_value_from_string ##### --> <!-- ##### FUNCTION gst_util_set_value_from_string ##### -->
<para> <para>

View file

@ -14,9 +14,6 @@ GValue implementations specific to GStreamer
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### MACRO GST_MAKE_FOURCC ##### --> <!-- ##### MACRO GST_MAKE_FOURCC ##### -->
<para> <para>
will transform four characters into a host-endiannness guint32 fourcc: will transform four characters into a host-endiannness guint32 fourcc:

View file

@ -15,9 +15,6 @@ The version macros get defined by including "gst/gst.h".
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### MACRO GST_VERSION_MAJOR ##### --> <!-- ##### MACRO GST_VERSION_MAJOR ##### -->
<para> <para>
The major version of GStreamer at compile time The major version of GStreamer at compile time

View file

@ -14,9 +14,6 @@ XML save/restore operations of pipelines
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### STRUCT GstXML ##### --> <!-- ##### STRUCT GstXML ##### -->
<para> <para>

View file

@ -27,9 +27,6 @@ network connections also need a protocol to do this.
#GstBuffer, #GstCaps, #GstEvent #GstBuffer, #GstCaps, #GstEvent
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### ENUM GstDPHeaderFlag ##### --> <!-- ##### ENUM GstDPHeaderFlag ##### -->
<para> <para>

View file

@ -14,9 +14,6 @@ accelerated routines for getting bits from a data stream.
</para> </para>
<!-- ##### SECTION Stability_Level ##### -->
<!-- ##### STRUCT gst_getbits_t ##### --> <!-- ##### STRUCT gst_getbits_t ##### -->
<para> <para>

View file

@ -57,7 +57,8 @@ event_func (GstPad * pad, GstEvent * event)
return FALSE; return FALSE;
} }
GST_START_TEST (test_num_buffers) GstElement *
setup_fakesrc ()
{ {
GstElement *src; GstElement *src;
GstPad *srcpad, *sinkpad; GstPad *srcpad, *sinkpad;
@ -70,8 +71,6 @@ GST_START_TEST (test_num_buffers)
"sink"); "sink");
fail_if (sinkpad == NULL, "Could not create a sinkpad"); fail_if (sinkpad == NULL, "Could not create a sinkpad");
g_object_set (G_OBJECT (src), "num-buffers", 3, NULL);
srcpad = gst_element_get_pad (src, "src"); srcpad = gst_element_get_pad (src, "src");
fail_if (srcpad == NULL, "Could not get source pad from fakesrc"); fail_if (srcpad == NULL, "Could not get source pad from fakesrc");
gst_pad_set_caps (sinkpad, NULL); gst_pad_set_caps (sinkpad, NULL);
@ -80,7 +79,41 @@ GST_START_TEST (test_num_buffers)
fail_unless (gst_pad_link (srcpad, sinkpad) == GST_PAD_LINK_OK, fail_unless (gst_pad_link (srcpad, sinkpad) == GST_PAD_LINK_OK,
"Could not link source and sink pads"); "Could not link source and sink pads");
return src;
}
void
cleanup_fakesrc (GstElement * src)
{
GstPad *srcpad, *sinkpad;
fail_unless (gst_element_set_state (src, GST_STATE_NULL) == GST_STATE_SUCCESS,
"could not set to null");
srcpad = gst_element_get_pad (src, "src");
sinkpad = gst_pad_get_peer (srcpad);
ASSERT_OBJECT_REFCOUNT (src, "src", 1);
gst_object_unref (src);
gst_pad_unlink (srcpad, sinkpad);
/* pad refs held by both creator and this function (through _get) */
ASSERT_OBJECT_REFCOUNT (srcpad, "srcpad", 2);
gst_object_unref (srcpad);
gst_object_unref (srcpad);
ASSERT_OBJECT_REFCOUNT (sinkpad, "sinkpad", 2);
gst_object_unref (sinkpad);
gst_object_unref (sinkpad);
}
GST_START_TEST (test_num_buffers)
{
GstElement *src;
src = setup_fakesrc ();
g_object_set (G_OBJECT (src), "num-buffers", 3, NULL);
fail_unless (gst_element_set_state (src, fail_unless (gst_element_set_state (src,
GST_STATE_PLAYING) == GST_STATE_SUCCESS, "could not set to playing"); GST_STATE_PLAYING) == GST_STATE_SUCCESS, "could not set to playing");
@ -93,15 +126,118 @@ GST_START_TEST (test_num_buffers)
g_list_free (buffers); g_list_free (buffers);
/* cleanup */ /* cleanup */
fail_unless (gst_element_set_state (src, GST_STATE_NULL) == GST_STATE_SUCCESS, cleanup_fakesrc (src);
"could not set to null");
gst_object_unref (src);
gst_object_unref (sinkpad);
} }
GST_END_TEST; GST_END_TEST;
GST_START_TEST (test_sizetype_empty)
{
GstElement *src;
GList *l;
src = setup_fakesrc ();
g_object_set (G_OBJECT (src), "sizetype", 1, NULL);
g_object_set (G_OBJECT (src), "num-buffers", 100, NULL);
fail_unless (gst_element_set_state (src,
GST_STATE_PLAYING) == GST_STATE_SUCCESS, "could not set to playing");
while (!have_eos) {
g_usleep (1000);
}
fail_unless (g_list_length (buffers) == 100);
l = buffers;
while (l) {
GstBuffer *buf = l->data;
fail_unless (GST_BUFFER_SIZE (buf) == 0);
l = l->next;
}
g_list_foreach (buffers, (GFunc) gst_mini_object_unref, NULL);
g_list_free (buffers);
/* cleanup */
cleanup_fakesrc (src);
}
GST_END_TEST;
GST_START_TEST (test_sizetype_fixed)
{
GstElement *src;
GList *l;
src = setup_fakesrc ();
g_object_set (G_OBJECT (src), "sizetype", 2, NULL);
g_object_set (G_OBJECT (src), "sizemax", 8192, NULL);
g_object_set (G_OBJECT (src), "num-buffers", 100, NULL);
fail_unless (gst_element_set_state (src,
GST_STATE_PLAYING) == GST_STATE_SUCCESS, "could not set to playing");
while (!have_eos) {
g_usleep (1000);
}
fail_unless (g_list_length (buffers) == 100);
l = buffers;
while (l) {
GstBuffer *buf = l->data;
fail_unless (GST_BUFFER_SIZE (buf) == 8192);
l = l->next;
}
g_list_foreach (buffers, (GFunc) gst_mini_object_unref, NULL);
g_list_free (buffers);
/* cleanup */
cleanup_fakesrc (src);
}
GST_END_TEST;
GST_START_TEST (test_sizetype_random)
{
GstElement *src;
GList *l;
src = setup_fakesrc ();
g_object_set (G_OBJECT (src), "sizetype", 3, NULL);
g_object_set (G_OBJECT (src), "sizemin", 4096, NULL);
g_object_set (G_OBJECT (src), "sizemax", 8192, NULL);
g_object_set (G_OBJECT (src), "num-buffers", 100, NULL);
fail_unless (gst_element_set_state (src,
GST_STATE_PLAYING) == GST_STATE_SUCCESS, "could not set to playing");
while (!have_eos) {
g_usleep (1000);
}
fail_unless (g_list_length (buffers) == 100);
l = buffers;
while (l) {
GstBuffer *buf = l->data;
fail_if (GST_BUFFER_SIZE (buf) > 8192);
fail_if (GST_BUFFER_SIZE (buf) < 4096);
l = l->next;
}
g_list_foreach (buffers, (GFunc) gst_mini_object_unref, NULL);
g_list_free (buffers);
/* cleanup */
cleanup_fakesrc (src);
}
GST_END_TEST;
Suite * Suite *
fakesrc_suite (void) fakesrc_suite (void)
{ {
@ -110,6 +246,9 @@ fakesrc_suite (void)
suite_add_tcase (s, tc_chain); suite_add_tcase (s, tc_chain);
tcase_add_test (tc_chain, test_num_buffers); tcase_add_test (tc_chain, test_num_buffers);
tcase_add_test (tc_chain, test_sizetype_empty);
tcase_add_test (tc_chain, test_sizetype_fixed);
tcase_add_test (tc_chain, test_sizetype_random);
return s; return s;
} }