gstreamer_core/libs/gst/check/gstconsistencychecker.c
branchRCL_3
changeset 30 7e817e7e631c
parent 29 567bb019e3e3
equal deleted inserted replaced
29:567bb019e3e3 30:7e817e7e631c
     1 /* GStreamer
       
     2  *
       
     3  * unit testing helper lib
       
     4  *
       
     5  * Copyright (C) 2009 Edward Hervey <bilboed@bilboed.com>
       
     6  *
       
     7  * This library is free software; you can redistribute it and/or
       
     8  * modify it under the terms of the GNU Library General Public
       
     9  * License as published by the Free Software Foundation; either
       
    10  * version 2 of the License, or (at your option) any later version.
       
    11  *
       
    12  * This library is distributed in the hope that it will be useful,
       
    13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
       
    14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
       
    15  * Library General Public License for more details.
       
    16  *
       
    17  * You should have received a copy of the GNU Library General Public
       
    18  * License along with this library; if not, write to the
       
    19  * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
       
    20  * Boston, MA 02111-1307, USA.
       
    21  */
       
    22 
       
    23 /**
       
    24  * SECTION:gstcheckconsistencychecker
       
    25  * @short_description: Data flow consistency checker for GStreamer unit tests.
       
    26  *
       
    27  * These macros and functions are for internal use of the unit tests found
       
    28  * inside the 'check' directories of various GStreamer packages.
       
    29  *
       
    30  * Since: 0.10.24
       
    31  */
       
    32 
       
    33 #include "gstconsistencychecker.h"
       
    34 
       
    35 struct _GstStreamConsistency
       
    36 {
       
    37   gboolean flushing;
       
    38   gboolean newsegment;
       
    39   gboolean eos;
       
    40   gulong probeid;
       
    41   GstPad *pad;
       
    42 };
       
    43 
       
    44 static gboolean
       
    45 source_pad_data_cb (GstPad * pad, GstMiniObject * data,
       
    46     GstStreamConsistency * consist)
       
    47 {
       
    48   if (GST_IS_BUFFER (data)) {
       
    49     GST_DEBUG_OBJECT (pad, "Buffer %" GST_TIME_FORMAT,
       
    50         GST_TIME_ARGS (GST_BUFFER_TIMESTAMP (GST_BUFFER (data))));
       
    51     /* If an EOS went through, a buffer would be invalid */
       
    52     fail_if (consist->eos, "Buffer received after EOS");
       
    53     /* Buffers need to be preceded by a newsegment event */
       
    54     fail_unless (consist->newsegment, "Buffer received without newsegment");
       
    55   } else {
       
    56     GstEvent *event = (GstEvent *) data;
       
    57 
       
    58     GST_DEBUG_OBJECT (pad, "%s", GST_EVENT_TYPE_NAME (event));
       
    59     switch (GST_EVENT_TYPE (event)) {
       
    60       case GST_EVENT_FLUSH_START:
       
    61         consist->flushing = TRUE;
       
    62         break;
       
    63       case GST_EVENT_FLUSH_STOP:
       
    64         /* Receiving a flush-stop is only valid after receiving a flush-start */
       
    65         fail_unless (consist->flushing,
       
    66             "Received a FLUSH_STOP without a FLUSH_START");
       
    67         fail_if (consist->eos, "Received a FLUSH_STOP after an EOS");
       
    68         consist->flushing = FALSE;
       
    69         break;
       
    70       case GST_EVENT_NEWSEGMENT:
       
    71         consist->newsegment = TRUE;
       
    72         consist->eos = FALSE;
       
    73         break;
       
    74       case GST_EVENT_EOS:
       
    75         /* FIXME : not 100% sure about whether two eos in a row is valid */
       
    76         fail_if (consist->eos, "Received EOS just after another EOS");
       
    77         consist->eos = TRUE;
       
    78         consist->newsegment = FALSE;
       
    79         break;
       
    80       case GST_EVENT_TAG:
       
    81         GST_DEBUG_OBJECT (pad, "tag %" GST_PTR_FORMAT, event->structure);
       
    82       default:
       
    83         if (GST_EVENT_IS_SERIALIZED (event) && GST_EVENT_IS_DOWNSTREAM (event)) {
       
    84           fail_if (consist->eos, "Event received after EOS");
       
    85           fail_unless (consist->newsegment, "Event received before newsegment");
       
    86         }
       
    87         /* FIXME : Figure out what to do for other events */
       
    88         break;
       
    89     }
       
    90   }
       
    91 
       
    92   return TRUE;
       
    93 }
       
    94 
       
    95 /**
       
    96  * gst_consistency_checker_new:
       
    97  * @pad: The #GstPad on which the dataflow will be checked.
       
    98  *
       
    99  * Sets up a data probe on the given pad which will raise assertions if the
       
   100  * data flow is inconsistent.
       
   101  *
       
   102  * Currently only works for source pads.
       
   103  *
       
   104  * Returns: A #GstStreamConsistency structure used to track data flow.
       
   105  *
       
   106  * Since: 0.10.24
       
   107  */
       
   108 
       
   109 GstStreamConsistency *
       
   110 gst_consistency_checker_new (GstPad * pad)
       
   111 {
       
   112   GstStreamConsistency *consist;
       
   113 
       
   114   g_return_val_if_fail (pad != NULL, NULL);
       
   115 
       
   116   consist = g_new0 (GstStreamConsistency, 1);
       
   117   consist->pad = g_object_ref (pad);
       
   118   consist->probeid =
       
   119       gst_pad_add_data_probe (pad, (GCallback) source_pad_data_cb, consist);
       
   120 
       
   121   return consist;
       
   122 }
       
   123 
       
   124 /**
       
   125  * gst_consistency_checker_reset:
       
   126  * @consist: The #GstStreamConsistency to reset.
       
   127  *
       
   128  * Reset the stream checker's internal variables.
       
   129  *
       
   130  * Since: 0.10.24
       
   131  */
       
   132 
       
   133 void
       
   134 gst_consistency_checker_reset (GstStreamConsistency * consist)
       
   135 {
       
   136   consist->eos = FALSE;
       
   137   consist->flushing = FALSE;
       
   138   consist->newsegment = FALSE;
       
   139 }
       
   140 
       
   141 /**
       
   142  * gst_consistency_checker_free:
       
   143  * @consist: The #GstStreamConsistency to free.
       
   144  *
       
   145  * Frees the allocated data and probe associated with @consist.
       
   146  *
       
   147  * Since: 0.10.24
       
   148  */
       
   149 
       
   150 void
       
   151 gst_consistency_checker_free (GstStreamConsistency * consist)
       
   152 {
       
   153   /* Remove the data probe */
       
   154   gst_pad_remove_data_probe (consist->pad, consist->probeid);
       
   155   g_object_unref (consist->pad);
       
   156   g_free (consist);
       
   157 }