Missing library from test link list.
[dcpomatic.git] / test / import_dcp_test.cc
index b3f5285280143b61f9c295279227dff1938c20e7..83dd0c6de043b8b35803e6b65987e3d1109fae38 100644 (file)
@@ -1,34 +1,50 @@
 /*
-    Copyright (C) 2014 Carl Hetherington <cth@carlh.net>
+    Copyright (C) 2014-2020 Carl Hetherington <cth@carlh.net>
 
-    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 <http://www.gnu.org/licenses/>.
 
 */
 
-#include <boost/test/unit_test.hpp>
-#include <dcp/cpl.h>
+/** @file  test/import_dcp_test.cc
+ *  @brief Test import of encrypted DCPs.
+ *  @ingroup specific
+ */
+
+#include "test.h"
 #include "lib/film.h"
+#include "lib/screen.h"
 #include "lib/dcp_subtitle_content.h"
 #include "lib/ratio.h"
 #include "lib/dcp_content_type.h"
 #include "lib/dcp_content.h"
 #include "lib/ffmpeg_content.h"
+#include "lib/examine_content_job.h"
+#include "lib/job_manager.h"
 #include "lib/config.h"
-#include "test.h"
+#include "lib/cross.h"
+#include "lib/video_content.h"
+#include "lib/content_factory.h"
+#include <dcp/cpl.h>
+#include <boost/test/unit_test.hpp>
 
+using std::vector;
+using std::string;
+using std::map;
 using boost::shared_ptr;
+using boost::dynamic_pointer_cast;
 
 /** Make an encrypted DCP, import it and make a new unencrypted DCP */
 BOOST_AUTO_TEST_CASE (import_dcp_test)
@@ -37,36 +53,146 @@ BOOST_AUTO_TEST_CASE (import_dcp_test)
        A->set_container (Ratio::from_id ("185"));
        A->set_dcp_content_type (DCPContentType::from_isdcf_name ("TLR"));
        A->set_name ("frobozz");
+       A->set_interop (false);
 
-       shared_ptr<FFmpegContent> c (new FFmpegContent (A, "test/data/test.mp4"));
+       shared_ptr<FFmpegContent> c (new FFmpegContent("test/data/test.mp4"));
        A->examine_and_add_content (c);
        A->set_encrypted (true);
-       wait_for_jobs ();
+       BOOST_CHECK (!wait_for_jobs ());
 
        A->make_dcp ();
-       wait_for_jobs ();
+       BOOST_CHECK (!wait_for_jobs ());
 
        dcp::DCP A_dcp ("build/test/import_dcp_test/" + A->dcp_name());
        A_dcp.read ();
 
+       Config::instance()->set_decryption_chain (shared_ptr<dcp::CertificateChain> (new dcp::CertificateChain (openssl_path ())));
+
+       /* Dear future-carl: I suck!  I thought you wouldn't still be running these tests in 2030!  Sorry! */
        dcp::EncryptedKDM kdm = A->make_kdm (
-               Config::instance()->decryption_certificate(),
-               A_dcp.cpls().front()->file (),
-               dcp::LocalTime ("2014-07-21T00:00:00+00:00"),
-               dcp::LocalTime ("2024-07-21T00:00:00+00:00"),
-               dcp::MODIFIED_TRANSITIONAL_1
+               Config::instance()->decryption_chain()->leaf (),
+               vector<string>(),
+               A_dcp.cpls().front()->file().get(),
+               dcp::LocalTime ("2030-07-21T00:00:00+00:00"),
+               dcp::LocalTime ("2031-07-21T00:00:00+00:00"),
+               dcp::MODIFIED_TRANSITIONAL_1,
+               true, 0
                );
 
        shared_ptr<Film> B = new_test_film ("import_dcp_test2");
        B->set_container (Ratio::from_id ("185"));
        B->set_dcp_content_type (DCPContentType::from_isdcf_name ("TLR"));
        B->set_name ("frobozz");
+       B->set_interop (false);
 
-       shared_ptr<DCPContent> d (new DCPContent (B, "build/test/import_dcp_test/" + A->dcp_name()));
-       d->add_kdm (kdm);
+       shared_ptr<DCPContent> d (new DCPContent("build/test/import_dcp_test/" + A->dcp_name()));
        B->examine_and_add_content (d);
-       wait_for_jobs ();
+       BOOST_CHECK (!wait_for_jobs ());
+       d->add_kdm (kdm);
+       JobManager::instance()->add (shared_ptr<Job> (new ExamineContentJob (B, d)));
+       BOOST_CHECK (!wait_for_jobs ());
 
        B->make_dcp ();
