tests: adaptivedemux: only check for data length after seek

When the test involves doing a seek, only check for data size after
the seek. The final segment range after seek might be different/smaller
than the threshold for doing the seek and doing the check before
seeking would fail.
This commit is contained in:
Thiago Santos 2016-04-22 15:02:01 -03:00
parent 00a74e98b3
commit 04e4392afe
2 changed files with 8 additions and 4 deletions

View file

@ -175,10 +175,12 @@ gst_adaptive_demux_test_check_received_data (GstAdaptiveDemuxTestEngine *
(guint64) gst_buffer_get_size (buffer), (guint64) gst_buffer_get_size (buffer),
testOutputStreamData->expected_size, stream->segment_start); testOutputStreamData->expected_size, stream->segment_start);
fail_unless (stream->total_received_size + /* Only verify after seeking */
stream->segment_received_size + if (testData->seek_event && testData->seeked)
gst_buffer_get_size (buffer) <= testOutputStreamData->expected_size, fail_unless (stream->total_received_size +
"Received unexpected data, please check what segments are being downloaded"); stream->segment_received_size +
gst_buffer_get_size (buffer) <= testOutputStreamData->expected_size,
"Received unexpected data, please check what segments are being downloaded");
streamOffset = stream->segment_start + stream->segment_received_size; streamOffset = stream->segment_start + stream->segment_received_size;
if (testOutputStreamData->expected_data) { if (testOutputStreamData->expected_data) {
@ -357,6 +359,7 @@ testSeekAdaptiveDemuxSendsData (GstAdaptiveDemuxTestEngine * engine,
g_cond_wait (&testData->test_task_state_cond, g_cond_wait (&testData->test_task_state_cond,
&testData->test_task_state_lock); &testData->test_task_state_lock);
} }
testData->seeked = TRUE;
g_mutex_unlock (&testData->test_task_state_lock); g_mutex_unlock (&testData->test_task_state_lock);
/* we can continue now, but this buffer will be rejected by AppSink /* we can continue now, but this buffer will be rejected by AppSink
* because it is in flushing mode * because it is in flushing mode

View file

@ -113,6 +113,7 @@ typedef struct _GstAdaptiveDemuxTestCase
*/ */
guint64 threshold_for_seek; guint64 threshold_for_seek;
GstEvent *seek_event; GstEvent *seek_event;
gboolean seeked;
gpointer signal_context; gpointer signal_context;
} GstAdaptiveDemuxTestCase; } GstAdaptiveDemuxTestCase;