X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=test%2Ffilm_metadata_test.cc;h=5c44c2a91377204e5a19e2da91dc8ddc131507ad;hb=8987f133295e352c44e05ef338eacc801c61a629;hp=80ecf3881f793c094ff1da8a2d83ec29732e1069;hpb=f9ead014bdfaa7abd7dcea55650ae261e8323ec7;p=dcpomatic.git diff --git a/test/film_metadata_test.cc b/test/film_metadata_test.cc index 80ecf3881..5c44c2a91 100644 --- a/test/film_metadata_test.cc +++ b/test/film_metadata_test.cc @@ -32,6 +32,7 @@ #include "lib/film.h" #include "lib/ratio.h" #include "lib/text_content.h" +#include "lib/video_content.h" #include "test.h" #include #include @@ -107,8 +108,11 @@ BOOST_AUTO_TEST_CASE (multiple_text_nodes_are_allowed) BOOST_AUTO_TEST_CASE (metadata_loads_from_2_14_x_1) { namespace fs = boost::filesystem; - auto film = make_shared(fs::path("build/test/metadata_loads_from_2_14_x_1")); - auto notes = film->read_metadata(fs::path("test/data/2.14.x.metadata.1.xml")); + auto dir = fs::path("build/test/metadata_loads_from_2_14_x_1"); + fs::remove_all(dir); + auto film = make_shared(dir); + fs::copy_file("test/data/2.14.x.metadata.1.xml", dir / "metadata.xml"); + auto notes = film->read_metadata(dir / "metadata.xml"); BOOST_REQUIRE_EQUAL (notes.size(), 0U); } @@ -117,8 +121,11 @@ BOOST_AUTO_TEST_CASE (metadata_loads_from_2_14_x_1) BOOST_AUTO_TEST_CASE (metadata_loads_from_2_14_x_2) { namespace fs = boost::filesystem; - auto film = make_shared(fs::path("build/test/metadata_loads_from_2_14_x_2")); - auto notes = film->read_metadata(fs::path("test/data/2.14.x.metadata.2.xml")); + auto dir = fs::path("build/test/metadata_loads_from_2_14_x_2"); + fs::remove_all(dir); + auto film = make_shared(dir); + fs::copy_file("test/data/2.14.x.metadata.2.xml", dir / "metadata.xml"); + auto notes = film->read_metadata(dir / "metadata.xml"); BOOST_REQUIRE_EQUAL (notes.size(), 1U); BOOST_REQUIRE_EQUAL (notes.front(), "A subtitle or closed caption file in this project is marked with the language 'eng', " @@ -130,8 +137,11 @@ BOOST_AUTO_TEST_CASE (metadata_loads_from_2_14_x_2) BOOST_AUTO_TEST_CASE (metadata_loads_from_2_14_x_3) { namespace fs = boost::filesystem; - auto film = make_shared(fs::path("build/test/metadata_loads_from_2_14_x_3")); - auto notes = film->read_metadata(fs::path("test/data/2.14.x.metadata.3.xml")); + auto dir = fs::path("build/test/metadata_loads_from_2_14_x_3"); + fs::remove_all(dir); + auto film = make_shared(dir); + fs::copy_file("test/data/2.14.x.metadata.3.xml", dir / "metadata.xml"); + auto notes = film->read_metadata(dir / "metadata.xml"); BOOST_REQUIRE (film->release_territory()); BOOST_REQUIRE (film->release_territory()->subtag() == dcp::LanguageTag::RegionSubtag("de").subtag()); @@ -151,3 +161,52 @@ BOOST_AUTO_TEST_CASE (metadata_loads_from_2_14_x_3) BOOST_REQUIRE (film->luminance() == dcp::Luminance(14, dcp::Luminance::Unit::FOOT_LAMBERT)); } + +/** Check that an empty tag results in the film's luminance being unset */ +BOOST_AUTO_TEST_CASE (metadata_loads_from_2_14_x_4) +{ + namespace fs = boost::filesystem; + auto dir = fs::path("build/test/metadata_loads_from_2_14_x_4"); + fs::remove_all(dir); + auto film = make_shared(dir); + fs::copy_file("test/data/2.14.x.metadata.4.xml", dir / "metadata.xml"); + auto notes = film->read_metadata(dir / "metadata.xml"); + + BOOST_REQUIRE (!film->luminance()); +} + + +BOOST_AUTO_TEST_CASE (metadata_video_range_guessed_for_dcp) +{ + namespace fs = boost::filesystem; + auto film = make_shared(fs::path("test/data/214x_dcp")); + film->read_metadata(); + + BOOST_REQUIRE_EQUAL(film->content().size(), 1U); + BOOST_REQUIRE(film->content()[0]->video); + BOOST_CHECK(film->content()[0]->video->range() == VideoRange::FULL); +} + + +BOOST_AUTO_TEST_CASE (metadata_video_range_guessed_for_mp4_with_unknown_range) +{ + namespace fs = boost::filesystem; + auto film = make_shared(fs::path("test/data/214x_mp4")); + film->read_metadata(); + + BOOST_REQUIRE_EQUAL(film->content().size(), 1U); + BOOST_REQUIRE(film->content()[0]->video); + BOOST_CHECK(film->content()[0]->video->range() == VideoRange::VIDEO); +} + + +BOOST_AUTO_TEST_CASE (metadata_video_range_guessed_for_png) +{ + namespace fs = boost::filesystem; + auto film = make_shared(fs::path("test/data/214x_png")); + film->read_metadata(); + + BOOST_REQUIRE_EQUAL(film->content().size(), 1U); + BOOST_REQUIRE(film->content()[0]->video); + BOOST_CHECK(film->content()[0]->video->range() == VideoRange::FULL); +}