From 0cdb390a035f8bb6d3a17633f791a78cf835143c Mon Sep 17 00:00:00 2001 From: Carl Hetherington Date: Fri, 22 Mar 2024 20:39:38 +0100 Subject: Add add-dkdm command to add DKDMs to DCP-o-matic's internal list from the CLI. --- test/kdm_cli_test.cc | 28 ++++++++++++++++++++++++++++ 1 file changed, 28 insertions(+) (limited to 'test/kdm_cli_test.cc') diff --git a/test/kdm_cli_test.cc b/test/kdm_cli_test.cc index 057d7be93..303f2b0d4 100644 --- a/test/kdm_cli_test.cc +++ b/test/kdm_cli_test.cc @@ -23,6 +23,7 @@ #include "lib/config.h" #include "lib/content_factory.h" #include "lib/cross.h" +#include "lib/dkdm_wrapper.h" #include "lib/film.h" #include "lib/kdm_cli.h" #include "lib/screen.h" @@ -34,6 +35,7 @@ #include +using std::dynamic_pointer_cast; using std::string; using std::vector; using boost::optional; @@ -331,3 +333,29 @@ BOOST_AUTO_TEST_CASE(kdm_cli_time) BOOST_CHECK(boost::filesystem::exists(kdm_filename)); } + +BOOST_AUTO_TEST_CASE(kdm_cli_add_dkdm) +{ + ConfigRestorer cr; + + setup_test_config(); + + BOOST_CHECK_EQUAL(Config::instance()->dkdms()->children().size(), 0U); + + vector args = { + "kdm_cli", + "add-dkdm", + "test/data/dkdm.xml" + }; + + vector output; + auto error = run(args, output); + BOOST_CHECK(!error); + + auto dkdms = Config::instance()->dkdms()->children(); + BOOST_CHECK_EQUAL(dkdms.size(), 1U); + auto dkdm = dynamic_pointer_cast(dkdms.front()); + BOOST_CHECK(dkdm); + BOOST_CHECK_EQUAL(dkdm->dkdm().as_xml(), dcp::file_to_string("test/data/dkdm.xml")); +} + -- cgit v1.2.3