summaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authorCarl Hetherington <cth@carlh.net>2018-02-08 20:41:57 +0000
committerCarl Hetherington <cth@carlh.net>2018-02-08 20:41:57 +0000
commite3f2d81e7e7d3b36d47020b5704fcc36d6959952 (patch)
treeb40b74eb97fc6e8a1fd375a96241a987b92241dd /test
parent18dbb50a911612e3148ccb1479928fda74b83194 (diff)
Pass DCP subtitles before video so that they are present when the video frame looks for them.
Diffstat (limited to 'test')
m---------test/data0
-rw-r--r--test/player_test.cc29
2 files changed, 29 insertions, 0 deletions
diff --git a/test/data b/test/data
-Subproject 8e92ab871972fd6b19114e5783b5dfccba9a61e
+Subproject 4e9eb33fcd08820325f40446e089e10928fe3c5
diff --git a/test/player_test.cc b/test/player_test.cc
index 1580d5902..e22570bc0 100644
--- a/test/player_test.cc
+++ b/test/player_test.cc
@@ -230,3 +230,32 @@ BOOST_AUTO_TEST_CASE (player_seek_test)
check_image(String::compose("test/data/player_seek_test_%1.png", i), String::compose("build/test/player_seek_test_%1.png", i));
}
}
+
+/** Test some more seeks towards the start of a DCP with awkward subtitles */
+BOOST_AUTO_TEST_CASE (player_seek_test2)
+{
+ shared_ptr<Film> film (new Film (optional<boost::filesystem::path>()));
+ shared_ptr<DCPContent> dcp (new DCPContent (film, private_data / "awkward_subs2"));
+ film->examine_and_add_content (dcp, true);
+ BOOST_REQUIRE (!wait_for_jobs ());
+ dcp->subtitle->set_use (true);
+
+ shared_ptr<Player> player (new Player (film, film->playlist()));
+ player->set_fast ();
+ player->set_always_burn_subtitles (true);
+ player->set_play_referenced ();
+
+ shared_ptr<Butler> butler (new Butler (player, film->log(), AudioMapping(), 2));
+ butler->disable_audio();
+
+ butler->seek(DCPTime::from_seconds(5), true);
+
+ for (int i = 0; i < 10; ++i) {
+ DCPTime t = DCPTime::from_seconds(5) + DCPTime::from_frames (i, 24);
+ butler->seek (t, true);
+ pair<shared_ptr<PlayerVideo>, DCPTime> video = butler->get_video();
+ BOOST_CHECK_EQUAL(video.second.get(), t.get());
+ write_image(video.first->image(note_handler, PlayerVideo::always_rgb, false, true), String::compose("build/test/player_seek_test2_%1.png", i), "RGB");
+ check_image(String::compose("test/data/player_seek_test2_%1.png", i), String::compose("build/test/player_seek_test2_%1.png", i));
+ }
+}