diff options
| author | Carl Hetherington <cth@carlh.net> | 2022-01-09 22:24:06 +0100 |
|---|---|---|
| committer | Carl Hetherington <cth@carlh.net> | 2022-01-11 09:33:59 +0100 |
| commit | 3d40a861b4e77f04df7196cffda5b41b9852b2c7 (patch) | |
| tree | e3820139e14f0f82ed88b2bc18d14959a6c26ab0 | |
| parent | b1ef870b61528feb0d72ed9d7fe54447b3b5c7db (diff) | |
Fix crashes when using kdm_cli with a certificate instead of a cinema.
| -rw-r--r-- | src/lib/kdm_cli.cc | 11 | ||||
| -rw-r--r-- | test/kdm_cli_test.cc | 55 | ||||
| -rw-r--r-- | test/wscript | 1 |
3 files changed, 63 insertions, 4 deletions
diff --git a/src/lib/kdm_cli.cc b/src/lib/kdm_cli.cc index e9a3651ba..e6ba600f4 100644 --- a/src/lib/kdm_cli.cc +++ b/src/lib/kdm_cli.cc @@ -354,8 +354,11 @@ from_dkdm ( continue; } - dcp::LocalTime begin(valid_from, i->cinema->utc_offset_hour(), i->cinema->utc_offset_minute()); - dcp::LocalTime end(valid_to, i->cinema->utc_offset_hour(), i->cinema->utc_offset_minute()); + int const offset_hour = i->cinema ? i->cinema->utc_offset_hour() : 0; + int const offset_minute = i->cinema ? i->cinema->utc_offset_minute() : 0; + + dcp::LocalTime begin(valid_from, offset_hour, offset_minute); + dcp::LocalTime end(valid_to, offset_hour, offset_minute); auto const kdm = kdm_from_dkdm( dkdm, @@ -369,14 +372,14 @@ from_dkdm ( ); dcp::NameFormat::Map name_values; - name_values['c'] = i->cinema->name; + name_values['c'] = i->cinema ? i->cinema->name : ""; name_values['s'] = i->name; name_values['f'] = dkdm.annotation_text().get_value_or(""); name_values['b'] = begin.date() + " " + begin.time_of_day(true, false); name_values['e'] = end.date() + " " + end.time_of_day(true, false); name_values['i'] = kdm.cpl_id(); - kdms.push_back (make_shared<KDMWithMetadata>(name_values, i->cinema.get(), i->cinema->emails, kdm)); + kdms.push_back (make_shared<KDMWithMetadata>(name_values, i->cinema.get(), i->cinema ? i->cinema->emails : list<string>(), kdm)); } write_files (kdms, zip, output, container_name_format, filename_format, verbose, out); if (email) { diff --git a/test/kdm_cli_test.cc b/test/kdm_cli_test.cc new file mode 100644 index 000000000..404f7f8d1 --- /dev/null +++ b/test/kdm_cli_test.cc @@ -0,0 +1,55 @@ +/* + Copyright (C) 2022 Carl Hetherington <cth@carlh.net> + + This file is part of DCP-o-matic. + + DCP-o-matic is free software; you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation; either version 2 of the License, or + (at your option) any later version. + + DCP-o-matic is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with DCP-o-matic. If not, see <http://www.gnu.org/licenses/>. + +*/ + + +#include "lib/kdm_cli.h" +#include <boost/test/unit_test.hpp> +#include <iostream> + + +using std::string; +using std::vector; + + +BOOST_AUTO_TEST_CASE (kdm_cli_test_certificate) +{ + vector<string> args = { + "kdm_cli", + "--verbose", + "--valid-from", "now", + "--valid-duration", "2 weeks", + "--certificate", "test/data/cert.pem", + "test/data/dkdm.xml" + }; + + char** argv = new char*[args.size()]; + for (auto i = 0U; i < args.size(); ++i) { + argv[i] = const_cast<char*>(args[i].c_str()); + } + + auto error = kdm_cli (args.size(), argv, [](string s) { std::cout << s << "\n"; }); + if (error) { + std::cout << *error << "\n"; + } + BOOST_CHECK (!error); + + delete[] argv; +} + diff --git a/test/wscript b/test/wscript index a5366b3ec..bb6484cd8 100644 --- a/test/wscript +++ b/test/wscript @@ -97,6 +97,7 @@ def build(bld): isdcf_name_test.cc j2k_bandwidth_test.cc job_manager_test.cc + kdm_cli_test.cc kdm_naming_test.cc low_bitrate_test.cc markers_test.cc |
