From 590df23cb1e0f9267835d3fd35238783412a59a5 Mon Sep 17 00:00:00 2001 From: Florin Apostol Date: Fri, 30 Oct 2015 15:02:35 +0000 Subject: [PATCH] dashdemux: unit testing reproducing inherited segment duration overflow unit test reproducing https://bugzilla.gnome.org/show_bug.cgi?id=751832 --- tests/check/elements/dash_mpd.c | 133 ++++++++++++++++++++++++++++++++ 1 file changed, 133 insertions(+) diff --git a/tests/check/elements/dash_mpd.c b/tests/check/elements/dash_mpd.c index 6ea64bcb87..545ee97b73 100644 --- a/tests/check/elements/dash_mpd.c +++ b/tests/check/elements/dash_mpd.c @@ -4480,6 +4480,138 @@ GST_START_TEST (dash_mpdparser_segment_timeline) GST_END_TEST; +/* + * Test SegmentList with multiple inherited segmentURLs + * + */ +GST_START_TEST (dash_mpdparser_multiple_inherited_segmentURL) +{ + GList *adaptationSets; + GstAdaptationSetNode *adapt_set; + GstActiveStream *activeStream; + GstMediaFragmentInfo fragment; + GstClockTime expectedDuration; + GstClockTime expectedTimestamp; + GstFlowReturn flow; + + /* + * Period duration is 30 seconds + * Period start is 10 seconds. Thus, period duration is 20 seconds. + * + * There are 2 segments in the AdaptationSet segment list and 2 in the + * Representation's segment list. + * Segment duration is 5s for the Adaptation segments and 8s for + * Representation segments. + * Separately, each segment list (duration 2*5=10 or 2*8=16) fits comfortably + * in the Period's 20s duration. + * + * We expect the Representation segments to overwrite the AdaptationSet segments. + */ + const gchar *xml = + "" + "" + "" + " " + " " + " " + " " + " " + " " + " " + " " + " " + " " + " "; + + gboolean ret; + GstMpdClient *mpdclient = gst_mpd_client_new (); + + ret = gst_mpd_parse (mpdclient, xml, (gint) strlen (xml)); + assert_equals_int (ret, TRUE); + + /* process the xml data */ + ret = gst_mpd_client_setup_media_presentation (mpdclient, GST_CLOCK_TIME_NONE, + -1, NULL); + assert_equals_int (ret, TRUE); + + /* get the list of adaptation sets of the first period */ + adaptationSets = gst_mpd_client_get_adaptation_sets (mpdclient); + fail_if (adaptationSets == NULL); + + /* setup streaming from the first adaptation set */ + adapt_set = (GstAdaptationSetNode *) g_list_nth_data (adaptationSets, 0); + fail_if (adapt_set == NULL); + ret = gst_mpd_client_setup_streaming (mpdclient, adapt_set); + assert_equals_int (ret, TRUE); + + activeStream = gst_mpdparser_get_active_stream_by_index (mpdclient, 0); + fail_if (activeStream == NULL); + + expectedDuration = duration_to_ms (0, 0, 0, 0, 0, 8, 0); + expectedTimestamp = duration_to_ms (0, 0, 0, 0, 0, 0, 0); + + /* the representation contains 2 segments defined in the Representation + * + * Both will have the duration specified in the Representation (8) + */ + + /* check first segment */ + ret = gst_mpd_client_get_next_fragment (mpdclient, 0, &fragment); + assert_equals_int (ret, TRUE); + assert_equals_string (fragment.uri, "/TestMedia2"); + assert_equals_int64 (fragment.range_start, 30); + assert_equals_int64 (fragment.range_end, 40); + assert_equals_string (fragment.index_uri, "/TestIndex2"); + assert_equals_int64 (fragment.index_range_start, 300); + assert_equals_int64 (fragment.index_range_end, 400); + assert_equals_uint64 (fragment.duration, expectedDuration * GST_MSECOND); + assert_equals_uint64 (fragment.timestamp, expectedTimestamp * GST_MSECOND); + gst_media_fragment_info_clear (&fragment); + + /* advance to next segment */ + flow = gst_mpd_client_advance_segment (mpdclient, activeStream, TRUE); + assert_equals_int (flow, GST_FLOW_OK); + + /* second segment starts after previous ends */ + expectedTimestamp = expectedTimestamp + expectedDuration; + + /* check second segment */ + ret = gst_mpd_client_get_next_fragment (mpdclient, 0, &fragment); + assert_equals_int (ret, TRUE); + assert_equals_string (fragment.uri, "/TestMedia3"); + assert_equals_int64 (fragment.range_start, 40); + assert_equals_int64 (fragment.range_end, 50); + assert_equals_string (fragment.index_uri, "/TestIndex3"); + assert_equals_int64 (fragment.index_range_start, 400); + assert_equals_int64 (fragment.index_range_end, 500); + assert_equals_uint64 (fragment.duration, expectedDuration * GST_MSECOND); + assert_equals_uint64 (fragment.timestamp, expectedTimestamp * GST_MSECOND); + gst_media_fragment_info_clear (&fragment); + + /* try to advance to the next segment. There isn't any, so it should fail */ + flow = gst_mpd_client_advance_segment (mpdclient, activeStream, TRUE); + assert_equals_int (flow, GST_FLOW_EOS); + + gst_mpd_client_free (mpdclient); +} + +GST_END_TEST; + /* * Test parsing empty xml string * @@ -5099,6 +5231,7 @@ dash_suite (void) tcase_add_test (tc_complexMPD, dash_mpdparser_segment_list); tcase_add_test (tc_complexMPD, dash_mpdparser_segment_template); tcase_add_test (tc_complexMPD, dash_mpdparser_segment_timeline); + tcase_add_test (tc_complexMPD, dash_mpdparser_multiple_inherited_segmentURL); /* tests checking the parsing of missing/incomplete attributes of xml */ tcase_add_test (tc_negativeTests, dash_mpdparser_missing_xml); -- 2.34.1