mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2024-12-30 12:10:37 +00:00
tests: more rtpbin checks
This commit is contained in:
parent
1c85da2d2b
commit
51c07ac626
1 changed files with 55 additions and 40 deletions
|
@ -27,58 +27,73 @@ 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");
|
||||
|
||||
/* 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);
|
||||
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);
|
||||
|
||||
/* 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);
|
||||
/* 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);
|
||||
|
||||
/* 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);
|
||||
/* 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);
|
||||
|
||||
/* 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);
|
||||
/* 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);
|
||||
|
||||
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);
|
||||
/* 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);
|
||||
|
||||
/* the other pad should be gone now */
|
||||
fail_unless (gst_element_get_static_pad (rtpbin, "send_rtp_src_0") == NULL);
|
||||
/* 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);
|
||||
|
||||
/* 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);
|
||||
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);
|
||||
|
||||
/* 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 other pad should be gone now */
|
||||
fail_unless (gst_element_get_static_pad (rtpbin, "send_rtp_src_0") == NULL);
|
||||
|
||||
/* the session should be gone now */
|
||||
g_signal_emit_by_name (rtpbin, "get-internal-session", 0, &session);
|
||||
fail_unless (session == 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);
|
||||
|
||||
/* unref the request pad and the static pad */
|
||||
gst_object_unref (rtp_sink);
|
||||
gst_object_unref (rtp_src);
|
||||
gst_object_unref (rtcp_src);
|
||||
/* 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);
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue