X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=test%2Frecover_test.cc;h=5d86fb9277d18909a023e6b00c9b4f6ad32589cc;hb=0758d834992f0adb8aa8d4d9908a64ce8708f05c;hp=92eae27eb9e8cf4ce734cea3878f0f0de8464327;hpb=8c7a308c03e4b4196b4e2379a26d432b100ae2b1;p=dcpomatic.git diff --git a/test/recover_test.cc b/test/recover_test.cc index 92eae27eb..5d86fb927 100644 --- a/test/recover_test.cc +++ b/test/recover_test.cc @@ -1,5 +1,5 @@ /* - Copyright (C) 2014 Carl Hetherington + Copyright (C) 2014-2015 Carl Hetherington This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -21,13 +21,17 @@ * @brief Test recovery of a DCP transcode after a crash. */ -#include -#include +#include "test.h" #include "lib/film.h" #include "lib/dcp_content_type.h" #include "lib/image_content.h" +#include "lib/ffmpeg_content.h" +#include "lib/video_content.h" #include "lib/ratio.h" -#include "test.h" +#include +#include +#include +#include using std::cout; using std::string; @@ -41,38 +45,70 @@ note (dcp::NoteType t, string n) } } -BOOST_AUTO_TEST_CASE (recover_test) +BOOST_AUTO_TEST_CASE (recover_test_2d) { - shared_ptr film = new_test_film ("recover_test"); + shared_ptr film = new_test_film ("recover_test_2d"); + 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")); + film->examine_and_add_content (content); + wait_for_jobs (); + + film->make_dcp (); + wait_for_jobs (); + + boost::filesystem::path const video = "build/test/recover_test_2d/video/185_2K_d2b23c22cff43b0247c7108dcd32323c_24_100000000_P_S_0_1200000.mxf"; + + boost::filesystem::copy_file ( + video, + "build/test/recover_test_2d/original.mxf" + ); + + boost::filesystem::resize_file (video, 2 * 1024 * 1024); + + film->make_dcp (); + wait_for_jobs (); + + shared_ptr A (new dcp::MonoPictureAsset ("build/test/recover_test_2d/original.mxf")); + shared_ptr B (new dcp::MonoPictureAsset (video)); + + dcp::EqualityOptions eq; + BOOST_CHECK (A->equals (B, eq, boost::bind (¬e, _1, _2))); +} + +BOOST_AUTO_TEST_CASE (recover_test_3d) +{ + shared_ptr film = new_test_film ("recover_test_3d"); 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->set_video_frame_type (VIDEO_FRAME_TYPE_3D_LEFT_RIGHT); + content->video->set_frame_type (VIDEO_FRAME_TYPE_3D_LEFT_RIGHT); film->examine_and_add_content (content); wait_for_jobs (); film->make_dcp (); wait_for_jobs (); - boost::filesystem::path const video = "build/test/recover_test/video/185_2K_1133fd57e751ce3e82146492466365f9_24_bicubic_100000000_P_S_3D.mxf"; + boost::filesystem::path const video = "build/test/recover_test_3d/video/185_2K_961f053444e90c5ddbf978eb0ebfa772_24_100000000_P_S_3D_0_96000.mxf"; boost::filesystem::copy_file ( video, - "build/test/recover_test/original.mxf" + "build/test/recover_test_3d/original.mxf" ); - + boost::filesystem::resize_file (video, 2 * 1024 * 1024); film->make_dcp (); wait_for_jobs (); - shared_ptr A (new dcp::StereoPictureMXF ("build/test/recover_test/original.mxf")); - shared_ptr B (new dcp::StereoPictureMXF (video)); + shared_ptr A (new dcp::StereoPictureAsset ("build/test/recover_test_3d/original.mxf")); + shared_ptr B (new dcp::StereoPictureAsset (video)); dcp::EqualityOptions eq; - eq.mxf_names_can_differ = true; BOOST_CHECK (A->equals (B, eq, boost::bind (¬e, _1, _2))); }