X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=test%2Fdcp_subtitle_test.cc;h=34059a680bba3f0a0892592828333751f2f9afd7;hb=a26b6e9e392a1ac342a19e0d33d92865819c6ded;hp=7e13b1c1a461d1698f70f74022eb465a69672583;hpb=6f344b876689a1234a5eb75041882f06f5d9fe5c;p=dcpomatic.git diff --git a/test/dcp_subtitle_test.cc b/test/dcp_subtitle_test.cc index 7e13b1c1a..34059a680 100644 --- a/test/dcp_subtitle_test.cc +++ b/test/dcp_subtitle_test.cc @@ -1,19 +1,20 @@ /* - Copyright (C) 2014 Carl Hetherington + Copyright (C) 2014-2016 Carl Hetherington - This program is free software; you can redistribute it and/or modify + This file is part of DCP-o-matic. + + DCP-o-matic is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. - This program is distributed in the hope that it will be useful, + DCP-o-matic is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License - along with this program; if not, write to the Free Software - Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. + along with DCP-o-matic. If not, see . */ @@ -28,6 +29,10 @@ #include "lib/ratio.h" #include "lib/dcp_decoder.h" #include "lib/dcp_content_type.h" +#include "lib/dcp_subtitle_decoder.h" +#include "lib/subtitle_content.h" +#include "lib/content_subtitle.h" +#include "lib/subtitle_decoder.h" #include "test.h" #include @@ -46,10 +51,10 @@ BOOST_AUTO_TEST_CASE (dcp_subtitle_test) film->examine_and_add_content (content); wait_for_jobs (); - BOOST_CHECK_EQUAL (content->full_length(), DCPTime::from_seconds (2)); + BOOST_CHECK_EQUAL (content->full_length().get(), DCPTime::from_seconds(2).get()); - content->set_use_subtitles (true); - content->set_burn_subtitles (false); + content->subtitle->set_use (true); + content->subtitle->set_burn (false); film->make_dcp (); wait_for_jobs (); @@ -67,7 +72,7 @@ BOOST_AUTO_TEST_CASE (dcp_subtitle_within_dcp_test) film->examine_and_add_content (content); wait_for_jobs (); - shared_ptr decoder (new DCPDecoder (content, film->log(), false)); + shared_ptr decoder (new DCPDecoder (content, film->log())); list ctp = decoder->text_subtitles_during ( ContentTimePeriod ( @@ -78,12 +83,12 @@ BOOST_AUTO_TEST_CASE (dcp_subtitle_within_dcp_test) ); BOOST_REQUIRE_EQUAL (ctp.size(), 2); - BOOST_CHECK_EQUAL (ctp.front().from, ContentTime::from_seconds (25 + 12 * 0.04)); - BOOST_CHECK_EQUAL (ctp.front().to, ContentTime::from_seconds (26 + 4 * 0.04)); - BOOST_CHECK_EQUAL (ctp.back().from, ContentTime::from_seconds (25 + 12 * 0.04)); - BOOST_CHECK_EQUAL (ctp.back().to, ContentTime::from_seconds (26 + 4 * 0.04)); + BOOST_CHECK_EQUAL (ctp.front().from.get(), ContentTime::from_seconds(25 + 12 * 0.04).get()); + BOOST_CHECK_EQUAL (ctp.front().to.get(), ContentTime::from_seconds(26 + 4 * 0.04).get()); + BOOST_CHECK_EQUAL (ctp.back().from.get(), ContentTime::from_seconds(25 + 12 * 0.04).get()); + BOOST_CHECK_EQUAL (ctp.back().to.get(), ContentTime::from_seconds(26 + 4 * 0.04).get()); - list subs = decoder->get_text_subtitles ( + list subs = decoder->subtitle->get_text ( ContentTimePeriod ( ContentTime::from_seconds (25), ContentTime::from_seconds (26) @@ -97,3 +102,23 @@ BOOST_AUTO_TEST_CASE (dcp_subtitle_within_dcp_test) BOOST_CHECK_EQUAL (subs.front().subs.front().text(), "Noch mal."); BOOST_CHECK_EQUAL (subs.front().subs.back().text(), "Encore une fois."); } + +/** Test subtitles whose text includes things like <b> */ +BOOST_AUTO_TEST_CASE (dcp_subtitle_test2) +{ + shared_ptr film = new_test_film ("dcp_subtitle_test2"); + film->set_container (Ratio::from_id ("185")); + film->set_dcp_content_type (DCPContentType::from_isdcf_name ("TLR")); + film->set_name ("frobozz"); + shared_ptr content (new DCPSubtitleContent (film, "test/data/dcp_sub2.xml")); + film->examine_and_add_content (content); + wait_for_jobs (); + + shared_ptr decoder (new DCPSubtitleDecoder (content)); + list 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(), 1); + BOOST_CHECK_EQUAL (sub.front().subs.front().text(), "<b>Hello world!</b>"); +}