X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=test%2Frecover_test.cc;h=e8194fd81735f6b9a418cf482e21ee4fce343ac6;hb=b1589146e73ad97d3f29e9d5cafe61e5424796a4;hp=dfd3f790f512d3fbaef9accd78ecbf5ad3afbdb9;hpb=9e7b4d64c4e9a9bcd0e08ede076162bb0ec666d1;p=dcpomatic.git diff --git a/test/recover_test.cc b/test/recover_test.cc index dfd3f790f..e8194fd81 100644 --- a/test/recover_test.cc +++ b/test/recover_test.cc @@ -20,6 +20,7 @@ /** @file test/recover_test.cc * @brief Test recovery of a DCP transcode after a crash. + * @ingroup specific */ #include "test.h" @@ -49,18 +50,19 @@ note (dcp::NoteType t, string n) BOOST_AUTO_TEST_CASE (recover_test_2d) { shared_ptr film = new_test_film ("recover_test_2d"); + 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"); - 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 (); + BOOST_REQUIRE (!wait_for_jobs()); - boost::filesystem::path const video = "build/test/recover_test_2d/video/185_2K_9284c41c42044ef9b4c14482730cdffe_24_100000000_P_S_0_1200000.mxf"; + boost::filesystem::path const video = "build/test/recover_test_2d/video/185_2K_d4343facdd66ca71f62a964fbade89f3_24_100000000_P_S_0_1200000.mxf"; boost::filesystem::copy_file ( video, "build/test/recover_test_2d/original.mxf" @@ -69,7 +71,7 @@ BOOST_AUTO_TEST_CASE (recover_test_2d) boost::filesystem::resize_file (video, 2 * 1024 * 1024); film->make_dcp (); - wait_for_jobs (); + BOOST_REQUIRE (!wait_for_jobs()); shared_ptr A (new dcp::MonoPictureAsset ("build/test/recover_test_2d/original.mxf")); shared_ptr B (new dcp::MonoPictureAsset (video)); @@ -78,69 +80,77 @@ BOOST_AUTO_TEST_CASE (recover_test_2d) 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_3d, * boost::unit_test::depends_on("recover_test_2d")) { - shared_ptr film = new_test_film ("recover_test_2d_encrypted"); + shared_ptr 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_encrypted (true); + film->set_three_d (true); - shared_ptr content (new FFmpegContent (film, "test/data/count300bd24.m2ts")); + shared_ptr content (new ImageContent("test/data/3d_test")); + content->video->set_frame_type (VIDEO_FRAME_TYPE_3D_LEFT_RIGHT); film->examine_and_add_content (content); - wait_for_jobs (); + BOOST_REQUIRE (!wait_for_jobs()); film->make_dcp (); - wait_for_jobs (); + BOOST_REQUIRE (!wait_for_jobs()); + + boost::filesystem::path const video = "build/test/recover_test_3d/video/185_2K_342fe9115d2b446914b31f7602e48cc6_24_100000000_P_S_3D_0_96000.mxf"; - boost::filesystem::path const video = "build/test/recover_test_2d_encrypted/video/185_2K_9284c41c42044ef9b4c14482730cdffe_24_100000000_P_S_0_1200000.mxf"; boost::filesystem::copy_file ( video, - "build/test/recover_test_2d_encrypted/original.mxf" + "build/test/recover_test_3d/original.mxf" ); boost::filesystem::resize_file (video, 2 * 1024 * 1024); film->make_dcp (); - wait_for_jobs (); + BOOST_REQUIRE (!wait_for_jobs()); - shared_ptr A (new dcp::MonoPictureAsset ("build/test/recover_test_2d_encrypted/original.mxf")); - shared_ptr B (new dcp::MonoPictureAsset (video)); + shared_ptr A (new dcp::StereoPictureAsset ("build/test/recover_test_3d/original.mxf")); + shared_ptr B (new dcp::StereoPictureAsset (video)); dcp::EqualityOptions eq; BOOST_CHECK (A->equals (B, eq, boost::bind (¬e, _1, _2))); } -BOOST_AUTO_TEST_CASE (recover_test_3d) + +BOOST_AUTO_TEST_CASE (recover_test_2d_encrypted, * boost::unit_test::depends_on("recover_test_3d")) { - shared_ptr film = new_test_film ("recover_test_3d"); + shared_ptr 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_three_d (true); + film->set_encrypted (true); + film->set_key (dcp::Key("eafcb91c9f5472edf01f3a2404c57258")); - shared_ptr content (new ImageContent (film, "test/data/3d_test")); - content->video->set_frame_type (VIDEO_FRAME_TYPE_3D_LEFT_RIGHT); + 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 (); + BOOST_REQUIRE (!wait_for_jobs()); - 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_2d_encrypted/video/185_2K_d4343facdd66ca71f62a964fbade89f3_24_100000000_Eeafcb91c9f5472edf01f3a2404c57258_S_0_1200000.mxf"; boost::filesystem::copy_file ( video, - "build/test/recover_test_3d/original.mxf" + "build/test/recover_test_2d_encrypted/original.mxf" ); boost::filesystem::resize_file (video, 2 * 1024 * 1024); film->make_dcp (); - wait_for_jobs (); + BOOST_REQUIRE (!wait_for_jobs()); - shared_ptr A (new dcp::StereoPictureAsset ("build/test/recover_test_3d/original.mxf")); - shared_ptr B (new dcp::StereoPictureAsset (video)); + shared_ptr A (new dcp::MonoPictureAsset ("build/test/recover_test_2d_encrypted/original.mxf")); + A->set_key (film->key ()); + shared_ptr B (new dcp::MonoPictureAsset (video)); + B->set_key (film->key ()); dcp::EqualityOptions eq; BOOST_CHECK (A->equals (B, eq, boost::bind (¬e, _1, _2)));