2 Copyright (C) 2020-2021 Carl Hetherington <cth@carlh.net>
4 This file is part of DCP-o-matic.
6 DCP-o-matic is free software; you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation; either version 2 of the License, or
9 (at your option) any later version.
11 DCP-o-matic is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 GNU General Public License for more details.
16 You should have received a copy of the GNU General Public License
17 along with DCP-o-matic. If not, see <http://www.gnu.org/licenses/>.
22 /** @file test/markers_test
23 * @brief Test SMPTE markers.
28 #include "lib/content_factory.h"
33 #include <dcp/reel_markers_asset.h>
35 #include <boost/test/unit_test.hpp>
39 using boost::optional;
42 /** Check that FFOC and LFOC are automatically added if not specified */
43 BOOST_AUTO_TEST_CASE (automatic_ffoc_lfoc_markers_test1)
45 string const name = "automatic_ffoc_lfoc_markers_test1";
46 auto film = new_test_film2 (name);
47 film->examine_and_add_content (content_factory("test/data/flat_red.png")[0]);
48 BOOST_REQUIRE (!wait_for_jobs());
50 film->set_interop (false);
51 make_and_verify_dcp (film);
53 dcp::DCP dcp (String::compose("build/test/%1/%2", name, film->dcp_name()));
55 BOOST_REQUIRE_EQUAL (dcp.cpls().size(), 1U);
56 auto cpl = dcp.cpls().front();
57 BOOST_REQUIRE_EQUAL (cpl->reels().size(), 1U);
58 auto reel = cpl->reels()[0];
59 auto markers = reel->main_markers();
60 BOOST_REQUIRE (markers);
62 auto ffoc = markers->get (dcp::Marker::FFOC);
64 BOOST_CHECK (*ffoc == dcp::Time(0, 0, 0, 1, 24));
65 auto lfoc = markers->get (dcp::Marker::LFOC);
67 BOOST_CHECK (*lfoc == dcp::Time(0, 0, 9, 23, 24));
71 /** Check that FFOC and LFOC are not overridden if they are specified */
72 BOOST_AUTO_TEST_CASE (automatic_ffoc_lfoc_markers_test2)
74 string const name = "automatic_ffoc_lfoc_markers_test2";
75 auto film = new_test_film2 (name);
76 film->examine_and_add_content (content_factory("test/data/flat_red.png")[0]);
77 BOOST_REQUIRE (!wait_for_jobs());
79 film->set_interop (false);
80 film->set_marker (dcp::Marker::FFOC, dcpomatic::DCPTime::from_seconds(1));
81 film->set_marker (dcp::Marker::LFOC, dcpomatic::DCPTime::from_seconds(9));
85 dcp::VerificationNote::Code::INCORRECT_FFOC,
86 dcp::VerificationNote::Code::INCORRECT_LFOC
89 dcp::DCP dcp (String::compose("build/test/%1/%2", name, film->dcp_name()));
91 BOOST_REQUIRE_EQUAL (dcp.cpls().size(), 1U);
92 auto cpl = dcp.cpls().front();
93 BOOST_REQUIRE_EQUAL (cpl->reels().size(), 1U);
94 auto reel = cpl->reels()[0];
95 auto markers = reel->main_markers();
96 BOOST_REQUIRE (markers);
98 auto ffoc = markers->get (dcp::Marker::FFOC);
100 BOOST_CHECK (*ffoc == dcp::Time (0, 0, 1, 0, 24));
101 auto lfoc = markers->get (dcp::Marker::LFOC);
102 BOOST_REQUIRE (lfoc);
103 BOOST_CHECK (*lfoc == dcp::Time(0, 0, 9, 0, 24));
108 BOOST_AUTO_TEST_CASE(markers_correct_with_reels)
110 string const name = "markers_correct_with_reels";
111 auto content1 = content_factory("test/data/flat_red.png")[0];
112 auto content2 = content_factory("test/data/flat_red.png")[0];
113 auto film = new_test_film2(name, { content1, content2});
115 film->set_interop(false);
116 film->set_reel_type(ReelType::BY_VIDEO_CONTENT);
117 make_and_verify_dcp(film);
119 dcp::DCP dcp(String::compose("build/test/%1/%2", name, film->dcp_name()));
121 BOOST_REQUIRE_EQUAL(dcp.cpls().size(), 1U);
122 auto cpl = dcp.cpls()[0];
123 BOOST_REQUIRE_EQUAL(cpl->reels().size(), 2U);
125 auto markers1 = cpl->reels()[0]->main_markers();
126 BOOST_REQUIRE(markers1);
127 auto ffoc = markers1->get(dcp::Marker::FFOC);
129 BOOST_CHECK(*ffoc == dcp::Time(0, 0, 0, 1, 24));
130 auto no_lfoc = markers1->get(dcp::Marker::LFOC);
131 BOOST_CHECK(!no_lfoc);
133 auto markers2 = cpl->reels()[1]->main_markers();
134 BOOST_REQUIRE(markers2);
135 auto no_ffoc = markers2->get(dcp::Marker::FFOC);
136 BOOST_REQUIRE(!no_ffoc);
137 auto lfoc = markers2->get(dcp::Marker::LFOC);
139 BOOST_CHECK(*lfoc == dcp::Time(0, 0, 9, 23, 24));