Add new test for imported XML subtitles.
authorCarl Hetherington <cth@carlh.net>
Sun, 23 Oct 2016 22:00:56 +0000 (23:00 +0100)
committerCarl Hetherington <cth@carlh.net>
Sun, 23 Oct 2016 22:00:56 +0000 (23:00 +0100)
test/data
test/dcp_subtitle_test.cc

index 6966026bc74f121a681b24b04d69c97a196b1355..b0c5a330fcb42082ff4f22c245721f3f88f9d74f 160000 (submodule)
--- a/test/data
+++ b/test/data
@@ -1 +1 @@
-Subproject commit 6966026bc74f121a681b24b04d69c97a196b1355
+Subproject commit b0c5a330fcb42082ff4f22c245721f3f88f9d74f
index 34059a680bba3f0a0892592828333751f2f9afd7..643742a7f6b1f3f41c16c2d2b7e1d4cce6e9804d 100644 (file)
@@ -122,3 +122,37 @@ BOOST_AUTO_TEST_CASE (dcp_subtitle_test2)
        BOOST_REQUIRE_EQUAL (sub.front().subs.size(), 1);
        BOOST_CHECK_EQUAL (sub.front().subs.front().text(), "&lt;b&gt;Hello world!&lt;/b&gt;");
 }
+
+/** Test a failure case */
+BOOST_AUTO_TEST_CASE (dcp_subtitle_test3)
+{
+       shared_ptr<Film> film = new_test_film ("dcp_subtitle_test3");
+       film->set_container (Ratio::from_id ("185"));
+       film->set_dcp_content_type (DCPContentType::from_isdcf_name ("TLR"));
+       film->set_name ("frobozz");
+       film->set_interop (true);
+       shared_ptr<DCPSubtitleContent> content (new DCPSubtitleContent (film, "test/data/dcp_sub3.xml"));
+       film->examine_and_add_content (content);
+       wait_for_jobs ();
+
+       film->make_dcp ();
+       wait_for_jobs ();
+
+       shared_ptr<DCPSubtitleDecoder> decoder (new DCPSubtitleDecoder (content));
+       list<ContentTextSubtitle> sub = decoder->subtitle->get_text (
+               ContentTimePeriod (ContentTime::from_seconds(0), ContentTime::from_seconds(2)), true, true
+               );
+       BOOST_REQUIRE_EQUAL (sub.size(), 1);
+       BOOST_REQUIRE_EQUAL (sub.front().subs.size(), 3);
+       list<dcp::SubtitleString> s = sub.front().subs;
+       list<dcp::SubtitleString>::const_iterator i = s.begin ();
+       BOOST_CHECK_EQUAL (i->text(), "This");
+       ++i;
+       BOOST_REQUIRE (i != s.end ());
+       BOOST_CHECK_EQUAL (i->text(), " is ");
+       ++i;
+       BOOST_REQUIRE (i != s.end ());
+       BOOST_CHECK_EQUAL (i->text(), "wrong.");
+       ++i;
+       BOOST_REQUIRE (i == s.end ());
+}