Verify a whole bunch of DCPs made by unit tests.
[dcpomatic.git] / test / ffmpeg_dcp_test.cc
index ea3b8d4f9d8ea2b0b81f6725bd6a9482d1cffd9a..0d56f4290fd1788db1e655773717e5274df96e71 100644 (file)
@@ -1,5 +1,5 @@
 /*
-    Copyright (C) 2012-2014 Carl Hetherington <cth@carlh.net>
+    Copyright (C) 2012-2021 Carl Hetherington <cth@carlh.net>
 
     This file is part of DCP-o-matic.
 
@@ -18,6 +18,7 @@
 
 */
 
+
 /** @file test/ffmpeg_dcp_test.cc
  *  @brief Test creation of a very simple DCP from some FFmpegContent (data/test.mp4).
  *  @ingroup feature
@@ -25,6 +26,7 @@
  *  Also a quick test of Film::have_dcp ().
  */
 
+
 #include <boost/test/unit_test.hpp>
 #include <boost/filesystem.hpp>
 #include <boost/algorithm/string.hpp>
 #include "lib/video_content.h"
 #include "test.h"
 
+
+using std::make_shared;
 using std::shared_ptr;
 
+
 BOOST_AUTO_TEST_CASE (ffmpeg_dcp_test)
 {
-       shared_ptr<Film> film = new_test_film ("ffmpeg_dcp_test");
+       auto film = new_test_film ("ffmpeg_dcp_test");
        film->set_name ("test_film2");
-       shared_ptr<FFmpegContent> c (new FFmpegContent("test/data/test.mp4"));
+       auto c = make_shared<FFmpegContent>("test/data/test.mp4");
        film->examine_and_add_content (c);
 
        BOOST_REQUIRE (!wait_for_jobs());
 
        film->set_container (Ratio::from_id ("185"));
        film->set_dcp_content_type (DCPContentType::from_isdcf_name ("TST"));
-       film->make_dcp ();
-       film->write_metadata ();
+       make_and_verify_dcp (film);
 
        BOOST_REQUIRE (!wait_for_jobs());
 }
 
-/** Briefly test Film::cpls().  Requires the output from ffmpeg_dcp_test above */
+
+/** Briefly test Film::cpls() */
 BOOST_AUTO_TEST_CASE (ffmpeg_have_dcp_test, * boost::unit_test::depends_on("ffmpeg_dcp_test"))
 {
-       boost::filesystem::path p = test_film_dir ("ffmpeg_dcp_test");
-       shared_ptr<Film> film (new Film (p));
+       auto p = test_film_dir ("ffmpeg_dcp_test");
+       auto film = make_shared<Film>(p);
        film->read_metadata ();
        BOOST_CHECK (!film->cpls().empty());
 
        p /= film->dcp_name();
-       boost::filesystem::directory_iterator i = boost::filesystem::directory_iterator (p);
+       auto i = boost::filesystem::directory_iterator (p);
        while (i != boost::filesystem::directory_iterator() && !boost::algorithm::starts_with (i->path().leaf().string(), "j2c")) {
                ++i;
        }