X-Git-Url: https://git.carlh.net/gitweb/?p=dcpomatic.git;a=blobdiff_plain;f=test%2Frecover_test.cc;h=b36dad05a5e9390ef3c394a8b3260a6aea559e3e;hp=4222426c3ce9341d6e92bf58e363bedf3705b68c;hb=6d686ea45f5cd01a0d11f92a903ac77779ad8562;hpb=736597f0fc1b085911ecb5a4595368e7dc9a9bd5 diff --git a/test/recover_test.cc b/test/recover_test.cc index 4222426c3..b36dad05a 100644 --- a/test/recover_test.cc +++ b/test/recover_test.cc @@ -1,5 +1,5 @@ /* - Copyright (C) 2014-2015 Carl Hetherington + Copyright (C) 2014-2021 Carl Hetherington This file is part of DCP-o-matic. @@ -18,11 +18,13 @@ */ + /** @file test/recover_test.cc * @brief Test recovery of a DCP transcode after a crash. - * @ingroup specific + * @ingroup feature */ + #include "test.h" #include "lib/film.h" #include "lib/dcp_content_type.h" @@ -35,18 +37,25 @@ #include #include + using std::cout; +using std::make_shared; +using std::shared_ptr; using std::string; -using boost::shared_ptr; +#if BOOST_VERSION >= 106100 +using namespace boost::placeholders; +#endif + static void note (dcp::NoteType t, string n) { - if (t == dcp::DCP_ERROR) { + if (t == dcp::NoteType::ERROR) { cout << n << "\n"; } } + BOOST_AUTO_TEST_CASE (recover_test_2d) { shared_ptr film = new_test_film ("recover_test_2d"); @@ -55,14 +64,18 @@ BOOST_AUTO_TEST_CASE (recover_test_2d) film->set_container (Ratio::from_id ("185")); film->set_name ("recover_test"); - shared_ptr content (new FFmpegContent (film, "test/data/count300bd24.m2ts")); + shared_ptr content (new FFmpegContent("test/data/count300bd24.m2ts")); film->examine_and_add_content (content); - wait_for_jobs (); + BOOST_REQUIRE (!wait_for_jobs()); - film->make_dcp (); - wait_for_jobs (); + make_and_verify_dcp ( + film, + { + dcp::VerificationNote::Code::MISSING_FFMC_IN_FEATURE, + dcp::VerificationNote::Code::MISSING_FFEC_IN_FEATURE + }); - boost::filesystem::path const video = "build/test/recover_test_2d/video/185_2K_84d36460538435d5d511ee533c8528df_24_100000000_P_S_0_1200000.mxf"; + boost::filesystem::path const video = "build/test/recover_test_2d/video/185_2K_02543352c540f4b083bff3f1e309d4a9_24_100000000_P_S_0_1200000.mxf"; boost::filesystem::copy_file ( video, "build/test/recover_test_2d/original.mxf" @@ -70,8 +83,7 @@ BOOST_AUTO_TEST_CASE (recover_test_2d) boost::filesystem::resize_file (video, 2 * 1024 * 1024); - film->make_dcp (); - wait_for_jobs (); + make_and_verify_dcp (film, { dcp::VerificationNote::Code::MISSING_FFEC_IN_FEATURE, dcp::VerificationNote::Code::MISSING_FFMC_IN_FEATURE }); shared_ptr A (new dcp::MonoPictureAsset ("build/test/recover_test_2d/original.mxf")); shared_ptr B (new dcp::MonoPictureAsset (video)); @@ -80,24 +92,24 @@ BOOST_AUTO_TEST_CASE (recover_test_2d) BOOST_CHECK (A->equals (B, eq, boost::bind (¬e, _1, _2))); } -BOOST_AUTO_TEST_CASE (recover_test_3d) + +BOOST_AUTO_TEST_CASE (recover_test_3d, * boost::unit_test::depends_on("recover_test_2d")) { - shared_ptr film = new_test_film ("recover_test_3d"); + auto film = new_test_film ("recover_test_3d"); film->set_interop (false); film->set_dcp_content_type (DCPContentType::from_isdcf_name ("FTR")); film->set_container (Ratio::from_id ("185")); film->set_name ("recover_test"); film->set_three_d (true); - shared_ptr content (new ImageContent (film, "test/data/3d_test")); - content->video->set_frame_type (VIDEO_FRAME_TYPE_3D_LEFT_RIGHT); + auto content = make_shared("test/data/3d_test"); + content->video->set_frame_type (VideoFrameType::THREE_D_LEFT_RIGHT); film->examine_and_add_content (content); - wait_for_jobs (); + BOOST_REQUIRE (!wait_for_jobs()); - film->make_dcp (); - wait_for_jobs (); + make_and_verify_dcp (film, { dcp::VerificationNote::Code::MISSING_FFEC_IN_FEATURE, dcp::VerificationNote::Code::MISSING_FFMC_IN_FEATURE }); - boost::filesystem::path const video = "build/test/recover_test_3d/video/185_2K_961f053444e90c5ddbf978eb0ebfa772_24_100000000_P_S_3D_0_96000.mxf"; + boost::filesystem::path const video = "build/test/recover_test_3d/video/185_2K_70e6661af92ae94458784c16a21a9748_24_100000000_P_S_3D_0_96000.mxf"; boost::filesystem::copy_file ( video, @@ -106,35 +118,34 @@ BOOST_AUTO_TEST_CASE (recover_test_3d) boost::filesystem::resize_file (video, 2 * 1024 * 1024); - film->make_dcp (); - wait_for_jobs (); + make_and_verify_dcp (film, { dcp::VerificationNote::Code::MISSING_FFEC_IN_FEATURE, dcp::VerificationNote::Code::MISSING_FFMC_IN_FEATURE }); - shared_ptr A (new dcp::StereoPictureAsset ("build/test/recover_test_3d/original.mxf")); - shared_ptr B (new dcp::StereoPictureAsset (video)); + auto A = make_shared("build/test/recover_test_3d/original.mxf"); + auto B = make_shared(video); dcp::EqualityOptions eq; BOOST_CHECK (A->equals (B, eq, boost::bind (¬e, _1, _2))); } -BOOST_AUTO_TEST_CASE (recover_test_2d_encrypted) +BOOST_AUTO_TEST_CASE (recover_test_2d_encrypted, * boost::unit_test::depends_on("recover_test_3d")) { - shared_ptr film = new_test_film ("recover_test_2d_encrypted"); + auto film = new_test_film ("recover_test_2d_encrypted"); film->set_interop (false); film->set_dcp_content_type (DCPContentType::from_isdcf_name ("FTR")); film->set_container (Ratio::from_id ("185")); film->set_name ("recover_test"); film->set_encrypted (true); + film->_key = dcp::Key("eafcb91c9f5472edf01f3a2404c57258"); - shared_ptr content (new FFmpegContent (film, "test/data/count300bd24.m2ts")); + auto content = make_shared("test/data/count300bd24.m2ts"); film->examine_and_add_content (content); - wait_for_jobs (); + BOOST_REQUIRE (!wait_for_jobs()); - film->make_dcp (); - wait_for_jobs (); + make_and_verify_dcp (film, { dcp::VerificationNote::Code::MISSING_FFEC_IN_FEATURE, dcp::VerificationNote::Code::MISSING_FFMC_IN_FEATURE }); boost::filesystem::path const video = - "build/test/recover_test_2d_encrypted/video/185_2K_84d36460538435d5d511ee533c8528df_24_100000000_E_S_0_1200000.mxf"; + "build/test/recover_test_2d_encrypted/video/185_2K_02543352c540f4b083bff3f1e309d4a9_24_100000000_Eeafcb91c9f5472edf01f3a2404c57258_S_0_1200000.mxf"; boost::filesystem::copy_file ( video, @@ -143,12 +154,11 @@ BOOST_AUTO_TEST_CASE (recover_test_2d_encrypted) boost::filesystem::resize_file (video, 2 * 1024 * 1024); - film->make_dcp (); - wait_for_jobs (); + make_and_verify_dcp (film, { dcp::VerificationNote::Code::MISSING_FFEC_IN_FEATURE, dcp::VerificationNote::Code::MISSING_FFMC_IN_FEATURE }); - shared_ptr A (new dcp::MonoPictureAsset ("build/test/recover_test_2d_encrypted/original.mxf")); + auto A = make_shared("build/test/recover_test_2d_encrypted/original.mxf"); A->set_key (film->key ()); - shared_ptr B (new dcp::MonoPictureAsset (video)); + auto B = make_shared(video); B->set_key (film->key ()); dcp::EqualityOptions eq;