summaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authorCarl Hetherington <cth@carlh.net>2022-05-10 01:16:44 +0200
committerCarl Hetherington <cth@carlh.net>2022-05-11 20:36:10 +0200
commitb7a57184200d340bebcf81552aa1f05f220a8ec5 (patch)
tree77fa11cc1ff6fff7d71635619bbc68d8c225839a /test
parentd2e40a18eee940f1333c7e63d423b1d56e50c5e6 (diff)
Fix ignore_video checker for separate-3D content (#2246).
Diffstat (limited to 'test')
-rw-r--r--test/threed_test.cc34
1 files changed, 34 insertions, 0 deletions
diff --git a/test/threed_test.cc b/test/threed_test.cc
index 4fe91ebca..b4599cf80 100644
--- a/test/threed_test.cc
+++ b/test/threed_test.cc
@@ -25,16 +25,20 @@
*/
+#include "lib/butler.h"
#include "lib/config.h"
#include "lib/content_factory.h"
#include "lib/cross.h"
#include "lib/dcp_content_type.h"
#include "lib/ffmpeg_content.h"
#include "lib/film.h"
+#include "lib/image.h"
#include "lib/job.h"
#include "lib/job_manager.h"
#include "lib/make_dcp.h"
+#include "lib/player.h"
#include "lib/ratio.h"
+#include "lib/util.h"
#include "lib/video_content.h"
#include "test.h"
#include <boost/test/unit_test.hpp>
@@ -255,3 +259,33 @@ BOOST_AUTO_TEST_CASE (threed_test_separate_files_very_different_lengths)
film->set_three_d (true);
make_and_verify_dcp (film);
}
+
+
+BOOST_AUTO_TEST_CASE (threed_test_butler_overfill)
+{
+ auto film = new_test_film2("threed_test_butler_overfill");
+ auto A = make_shared<FFmpegContent>(TestPaths::private_data() / "arrietty_JP-EN.mkv");
+ film->examine_and_add_content(A);
+ auto B = make_shared<FFmpegContent>(TestPaths::private_data() / "arrietty_JP-EN.mkv");
+ film->examine_and_add_content(B);
+ BOOST_REQUIRE (!wait_for_jobs());
+
+ auto player = std::make_shared<Player>(film, Image::Alignment::COMPACT);
+ int const audio_channels = 2;
+ auto butler = std::make_shared<Butler>(film, player, AudioMapping(), audio_channels, boost::bind(PlayerVideo::force, AV_PIX_FMT_RGB24), VideoRange::FULL, Image::Alignment::PADDED, true, false);
+
+ int const audio_frames = 1920;
+ std::vector<float> audio(audio_frames * audio_channels);
+
+ B->video->set_frame_type(VideoFrameType::THREE_D_RIGHT);
+ B->set_position(film, dcpomatic::DCPTime());
+
+ butler->seek(dcpomatic::DCPTime(), true);
+ Butler::Error error;
+ for (auto i = 0; i < 960; ++i) {
+ butler->get_video(Butler::Behaviour::BLOCKING, &error);
+ butler->get_audio(Butler::Behaviour::BLOCKING, audio.data(), audio_frames);
+ }
+ BOOST_REQUIRE (error.code == Butler::Error::Code::NONE);
+}
+