-       wait_for_jobs ();
+       BOOST_CHECK (!wait_for_jobs ());
+
+       /* Should be 1s red, 1s green, 1s blue */
+       check_dcp ("test/data/import_dcp_test2", "build/test/import_dcp_test2/" + B->dcp_name());
+}
+
+
+/** Check that DCP markers are imported correctly */
+BOOST_AUTO_TEST_CASE (import_dcp_markers_test)
+{
+       /* Make a DCP with some markers */
+       shared_ptr<Film> film = new_test_film2 ("import_dcp_markers_test");
+       shared_ptr<Content> content = content_factory("test/data/flat_red.png").front();
+       film->examine_and_add_content (content);
+       BOOST_REQUIRE (!wait_for_jobs());
+
+       content->video->set_length (24 * 60 * 10);
+
+       film->set_marker(dcp::FFOC, dcpomatic::DCPTime::from_seconds(1.91));
+       film->set_marker(dcp::FFMC, dcpomatic::DCPTime::from_seconds(9.4));
+       film->set_marker(dcp::LFMC, dcpomatic::DCPTime::from_seconds(9.99));
+
+       film->make_dcp ();
+       BOOST_REQUIRE (!wait_for_jobs());
+
+       /* Import the DCP to a new film and check the markers */
+       shared_ptr<Film> film2 = new_test_film2 ("import_dcp_markers_test2");
+       shared_ptr<DCPContent> imported (new DCPContent(film->dir(film->dcp_name())));
+       film2->examine_and_add_content (imported);
+       BOOST_REQUIRE (!wait_for_jobs());
+       film2->write_metadata ();
+
+       BOOST_CHECK_EQUAL (imported->markers().size(), 3);
+
+       map<dcp::Marker, dcpomatic::ContentTime> markers = imported->markers();
+       BOOST_REQUIRE(markers.find(dcp::FFOC) != markers.end());
+       BOOST_CHECK(markers[dcp::FFOC] == dcpomatic::ContentTime(184000));
+       BOOST_REQUIRE(markers.find(dcp::FFMC) != markers.end());
+       BOOST_CHECK(markers[dcp::FFMC] == dcpomatic::ContentTime(904000));
+       BOOST_REQUIRE(markers.find(dcp::LFMC) != markers.end());
+       BOOST_CHECK(markers[dcp::LFMC] == dcpomatic::ContentTime(960000));
+
+       /* Load that film and check that the markers have been loaded */
+       shared_ptr<Film> film3(new Film(boost::filesystem::path("build/test/import_dcp_markers_test2")));
+       film3->read_metadata ();
+       BOOST_REQUIRE (film3->content().size() == 1);
+       shared_ptr<DCPContent> reloaded = dynamic_pointer_cast<DCPContent>(film3->content().front());
+       BOOST_REQUIRE (reloaded);
+
+       BOOST_CHECK_EQUAL (reloaded->markers().size(), 3);
+
+       markers = reloaded->markers();
+       BOOST_REQUIRE(markers.find(dcp::FFOC) != markers.end());
+       BOOST_CHECK(markers[dcp::FFOC] == dcpomatic::ContentTime(184000));
+       BOOST_REQUIRE(markers.find(dcp::FFMC) != markers.end());
+       BOOST_CHECK(markers[dcp::FFMC] == dcpomatic::ContentTime(904000));
+       BOOST_REQUIRE(markers.find(dcp::LFMC) != markers.end());
+       BOOST_CHECK(markers[dcp::LFMC] == dcpomatic::ContentTime(960000));
 }
+
+
+/** Check that DCP metadata (ratings and content version) are imported correctly */
+BOOST_AUTO_TEST_CASE (import_dcp_metadata_test)
+{
+       /* Make a DCP with some ratings and a content version */
+       shared_ptr<Film> film = new_test_film2 ("import_dcp_metadata_test");
+       shared_ptr<Content> content = content_factory("test/data/flat_red.png").front();
+       film->examine_and_add_content (content);
+       BOOST_REQUIRE (!wait_for_jobs());
+
+       content->video->set_length (10);
+
+       std::vector<dcp::Rating> ratings;
+       ratings.push_back (dcp::Rating("BBFC", "15"));
+       ratings.push_back (dcp::Rating("MPAA", "NC-17"));
+       film->set_ratings (ratings);
+
+       film->set_content_version ("Fred");
+
+       film->make_dcp ();
+       BOOST_REQUIRE (!wait_for_jobs());
+
+       /* Import the DCP to a new film and check the metadata */
+       shared_ptr<Film> film2 = new_test_film2 ("import_dcp_metadata_test2");
+       shared_ptr<DCPContent> imported (new DCPContent(film->dir(film->dcp_name())));
+       film2->examine_and_add_content (imported);
+       BOOST_REQUIRE (!wait_for_jobs());
+       film2->write_metadata ();
+
+       BOOST_CHECK (imported->ratings() == ratings);
+       BOOST_CHECK_EQUAL (imported->content_version(), "Fred");
+
+       /* Load that film and check that the metadata has been loaded */
+       shared_ptr<Film> film3(new Film(boost::filesystem::path("build/test/import_dcp_metadata_test2")));
+       film3->read_metadata ();
+       BOOST_REQUIRE (film3->content().size() == 1);
+       shared_ptr<DCPContent> reloaded = dynamic_pointer_cast<DCPContent>(film3->content().front());
+       BOOST_REQUIRE (reloaded);
+
+       BOOST_CHECK (reloaded->ratings() == ratings);
+       BOOST_CHECK_EQUAL (reloaded->content_version(), "Fred");
+}
+