Fix --standard flag to dcpomatic2_cli (github #9).
[dcpomatic.git] / test / reel_writer_test.cc
index db63ca8bf0247668b5980574e24f2e27af52627d..6d87d5b7ef98b51ef10cb15b9d742c408fde45ab 100644 (file)
@@ -33,56 +33,58 @@ using std::string;
 using boost::shared_ptr;
 using boost::optional;
 
-static bool equal (dcp::FrameInfo a, ReelWriter const & writer, boost::filesystem::path file, Frame frame, Eyes eyes)
+static bool equal (dcp::FrameInfo a, ReelWriter const & writer, shared_ptr<InfoFileHandle> file, Frame frame, Eyes eyes)
 {
-       FILE* f = fopen_boost(file, "rb");
-       BOOST_REQUIRE (f);
-       dcp::FrameInfo b = writer.read_frame_info(f, frame, eyes);
-       bool const r = a.offset == b.offset && a.size == b.size && a.hash == b.hash;
-       fclose (f);
-       return r;
+       dcp::FrameInfo b = writer.read_frame_info(file, frame, eyes);
+       return a.offset == b.offset && a.size == b.size && a.hash == b.hash;
 }
 
 BOOST_AUTO_TEST_CASE (write_frame_info_test)
 {
        shared_ptr<Film> film = new_test_film2 ("write_frame_info_test");
-       dcpomatic::DCPTimePeriod const period (dcpomatic::DCPTime(0), dcpomatic::DCPTime(96000));
+       DCPTimePeriod const period (DCPTime(0), DCPTime(96000));
        ReelWriter writer (film, period, shared_ptr<Job>(), 0, 1, optional<string>());
 
        /* Write the first one */
 
-       boost::filesystem::path file = film->info_file (period);
-       BOOST_CHECK (!boost::filesystem::exists(file));
        dcp::FrameInfo info1(0, 123, "12345678901234567890123456789012");
        writer.write_frame_info (0, EYES_LEFT, info1);
-       BOOST_CHECK (boost::filesystem::exists(file));
 
-       BOOST_CHECK (equal(info1, writer, file, 0, EYES_LEFT));
+       {
+               shared_ptr<InfoFileHandle> file = film->info_file_handle(period, true);
+               BOOST_CHECK (equal(info1, writer, file, 0, EYES_LEFT));
+       }
 
        /* Write some more */
 
        dcp::FrameInfo info2(596, 14921, "123acb789f1234ae782012n456339522");
        writer.write_frame_info (5, EYES_RIGHT, info2);
-       BOOST_CHECK (boost::filesystem::exists(file));
 
-       BOOST_CHECK (equal(info1, writer, file, 0, EYES_LEFT));
-       BOOST_CHECK (equal(info2, writer, file, 5, EYES_RIGHT));
+       {
+               shared_ptr<InfoFileHandle> file = film->info_file_handle(period, true);
+               BOOST_CHECK (equal(info1, writer, file, 0, EYES_LEFT));
+               BOOST_CHECK (equal(info2, writer, file, 5, EYES_RIGHT));
+       }
 
        dcp::FrameInfo info3(12494, 99157123, "xxxxyyyyabc12356ffsfdsf456339522");
        writer.write_frame_info (10, EYES_LEFT, info3);
-       BOOST_CHECK (boost::filesystem::exists(file));
 
-       BOOST_CHECK (equal(info1, writer, file, 0, EYES_LEFT));
-       BOOST_CHECK (equal(info2, writer, file, 5, EYES_RIGHT));
-       BOOST_CHECK (equal(info3, writer, file, 10, EYES_LEFT));
+       {
+               shared_ptr<InfoFileHandle> file = film->info_file_handle(period, true);
+               BOOST_CHECK (equal(info1, writer, file, 0, EYES_LEFT));
+               BOOST_CHECK (equal(info2, writer, file, 5, EYES_RIGHT));
+               BOOST_CHECK (equal(info3, writer, file, 10, EYES_LEFT));
+       }
 
        /* Overwrite one */
 
        dcp::FrameInfo info4(55512494, 123599157123, "ABCDEFGyabc12356ffsfdsf4563395ZZ");
        writer.write_frame_info (5, EYES_RIGHT, info4);
-       BOOST_CHECK (boost::filesystem::exists(file));
 
-       BOOST_CHECK (equal(info1, writer, file, 0, EYES_LEFT));
-       BOOST_CHECK (equal(info4, writer, file, 5, EYES_RIGHT));
-       BOOST_CHECK (equal(info3, writer, file, 10, EYES_LEFT));
+       {
+               shared_ptr<InfoFileHandle> file = film->info_file_handle(period, true);
+               BOOST_CHECK (equal(info1, writer, file, 0, EYES_LEFT));
+               BOOST_CHECK (equal(info4, writer, file, 5, EYES_RIGHT));
+               BOOST_CHECK (equal(info3, writer, file, 10, EYES_LEFT));
+       }
 }