X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=test%2Ffilm_metadata_test.cc;h=62cb5cf1d562f47a95868b70a3416cba03bb9e5b;hb=8aec035b6ec6d8a119aef8748d571a65c3de386b;hp=f1313497adae172d82fbe3396a9c29d1a169ee97;hpb=3ff1586aad2fa5ba7e5fd95e178614aae12496e6;p=dcpomatic.git diff --git a/test/film_metadata_test.cc b/test/film_metadata_test.cc index f1313497a..62cb5cf1d 100644 --- a/test/film_metadata_test.cc +++ b/test/film_metadata_test.cc @@ -41,7 +41,7 @@ using std::string; using std::list; using std::make_shared; -using std::shared_ptr; +using std::vector; BOOST_AUTO_TEST_CASE (film_metadata_test) @@ -64,7 +64,7 @@ BOOST_AUTO_TEST_CASE (film_metadata_test) film->set_release_territory (dcp::LanguageTag::RegionSubtag("US")); film->write_metadata (); - list ignore = { "Key", "ContextID" }; + list ignore = { "Key", "ContextID", "LastWrittenBy" }; check_xml ("test/data/metadata.xml.ref", dir.string() + "/metadata.xml", ignore); auto g = make_shared(dir); @@ -107,8 +107,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 +120,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', " @@ -126,3 +132,45 @@ 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 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()); + + BOOST_REQUIRE (film->audio_language()); + BOOST_REQUIRE (*film->audio_language() == dcp::LanguageTag("sv-SE")); + + BOOST_REQUIRE (film->content_versions() == vector{"3"}); + BOOST_REQUIRE (film->ratings() == vector{ dcp::Rating("", "214rating") }); + BOOST_REQUIRE_EQUAL (film->studio().get_value_or(""), "214studio"); + BOOST_REQUIRE_EQUAL (film->facility().get_value_or(""), "214facility"); + BOOST_REQUIRE_EQUAL (film->temp_version(), true); + BOOST_REQUIRE_EQUAL (film->pre_release(), true); + BOOST_REQUIRE_EQUAL (film->red_band(), true); + BOOST_REQUIRE_EQUAL (film->two_d_version_of_three_d(), true); + BOOST_REQUIRE_EQUAL (film->chain().get_value_or(""), "214chain"); + 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()); +} +