summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCarl Hetherington <cth@carlh.net>2022-09-09 01:44:56 +0200
committerCarl Hetherington <cth@carlh.net>2022-09-09 01:54:38 +0200
commitb1d0ce202bac3fedbc5c77e879cbfd253befbf8a (patch)
tree77212f3491a1fdbcd3177b4c459a8c5af7b5a2db
parent758bcded6f954a60d4b9a38d12b51c68260e08f6 (diff)
Extract run() method to call kdm_cli().
-rw-r--r--test/kdm_cli_test.cc27
1 files changed, 17 insertions, 10 deletions
diff --git a/test/kdm_cli_test.cc b/test/kdm_cli_test.cc
index 16529a897..52b031623 100644
--- a/test/kdm_cli_test.cc
+++ b/test/kdm_cli_test.cc
@@ -27,6 +27,21 @@
using std::string;
using std::vector;
+optional<string>
+run(vector<string> const& args, vector<string>& output)
+{
+ std::vector<char*> argv(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.data(), [&output](string s) { output.push_back(s); });
+ if (error) {
+ std::cout << *error << "\n";
+ }
+
+ return error;
+}
BOOST_AUTO_TEST_CASE (kdm_cli_test_certificate)
@@ -42,23 +57,15 @@ BOOST_AUTO_TEST_CASE (kdm_cli_test_certificate)
"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());
- }
-
boost::filesystem::path const kdm_filename = "build/test/KDM_Test_FTR-1_F-133_XX-XX_MOS_2K_20220109_SMPTE_OV__my_great_screen.xml";
boost::system::error_code ec;
boost::filesystem::remove(kdm_filename, ec);
- auto error = kdm_cli (args.size(), argv, [](string s) { std::cout << s << "\n"; });
- if (error) {
- std::cout << *error << "\n";
- }
+ vector<string> output;
+ auto error = run(args, output);
BOOST_CHECK (!error);
BOOST_CHECK(boost::filesystem::exists(kdm_filename));
- delete[] argv;
}