diff options
| author | Carl Hetherington <cth@carlh.net> | 2023-05-30 12:23:00 +0200 |
|---|---|---|
| committer | Carl Hetherington <cth@carlh.net> | 2023-05-30 12:23:30 +0200 |
| commit | 3ef1d207f33502fa5e114924f0f9abeeda97900a (patch) | |
| tree | cf4ff38f0eccbb5cd7a8de2ce565d5f7ae950087 | |
| parent | 575932b8dccb30a02e0cc140b52aede72828a69a (diff) | |
Add --config option to map (#2543).
| -rw-r--r-- | src/lib/map_cli.cc | 12 | ||||
| m--------- | test/data | 0 | ||||
| -rw-r--r-- | test/map_cli_test.cc | 29 |
3 files changed, 40 insertions, 1 deletions
diff --git a/src/lib/map_cli.cc b/src/lib/map_cli.cc index 1b99afa94..c95d7f1a1 100644 --- a/src/lib/map_cli.cc +++ b/src/lib/map_cli.cc @@ -63,6 +63,7 @@ help(std::function<void (string)> out) out(" -s, --soft-link using soft links instead of copying"); out(" -d, --assets-dir look in this directory for assets (can be given more than once)"); out(" -r, --rename rename all files to <uuid>.<mxf|xml>"); + out(" --config <dir> directory containing config.xml and cinemas.xml"); } @@ -74,6 +75,7 @@ map_cli(int argc, char* argv[], std::function<void (string)> out) bool soft_link = false; bool rename = false; vector<boost::filesystem::path> assets_dir; + optional<boost::filesystem::path> config_dir; /* This makes it possible to call getopt several times in the same executable, for tests */ optind = 0; @@ -87,10 +89,11 @@ map_cli(int argc, char* argv[], std::function<void (string)> out) { "soft-link", no_argument, 0, 's' }, { "assets-dir", required_argument, 0, 'd' }, { "rename", no_argument, 0, 'r' }, + { "config", required_argument, 0, 'c' }, { 0, 0, 0, 0 } }; - int c = getopt_long(argc, argv, "ho:lsd:r", long_options, &option_index); + int c = getopt_long(argc, argv, "ho:lsd:rc:", long_options, &option_index); if (c == -1) { break; @@ -117,6 +120,9 @@ map_cli(int argc, char* argv[], std::function<void (string)> out) case 'r': rename = true; break; + case 'c': + config_dir = optarg; + break; } } @@ -127,6 +133,10 @@ map_cli(int argc, char* argv[], std::function<void (string)> out) exit(EXIT_FAILURE); } + if (config_dir) { + State::override_path = *config_dir; + } + vector<boost::filesystem::path> cpl_filenames; for (int i = optind; i < argc; ++i) { cpl_filenames.push_back(argv[i]); diff --git a/test/data b/test/data -Subproject 31458f4b7a93bd95d23b4b58eb89503e8cec875 +Subproject ece8e470df37357b9a9c29360c15213b6e71ec3 diff --git a/test/map_cli_test.cc b/test/map_cli_test.cc index 3e6abc059..ffe281de5 100644 --- a/test/map_cli_test.cc +++ b/test/map_cli_test.cc @@ -353,3 +353,32 @@ BOOST_AUTO_TEST_CASE(map_two_smpte_cpls_each_with_subs) { test_two_cpls_each_with_subs("map_two_smpte_cpls_each_with_subs", false); } + + +BOOST_AUTO_TEST_CASE(map_with_given_config) +{ + string const name = "map_with_given_config"; + string const out = String::compose("build/test/%1_out", name); + + auto content = content_factory("test/data/flat_red.png"); + auto film = new_test_film2(name + "_in", content); + make_and_verify_dcp(film); + + vector<string> const args = { + "map_cli", + "-o", out, + "-d", film->dir(film->dcp_name()).string(), + "--config", "test/data/map_with_given_config", + find_cpl(film->dir(film->dcp_name())).string() + }; + + boost::filesystem::remove_all(out); + + Config::instance()->drop(); + vector<string> output_messages; + auto error = run(args, output_messages); + BOOST_CHECK(!error); + + /* It should be signed by the key in test/data/map_with_given_config, not the one in test/data/signer_key */ + BOOST_CHECK(dcp::file_to_string(find_file(out, "cpl_")).find("dnQualifier=\\+uOcNN2lPuxpxgd/5vNkkBER0GE=,CN=CS.dcpomatic.smpte-430-2.LEAF,OU=dcpomatic.com,O=dcpomatic.com") != std::string::npos); +} |
