summaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authorCarl Hetherington <cth@carlh.net>2022-03-14 20:29:44 +0100
committerCarl Hetherington <cth@carlh.net>2022-03-15 09:20:17 +0100
commit0c846af54055b9915c6c68617cd28176d5f84351 (patch)
tree72a7c31582f3919a4e18c91ccaa412c0d91a6056 /test
parent6acf4527c0b2919f5774d9dbff2ad5c0fa98075a (diff)
Fix incorrectly-timed emission of silence padding causing buffer fill (#2217).
On initialisation or after seek we insert silence corresponding to a positive delay in an audio stream. Previously this inserted silence was done at time 0, so that after a seek to time T the silent frames would come out of the audio merger at time 0 and then the player would fill the space up to time T with silence. If T was far enough along this would fill the audio buffers without there being any video.
Diffstat (limited to 'test')
-rw-r--r--test/butler_test.cc46
1 files changed, 41 insertions, 5 deletions
diff --git a/test/butler_test.cc b/test/butler_test.cc
index 3d524a3b2..bee66217f 100644
--- a/test/butler_test.cc
+++ b/test/butler_test.cc
@@ -1,5 +1,5 @@
/*
- Copyright (C) 2017-2021 Carl Hetherington <cth@carlh.net>
+ Copyright (C) 2017-2022 Carl Hetherington <cth@carlh.net>
This file is part of DCP-o-matic.
@@ -19,13 +19,14 @@
*/
+#include "lib/audio_content.h"
+#include "lib/audio_mapping.h"
#include "lib/butler.h"
-#include "lib/film.h"
-#include "lib/dcp_content_type.h"
-#include "lib/ratio.h"
#include "lib/content_factory.h"
-#include "lib/audio_mapping.h"
+#include "lib/dcp_content_type.h"
+#include "lib/film.h"
#include "lib/player.h"
+#include "lib/ratio.h"
#include "test.h"
#include <boost/test/unit_test.hpp>
@@ -77,3 +78,38 @@ BOOST_AUTO_TEST_CASE (butler_test1)
BOOST_REQUIRE_EQUAL (buffer[i * 6 + 5], 0);
}
}
+
+
+BOOST_AUTO_TEST_CASE (butler_test2)
+{
+ auto content = content_factory(TestPaths::private_data() / "arrietty_JP-EN.mkv");
+ BOOST_REQUIRE (!content.empty());
+ auto film = new_test_film2 ("butler_test2", { content.front() });
+ BOOST_REQUIRE (content.front()->audio);
+ content.front()->audio->set_delay(100);
+
+ /* This is the map of the player output (5.1) to the butler output (also 5.1) */
+ auto map = AudioMapping (6, 6);
+ for (int i = 0; i < 6; ++i) {
+ map.set (i, i, 1);
+ }
+
+ Butler butler (film, make_shared<Player>(film, Image::Alignment::COMPACT), map, 6, bind(&PlayerVideo::force, _1, AV_PIX_FMT_RGB24), VideoRange::FULL, Image::Alignment::COMPACT, false, false);
+
+ int const audio_frames_per_video_frame = 48000 / 25;
+ float audio_buffer[audio_frames_per_video_frame * 6];
+ for (int i = 0; i < 16; ++i) {
+ butler.get_video(Butler::Behaviour::BLOCKING, 0);
+ butler.get_audio(Butler::Behaviour::BLOCKING, audio_buffer, audio_frames_per_video_frame);
+ }
+
+ butler.seek (DCPTime::from_seconds(60), false);
+
+ for (int i = 0; i < 240; ++i) {
+ butler.get_video(Butler::Behaviour::BLOCKING, 0);
+ butler.get_audio(Butler::Behaviour::BLOCKING, audio_buffer, audio_frames_per_video_frame);
+ }
+
+ butler.rethrow();
+}
+