+ BOOST_CHECK (!wait_for_jobs ());
+ d->add_kdm (kdm);
+ JobManager::instance()->add (make_shared<ExamineContentJob>(B, d));
+ BOOST_CHECK (!wait_for_jobs ());
+
+ make_and_verify_dcp (B);
+
+ /* Should be 1s red, 1s green, 1s blue */
+ check_dcp ("test/data/import_dcp_test2", "build/test/import_dcp_test2/" + B->dcp_name());
+}
+
+
+/** Check that DCP markers are imported correctly */
+BOOST_AUTO_TEST_CASE (import_dcp_markers_test)
+{
+ Cleanup cl;
+
+ /* Make a DCP with some markers */
+ auto content = content_factory("test/data/flat_red.png");
+ auto film = new_test_film2 ("import_dcp_markers_test", content, &cl);
+
+ content[0]->video->set_length (24 * 60 * 10);
+
+ film->set_marker(dcp::Marker::FFOC, dcpomatic::DCPTime::from_frames(1, 24));
+ film->set_marker(dcp::Marker::FFMC, dcpomatic::DCPTime::from_seconds(9.4));
+ film->set_marker(dcp::Marker::LFMC, dcpomatic::DCPTime::from_seconds(9.99));
+
+ make_and_verify_dcp (film);
+
+ /* Import the DCP to a new film and check the markers */
+ auto imported = make_shared<DCPContent>(film->dir(film->dcp_name()));
+ auto film2 = new_test_film2 ("import_dcp_markers_test2", {imported}, &cl);
+ film2->write_metadata ();
+
+ /* When import_dcp_markers_test was made a LFOC marker will automatically
+ * have been added.
+ */
+ BOOST_CHECK_EQUAL (imported->markers().size(), 4U);
+
+ auto markers = imported->markers();
+ BOOST_REQUIRE(markers.find(dcp::Marker::FFMC) != markers.end());
+ BOOST_CHECK(markers[dcp::Marker::FFMC] == dcpomatic::ContentTime(904000));
+ BOOST_REQUIRE(markers.find(dcp::Marker::LFMC) != markers.end());
+ BOOST_CHECK(markers[dcp::Marker::LFMC] == dcpomatic::ContentTime(960000));
+
+ /* Load that film and check that the markers have been loaded */
+ auto film3 = make_shared<Film>(boost::filesystem::path("build/test/import_dcp_markers_test2"));
+ film3->read_metadata ();
+ BOOST_REQUIRE_EQUAL (film3->content().size(), 1U);
+ auto reloaded = dynamic_pointer_cast<DCPContent>(film3->content().front());
+ BOOST_REQUIRE (reloaded);
+
+ BOOST_CHECK_EQUAL (reloaded->markers().size(), 4U);