tests: qtdemux: Add checking exposed segment event
authorSeungha Yang <seungha.yang@navercorp.com>
Fri, 1 Jun 2018 13:47:10 +0000 (22:47 +0900)
committerThibault Saunier <tsaunier@igalia.com>
Wed, 6 Jun 2018 15:19:25 +0000 (11:19 -0400)
https://bugzilla.gnome.org/show_bug.cgi?id=796480

tests/check/elements/qtdemux.c

index 07acbfc..44aa9b4 100644 (file)
@@ -33,19 +33,42 @@ typedef struct
 static GstPadProbeReturn
 qtdemux_probe (GstPad * pad, GstPadProbeInfo * info, CommonTestData * data)
 {
-  GstBuffer *buf = GST_PAD_PROBE_INFO_BUFFER (info);
+  if (GST_IS_EVENT (GST_PAD_PROBE_INFO_DATA (info))) {
+    GstEvent *ev = GST_PAD_PROBE_INFO_EVENT (info);
+
+    switch (GST_EVENT_TYPE (ev)) {
+      case GST_EVENT_SEGMENT:
+      {
+        const GstSegment *segment;
+        gst_event_parse_segment (ev, &segment);
+        fail_unless (GST_CLOCK_TIME_IS_VALID (segment->format));
+        fail_unless (GST_CLOCK_TIME_IS_VALID (segment->start));
+        fail_unless (GST_CLOCK_TIME_IS_VALID (segment->base));
+        fail_unless (GST_CLOCK_TIME_IS_VALID (segment->time));
+        fail_unless (GST_CLOCK_TIME_IS_VALID (segment->position));
+        break;
+      }
+        break;
+      default:
+        break;
+    }
+
+    return GST_PAD_PROBE_OK;
+  } else if (GST_IS_BUFFER (GST_PAD_PROBE_INFO_DATA (info))) {
+    GstBuffer *buf = GST_PAD_PROBE_INFO_BUFFER (info);
+
+    fail_unless_equals_int (gst_buffer_get_size (buf), data->expected_size);
+    fail_unless_equals_uint64 (GST_BUFFER_PTS (buf), data->expected_time);
+  }
 
-  fail_unless_equals_int (gst_buffer_get_size (buf), data->expected_size);
-  fail_unless_equals_uint64 (GST_BUFFER_PTS (buf), data->expected_time);
-  gst_buffer_unref (buf);
-  return GST_PAD_PROBE_HANDLED;
+  return GST_PAD_PROBE_DROP;
 }
 
 static void
 qtdemux_pad_added_cb (GstElement * element, GstPad * pad, CommonTestData * data)
 {
   data->srcpad = pad;
-  gst_pad_add_probe (pad, GST_PAD_PROBE_TYPE_BUFFER,
+  gst_pad_add_probe (pad, GST_PAD_PROBE_TYPE_DATA_DOWNSTREAM,
       (GstPadProbeCallback) qtdemux_probe, data, NULL);
 }