Remove our forcing of analyzeduration and probesize as they seem to
authorCarl Hetherington <cth@carlh.net>
Thu, 19 Dec 2019 22:56:49 +0000 (22:56 +0000)
committerCarl Hetherington <cth@carlh.net>
Thu, 19 Dec 2019 23:26:36 +0000 (00:26 +0100)
cause weird problems when scanning some files.  The unit test case
added here is a case in point: before this patch one
stream reported an incorrect channel count and sample rate.

It's a bit worrying as these parameters have been in DoM for many years,
but perhaps they have become unnecessary / harmful with changes to FFmpeg.

src/lib/ffmpeg.cc
test/ffmpeg_examiner_test.cc

index 0668f9f37b381707b726cee11086ec4511845bca..8dc525db970d4c6efb6a2ea0e1fade96e0c8ca23 100644 (file)
@@ -120,11 +120,6 @@ FFmpeg::setup_general ()
        _format_context->pb = _avio_context;
 
        AVDictionary* options = 0;
-       /* These durations are in microseconds, and represent how far into the content file
-          we will look for streams.
-       */
-       av_dict_set (&options, "analyzeduration", raw_convert<string> (5 * 60 * 1000000).c_str(), 0);
-       av_dict_set (&options, "probesize", raw_convert<string> (5 * 60 * 1000000).c_str(), 0);
 #ifdef DCPOMATIC_VARIANT_SWAROOP
        if (_ffmpeg_content->kdm()) {
                DecryptedECinemaKDM kdm (_ffmpeg_content->kdm().get(), Config::instance()->decryption_chain()->key().get());
index b6b2bbf06c5ee543845c31c3644fba430c779800..5da7bbd3f6c3d500c5de930d17d35037a9b5c167 100644 (file)
@@ -19,8 +19,7 @@
 */
 
 /** @file  test/ffmpeg_examiner_test.cc
- *  @brief Check that the FFmpegExaminer can extract the first video and audio time
- *  correctly from data/count300bd24.m2ts.
+ *  @brief FFMpegExaminer tests
  *  @ingroup specific
  */
 
@@ -33,6 +32,9 @@
 using boost::shared_ptr;
 using namespace dcpomatic;
 
+/** Check that the FFmpegExaminer can extract the first video and audio time
+ *  correctly from data/count300bd24.m2ts.
+ */
 BOOST_AUTO_TEST_CASE (ffmpeg_examiner_test)
 {
        shared_ptr<Film> film = new_test_film ("ffmpeg_examiner_test");
@@ -43,3 +45,19 @@ BOOST_AUTO_TEST_CASE (ffmpeg_examiner_test)
        BOOST_CHECK_EQUAL (examiner->audio_streams().size(), 1U);
        BOOST_CHECK_EQUAL (examiner->audio_streams()[0]->first_audio.get().get(), ContentTime::from_seconds(600).get());
 }
+
+/** Check that audio sampling rate and channel counts are correctly picked up from
+ *  a problematic file.  When we used to specify analyzeduration and probesize
+ *  this file's details were picked up incorrectly.
+ */
+BOOST_AUTO_TEST_CASE (ffmpeg_examiner_probesize_test)
+{
+       shared_ptr<FFmpegContent> content (new FFmpegContent(private_data / "RockyTop10 Playlist Flat.m4v"));
+       shared_ptr<FFmpegExaminer> examiner (new FFmpegExaminer(content));
+
+       BOOST_CHECK_EQUAL (examiner->audio_streams().size(), 2U);
+       BOOST_CHECK_EQUAL (examiner->audio_streams()[0]->frame_rate(), 48000);
+       BOOST_CHECK_EQUAL (examiner->audio_streams()[0]->channels(), 2);
+       BOOST_CHECK_EQUAL (examiner->audio_streams()[1]->frame_rate(), 48000);
+       BOOST_CHECK_EQUAL (examiner->audio_streams()[1]->channels(), 6);
+}