X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=test%2Fkdm_cli_test.cc;h=e300d82a5a04b8b481861ebb8ca47458b22ac791;hb=dc5e11944a30a9d381dc0e67cf657c5f2cb65845;hp=52b0316235a77a6ee0ff82ba0da0bef132e52a36;hpb=b1d0ce202bac3fedbc5c77e879cbfd253befbf8a;p=dcpomatic.git diff --git a/test/kdm_cli_test.cc b/test/kdm_cli_test.cc index 52b031623..e300d82a5 100644 --- a/test/kdm_cli_test.cc +++ b/test/kdm_cli_test.cc @@ -19,14 +19,24 @@ */ +#include "lib/cinema.h" +#include "lib/config.h" #include "lib/kdm_cli.h" +#include "lib/screen.h" +#include "lib/trusted_device.h" +#include "test.h" +#include #include #include #include +using std::list; using std::string; using std::vector; +using boost::optional; + + optional run(vector const& args, vector& output) { @@ -66,6 +76,100 @@ BOOST_AUTO_TEST_CASE (kdm_cli_test_certificate) BOOST_CHECK (!error); BOOST_CHECK(boost::filesystem::exists(kdm_filename)); +} + + +static +void +setup_test_config() +{ + auto config = Config::instance(); + auto const cert = dcp::Certificate(dcp::file_to_string("test/data/cert.pem")); + + auto cinema_a = std::make_shared("Dean's Screens", list(), "", 0, 0); + cinema_a->add_screen(std::make_shared("Screen 1", "", cert, boost::none, std::vector())); + cinema_a->add_screen(std::make_shared("Screen 2", "", cert, boost::none, std::vector())); + cinema_a->add_screen(std::make_shared("Screen 3", "", cert, boost::none, std::vector())); + config->add_cinema(cinema_a); + + auto cinema_b = std::make_shared("Floyd's Celluloid", list(), "", 0, 0); + cinema_b->add_screen(std::make_shared("Foo", "", cert, boost::none, std::vector())); + cinema_b->add_screen(std::make_shared("Bar", "", cert, boost::none, std::vector())); + config->add_cinema(cinema_b); +} + + +BOOST_AUTO_TEST_CASE(kdm_cli_select_cinema) +{ + ConfigRestorer cr; + + setup_test_config(); + + vector kdm_filenames = { + "build/test/KDM_Test_FTR-1_F-133_XX-XX_MOS_2K_20220109_SMPTE_OV_Floyds_Celluloid_Foo.xml", + "build/test/KDM_Test_FTR-1_F-133_XX-XX_MOS_2K_20220109_SMPTE_OV_Floyds_Celluloid_Bar.xml" + }; + + for (auto path: kdm_filenames) { + boost::system::error_code ec; + boost::filesystem::remove(path, ec); + } + + vector args = { + "kdm_cli", + "--verbose", + "--valid-from", "now", + "--valid-duration", "2 weeks", + "-c", "Floyd's Celluloid", + "-o", "build/test", + "test/data/dkdm.xml" + }; + + vector output; + auto error = run(args, output); + BOOST_CHECK(!error); + BOOST_REQUIRE_EQUAL(output.size(), 2U); + BOOST_CHECK(boost::algorithm::starts_with(output[0], "Making KDMs valid from")); + BOOST_CHECK_EQUAL(output[1], "Wrote 2 KDM files to build/test"); + + for (auto path: kdm_filenames) { + BOOST_CHECK(boost::filesystem::exists(path)); + } } + +BOOST_AUTO_TEST_CASE(kdm_cli_select_screen) +{ + ConfigRestorer cr; + + setup_test_config(); + + boost::filesystem::path kdm_filename = "build/test/KDM_Test_FTR-1_F-133_XX-XX_MOS_2K_20220109_SMPTE_OV_Deans_Screens_Screen_2.xml"; + + boost::system::error_code ec; + boost::filesystem::remove(kdm_filename, ec); + + vector args = { + "kdm_cli", + "--verbose", + "--valid-from", "now", + "--valid-duration", "2 weeks", + "-c", "Dean's Screens", + "-S", "Screen 2", + "-o", "build/test", + "test/data/dkdm.xml" + }; + + vector output; + auto error = run(args, output); + BOOST_CHECK(!error); + + BOOST_REQUIRE_EQUAL(output.size(), 2U); + BOOST_CHECK(boost::algorithm::starts_with(output[0], "Making KDMs valid from")); + BOOST_CHECK_EQUAL(output[1], "Wrote 1 KDM files to build/test"); + + BOOST_CHECK(boost::filesystem::exists(kdm_filename)); +} + +