mirror of
https://github.com/slsdetectorgroup/slsDetectorPackage.git
synced 2026-02-10 12:08:41 +01:00
Formatting
This commit is contained in:
@@ -2,10 +2,10 @@
|
||||
// Copyright (C) 2021 Contributors to the SLS Detector Package
|
||||
|
||||
#include "CommandLineOptions.h"
|
||||
#include "sls/sls_detector_defs.h"
|
||||
#include "sls/versionAPI.h"
|
||||
#include "sls/ToString.h"
|
||||
#include "sls/logger.h"
|
||||
#include "sls/sls_detector_defs.h"
|
||||
#include "sls/versionAPI.h"
|
||||
|
||||
#include <csignal>
|
||||
#include <cstring>
|
||||
@@ -28,7 +28,7 @@ ParsedOptions CommandLineOptions::parse(int argc, char *argv[]) {
|
||||
FrameSyncOptions frame;
|
||||
base.port = DEFAULT_TCP_RX_PORTNO;
|
||||
|
||||
auto optString = buildOptString();
|
||||
auto optString = buildOptString();
|
||||
auto longOptions = buildOptionList();
|
||||
optind = 0; // reset getopt
|
||||
int opt, option_index = 0;
|
||||
@@ -40,12 +40,10 @@ ParsedOptions CommandLineOptions::parse(int argc, char *argv[]) {
|
||||
case 'h':
|
||||
handleCommonOption(opt, optarg, base);
|
||||
return base; // exit after version/help
|
||||
|
||||
case 'p':
|
||||
case 'u':
|
||||
handleCommonOption(opt, optarg, base);
|
||||
break;
|
||||
|
||||
case 'c':
|
||||
case 'n':
|
||||
case 't':
|
||||
@@ -60,10 +58,12 @@ ParsedOptions CommandLineOptions::parse(int argc, char *argv[]) {
|
||||
if (optind < argc) {
|
||||
|
||||
// deprecated and current options => invalid
|
||||
if (base.port != DEFAULT_TCP_RX_PORTNO ||
|
||||
multi.numReceivers != 1 || frame.numReceivers != 1 || multi.callbackEnabled != false || frame.printHeaders != false) {
|
||||
LOG(sls::logWARNING)
|
||||
<< "Cannot use both deprecated options and the valid options simultaneously. Please move away from the deprecated options.\n";
|
||||
if (base.port != DEFAULT_TCP_RX_PORTNO || multi.numReceivers != 1 ||
|
||||
frame.numReceivers != 1 || multi.callbackEnabled != false ||
|
||||
frame.printHeaders != false) {
|
||||
LOG(sls::logWARNING) << "Cannot use both deprecated options and "
|
||||
"the valid options simultaneously. Please "
|
||||
"move away from the deprecated options.\n";
|
||||
}
|
||||
|
||||
// unsupported deprecated arguments
|
||||
@@ -74,7 +74,6 @@ ParsedOptions CommandLineOptions::parse(int argc, char *argv[]) {
|
||||
// parse deprecated arguments
|
||||
std::vector<std::string> args(argv, argv + argc);
|
||||
auto [p, n, o] = ParseDeprecated(args);
|
||||
|
||||
// set options
|
||||
base.port = p;
|
||||
if (appType_ == AppType::MultiReceiver) {
|
||||
@@ -113,9 +112,9 @@ ParsedOptions CommandLineOptions::parse(int argc, char *argv[]) {
|
||||
std::vector<option> CommandLineOptions::buildOptionList() const {
|
||||
std::vector<option> opts = {
|
||||
{"version", no_argument, nullptr, 'v'},
|
||||
{"help", no_argument, nullptr, 'h'},
|
||||
{"port", required_argument, nullptr, 'p'},
|
||||
{"uid", required_argument, nullptr, 'u'},
|
||||
{"help", no_argument, nullptr, 'h'},
|
||||
};
|
||||
switch (appType_) {
|
||||
case AppType::SingleReceiver:
|
||||
@@ -135,7 +134,7 @@ std::vector<option> CommandLineOptions::buildOptionList() const {
|
||||
}
|
||||
|
||||
std::string CommandLineOptions::buildOptString() const {
|
||||
std::string optstr = "vp:u:h";
|
||||
std::string optstr = "vhp:u:";
|
||||
if (appType_ == AppType::MultiReceiver ||
|
||||
appType_ == AppType::FrameSynchronizer)
|
||||
optstr += "cn:";
|
||||
@@ -241,8 +240,10 @@ void CommandLineOptions::handleAppSpecificOption(int opt, const char *optarg,
|
||||
}
|
||||
}
|
||||
|
||||
/* maintain backward compatibility of [start port] [num receivers] [optional arg] */
|
||||
std::tuple<uint16_t, uint16_t, bool> CommandLineOptions::ParseDeprecated(const std::vector<std::string> &args) {
|
||||
/* maintain backward compatibility of [start port] [num receivers] [optional
|
||||
* arg] */
|
||||
std::tuple<uint16_t, uint16_t, bool>
|
||||
CommandLineOptions::ParseDeprecated(const std::vector<std::string> &args) {
|
||||
|
||||
size_t nargs = args.size();
|
||||
if (nargs != 1 && nargs != 3 && nargs != 4) {
|
||||
@@ -251,7 +252,7 @@ std::tuple<uint16_t, uint16_t, bool> CommandLineOptions::ParseDeprecated(const s
|
||||
|
||||
LOG(sls::logWARNING)
|
||||
<< "Deprecated options will be removed in future versions. "
|
||||
"Please use the new options.\n";
|
||||
"Please use the new options.\n";
|
||||
|
||||
// default deprecated values
|
||||
if (nargs == 1) {
|
||||
@@ -334,7 +335,7 @@ std::string CommandLineOptions::getHelpMessage() const {
|
||||
|
||||
void CommandLineOptions::setupSignalHandler(int signal, void (*handler)(int)) {
|
||||
// Catch signal SIGINT to close files and call destructors properly
|
||||
struct sigaction sa{};
|
||||
struct sigaction sa {};
|
||||
sa.sa_handler = handler;
|
||||
sigemptyset(&sa.sa_mask); // dont block additional signals
|
||||
sa.sa_flags = 0;
|
||||
|
||||
@@ -5,16 +5,11 @@
|
||||
#include <cstdint>
|
||||
#include <getopt.h>
|
||||
#include <string>
|
||||
#include <tuple>
|
||||
#include <variant>
|
||||
#include <vector>
|
||||
#include <tuple>
|
||||
|
||||
enum class AppType {
|
||||
MultiReceiver,
|
||||
SingleReceiver,
|
||||
FrameSynchronizer
|
||||
};
|
||||
|
||||
enum class AppType { MultiReceiver, SingleReceiver, FrameSynchronizer };
|
||||
|
||||
struct CommonOptions {
|
||||
uint16_t port = -1;
|
||||
@@ -33,7 +28,8 @@ struct FrameSyncOptions : CommonOptions {
|
||||
bool printHeaders = false;
|
||||
};
|
||||
|
||||
using ParsedOptions = std::variant<CommonOptions, MultiReceiverOptions, FrameSyncOptions>;
|
||||
using ParsedOptions =
|
||||
std::variant<CommonOptions, MultiReceiverOptions, FrameSyncOptions>;
|
||||
|
||||
class CommandLineOptions {
|
||||
public:
|
||||
@@ -45,7 +41,9 @@ class CommandLineOptions {
|
||||
std::string getHelpMessage() const;
|
||||
static void setupSignalHandler(int signal, void (*handler)(int));
|
||||
static void setEffectiveUID(uid_t uid);
|
||||
static std::tuple<uint16_t, uint16_t, bool> ParseDeprecated(const std::vector<std::string> &args);
|
||||
static std::tuple<uint16_t, uint16_t, bool>
|
||||
ParseDeprecated(const std::vector<std::string> &args);
|
||||
|
||||
private:
|
||||
AppType appType_;
|
||||
std::vector<option> buildOptionList() const;
|
||||
@@ -60,8 +58,5 @@ class CommandLineOptions {
|
||||
MultiReceiverOptions &multi,
|
||||
FrameSyncOptions &frame);
|
||||
|
||||
|
||||
|
||||
|
||||
static constexpr uint16_t MAX_RECEIVERS = 1000;
|
||||
};
|
||||
|
||||
@@ -549,19 +549,20 @@ int main(int argc, char *argv[]) {
|
||||
<< "Thread " << i << " [ Tid: " << gettid() << ']';
|
||||
try {
|
||||
sls::Receiver receiver(port);
|
||||
receiver.registerCallBackStartAcquisition(StartAcquisitionCallback,
|
||||
user_data);
|
||||
receiver.registerCallBackStartAcquisition(
|
||||
StartAcquisitionCallback, user_data);
|
||||
receiver.registerCallBackAcquisitionFinished(
|
||||
AcquisitionFinishedCallback, user_data);
|
||||
receiver.registerCallBackRawDataReady(GetDataCallback, user_data);
|
||||
receiver.registerCallBackRawDataReady(GetDataCallback,
|
||||
user_data);
|
||||
|
||||
/** - as long as no Ctrl+C */
|
||||
// each child shares the common semaphore
|
||||
sem_wait(semaphore);
|
||||
} catch (...) {
|
||||
LOG(sls::logINFOBLUE)
|
||||
<< "Exiting Thread " << i << " [ Tid: " << gettid() << " ]";
|
||||
for (auto &s : semaphores)
|
||||
<< "Exiting Thread " << i << " [ Tid: " << gettid() << " ]";
|
||||
for (auto &s : semaphores)
|
||||
sem_destroy(&s);
|
||||
cleanup();
|
||||
if (global_frame_status)
|
||||
@@ -569,7 +570,7 @@ int main(int argc, char *argv[]) {
|
||||
std::exit(EXIT_FAILURE);
|
||||
}
|
||||
LOG(sls::logINFOBLUE)
|
||||
<< "Exiting Thread " << i << " [ Tid: " << gettid() << " ]";
|
||||
<< "Exiting Thread " << i << " [ Tid: " << gettid() << " ]";
|
||||
sem_destroy(semaphore);
|
||||
});
|
||||
}
|
||||
|
||||
@@ -38,7 +38,7 @@ int main(int argc, char *argv[]) {
|
||||
} catch (sls::RuntimeError &e) {
|
||||
return EXIT_FAILURE;
|
||||
}
|
||||
auto& o = std::get<CommonOptions>(opts);
|
||||
auto &o = std::get<CommonOptions>(opts);
|
||||
if (o.versionRequested || o.helpRequested) {
|
||||
return EXIT_SUCCESS;
|
||||
}
|
||||
|
||||
@@ -1,283 +1,328 @@
|
||||
// SPDX-License-Identifier: LGPL-3.0-or-other
|
||||
// Copyright (C) 2021 Contributors to the SLS Detector Package
|
||||
#include "catch.hpp"
|
||||
#include "CommandLineOptions.h"
|
||||
#include "catch.hpp"
|
||||
#include "sls/versionAPI.h"
|
||||
|
||||
#include <unistd.h>
|
||||
|
||||
namespace sls {
|
||||
|
||||
template<typename T, typename U>
|
||||
constexpr bool is_type() {
|
||||
return std::is_same_v<std::decay_t<U>, T>;
|
||||
template <typename T, typename U> constexpr bool is_type() {
|
||||
return std::is_same_v<std::decay_t<U>, T>;
|
||||
}
|
||||
|
||||
TEST_CASE("CommandLineOption construction", "[.rxcmdcall]") {
|
||||
CommandLineOptions s(AppType::SingleReceiver);
|
||||
REQUIRE(s.getTypeString() == "slsReceiver");
|
||||
REQUIRE(s.getVersion() ==
|
||||
std::string("slsReceiver Version: ") + APIRECEIVER);
|
||||
REQUIRE_NOTHROW(s.getHelpMessage());
|
||||
|
||||
CommandLineOptions m(AppType::MultiReceiver);
|
||||
REQUIRE(m.getTypeString() == "slsMultiReceiver");
|
||||
REQUIRE(m.getVersion() ==
|
||||
std::string("slsMultiReceiver Version: ") + APIRECEIVER);
|
||||
REQUIRE_NOTHROW(m.getHelpMessage());
|
||||
|
||||
CommandLineOptions f(AppType::FrameSynchronizer);
|
||||
REQUIRE(f.getTypeString() == "slsFrameSynchronizer");
|
||||
REQUIRE(f.getVersion() ==
|
||||
std::string("slsFrameSynchronizer Version: ") + APIRECEIVER);
|
||||
REQUIRE_NOTHROW(f.getHelpMessage());
|
||||
}
|
||||
|
||||
TEST_CASE("Validate common options", "[.rxcmdcall]") {
|
||||
std::string uidStr = std::to_string(getuid());
|
||||
|
||||
for (auto app : {AppType::SingleReceiver, AppType::MultiReceiver,
|
||||
AppType::FrameSynchronizer}) {
|
||||
CommandLineOptions s(app);
|
||||
REQUIRE_NOTHROW(s.parse({}));
|
||||
REQUIRE_NOTHROW(s.parse({"", "-v"}));
|
||||
REQUIRE_NOTHROW(s.parse({"", "-h"}));
|
||||
REQUIRE_NOTHROW(s.parse({"", "-h", "gdfg"})); // ignored extra args
|
||||
REQUIRE_NOTHROW(s.parse({"", "-p", "1955"}));
|
||||
REQUIRE_NOTHROW(s.parse({"", "-u", uidStr}));
|
||||
REQUIRE_NOTHROW(s.parse({"", "-p", "1234", "-u", uidStr}));
|
||||
}
|
||||
}
|
||||
|
||||
TEST_CASE("CommandLineOption construction", "[.rxcmdcall]") {
|
||||
CommandLineOptions s(AppType::SingleReceiver);
|
||||
REQUIRE(s.getTypeString() == "slsReceiver");
|
||||
REQUIRE(s.getVersion() == std::string("slsReceiver Version: ") + APIRECEIVER);
|
||||
REQUIRE_NOTHROW(s.getHelpMessage());
|
||||
TEST_CASE("Validate specific options", "[.rxcmdcall]") {
|
||||
std::string uidStr = std::to_string(getuid());
|
||||
|
||||
CommandLineOptions m(AppType::MultiReceiver);
|
||||
REQUIRE(m.getTypeString() == "slsMultiReceiver");
|
||||
REQUIRE(m.getVersion() == std::string("slsMultiReceiver Version: ") + APIRECEIVER);
|
||||
REQUIRE_NOTHROW(m.getHelpMessage());
|
||||
CommandLineOptions s(AppType::SingleReceiver);
|
||||
REQUIRE_NOTHROW(s.parse({"", "-t", "1955"}));
|
||||
REQUIRE_THROWS(s.parse({"", "-c"}));
|
||||
REQUIRE_THROWS(s.parse({"", "-n", "2"}));
|
||||
REQUIRE_THROWS(s.parse({"", "-m", "2"}));
|
||||
|
||||
CommandLineOptions f(AppType::FrameSynchronizer);
|
||||
REQUIRE(f.getTypeString() == "slsFrameSynchronizer");
|
||||
REQUIRE(f.getVersion() == std::string("slsFrameSynchronizer Version: ") + APIRECEIVER);
|
||||
REQUIRE_NOTHROW(f.getHelpMessage());
|
||||
for (auto app : {AppType::MultiReceiver, AppType::FrameSynchronizer}) {
|
||||
CommandLineOptions m(app);
|
||||
REQUIRE_NOTHROW(m.parse({"", "-c"}));
|
||||
REQUIRE_NOTHROW(m.parse({"", "-n", "2"}));
|
||||
REQUIRE_NOTHROW(
|
||||
m.parse({"", "-p", "1234", "-u", uidStr, "-c", "-n", "2"}));
|
||||
REQUIRE_THROWS(m.parse({"", "-t", "1955"}));
|
||||
REQUIRE_THROWS(m.parse({"", "-m", "2"}));
|
||||
}
|
||||
}
|
||||
|
||||
TEST_CASE("Validate common options", "[.rxcmdcall]") {
|
||||
std::string uidStr = std::to_string(getuid());
|
||||
|
||||
for (auto app : {AppType::SingleReceiver, AppType::MultiReceiver, AppType::FrameSynchronizer}) {
|
||||
CommandLineOptions s(app);
|
||||
REQUIRE_NOTHROW(s.parse({}));
|
||||
REQUIRE_NOTHROW(s.parse({"", "-v"}));
|
||||
REQUIRE_NOTHROW(s.parse({"", "-h"}));
|
||||
REQUIRE_NOTHROW(s.parse({"", "-h", "gdfg"})); // ignored extra args
|
||||
REQUIRE_NOTHROW(s.parse({"", "-p", "1955"}));
|
||||
REQUIRE_NOTHROW(s.parse({"", "-u", uidStr}));
|
||||
REQUIRE_NOTHROW(s.parse({"", "-p", "1234", "-u", uidStr}));
|
||||
}
|
||||
}
|
||||
|
||||
TEST_CASE("Validate specific options", "[.rxcmdcall]") {
|
||||
std::string uidStr = std::to_string(getuid());
|
||||
|
||||
CommandLineOptions s(AppType::SingleReceiver);
|
||||
REQUIRE_NOTHROW(s.parse({"", "-t", "1955"}));
|
||||
REQUIRE_THROWS(s.parse({"", "-c"}));
|
||||
REQUIRE_THROWS(s.parse({"", "-n", "2"}));
|
||||
REQUIRE_THROWS(s.parse({"", "-m", "2"}));
|
||||
|
||||
for (auto app : {AppType::MultiReceiver, AppType::FrameSynchronizer}) {
|
||||
CommandLineOptions m(app);
|
||||
REQUIRE_NOTHROW(m.parse({"", "-c"}));
|
||||
REQUIRE_NOTHROW(m.parse({"", "-n", "2"}));
|
||||
REQUIRE_NOTHROW(m.parse({"", "-p", "1234", "-u", uidStr, "-c", "-n", "2"}));
|
||||
REQUIRE_THROWS(m.parse({"", "-t", "1955"}));
|
||||
REQUIRE_THROWS(m.parse({"", "-m", "2"}));
|
||||
}
|
||||
}
|
||||
|
||||
TEST_CASE("Parse version and help", "[.rxcmdcall]") {
|
||||
for (auto app : {AppType::SingleReceiver, AppType::MultiReceiver, AppType::FrameSynchronizer}) {
|
||||
CommandLineOptions s(app);
|
||||
auto opts = s.parse({});
|
||||
std::visit([](const auto& o) {
|
||||
TEST_CASE("Parse version and help", "[.rxcmdcall]") {
|
||||
for (auto app : {AppType::SingleReceiver, AppType::MultiReceiver,
|
||||
AppType::FrameSynchronizer}) {
|
||||
CommandLineOptions s(app);
|
||||
auto opts = s.parse({});
|
||||
std::visit(
|
||||
[](const auto &o) {
|
||||
REQUIRE(o.versionRequested == false); // default
|
||||
REQUIRE(o.helpRequested == false); // default
|
||||
}, opts);
|
||||
REQUIRE(o.helpRequested == false); // default
|
||||
},
|
||||
opts);
|
||||
|
||||
opts = s.parse({"", "-v"});
|
||||
std::visit([](const auto& o) {
|
||||
opts = s.parse({"", "-v"});
|
||||
std::visit(
|
||||
[](const auto &o) {
|
||||
REQUIRE(o.versionRequested == true);
|
||||
REQUIRE(o.helpRequested == false);
|
||||
}, opts);
|
||||
REQUIRE(o.helpRequested == false);
|
||||
},
|
||||
opts);
|
||||
|
||||
opts = s.parse({"", "-h"});
|
||||
std::visit([](const auto& o) {
|
||||
opts = s.parse({"", "-h"});
|
||||
std::visit(
|
||||
[](const auto &o) {
|
||||
REQUIRE(o.versionRequested == false);
|
||||
REQUIRE(o.helpRequested == true);
|
||||
}, opts);
|
||||
},
|
||||
opts);
|
||||
|
||||
opts = s.parse({"", "-h", "-v"});
|
||||
std::visit([](const auto& o) {
|
||||
opts = s.parse({"", "-h", "-v"});
|
||||
std::visit(
|
||||
[](const auto &o) {
|
||||
REQUIRE(o.versionRequested == false); // exits after help
|
||||
REQUIRE(o.helpRequested == true);
|
||||
}, opts);
|
||||
},
|
||||
opts);
|
||||
|
||||
opts = s.parse({"", "-v", "-h"});
|
||||
std::visit([](const auto& o) {
|
||||
opts = s.parse({"", "-v", "-h"});
|
||||
std::visit(
|
||||
[](const auto &o) {
|
||||
REQUIRE(o.helpRequested == false); // exits after version
|
||||
REQUIRE(o.versionRequested == true);
|
||||
}, opts);
|
||||
},
|
||||
opts);
|
||||
|
||||
opts = s.parse({"", "-v", "-h", "sdfsf"}); // ignores extra args
|
||||
std::visit([](const auto& o) {
|
||||
opts = s.parse({"", "-v", "-h", "sdfsf"}); // ignores extra args
|
||||
std::visit(
|
||||
[](const auto &o) {
|
||||
REQUIRE(o.helpRequested == false); // exits after version
|
||||
REQUIRE(o.versionRequested == true);
|
||||
}, opts);
|
||||
}
|
||||
},
|
||||
opts);
|
||||
}
|
||||
}
|
||||
|
||||
TEST_CASE("Parse port and uid", "[.rxcmdcall]") {
|
||||
uid_t uid = getuid();
|
||||
std::string uidStr = std::to_string(uid);
|
||||
uid_t invalidUid = uid + 1000;
|
||||
std::string invalidUidStr = std::to_string(invalidUid);
|
||||
TEST_CASE("Parse port and uid", "[.rxcmdcall]") {
|
||||
uid_t uid = getuid();
|
||||
std::string uidStr = std::to_string(uid);
|
||||
uid_t invalidUid = uid + 1000;
|
||||
std::string invalidUidStr = std::to_string(invalidUid);
|
||||
|
||||
for (auto app : {AppType::SingleReceiver, AppType::MultiReceiver, AppType::FrameSynchronizer}) {
|
||||
CommandLineOptions s(app);
|
||||
REQUIRE_THROWS(s.parse({"", "-p", "1234", "-u", invalidUidStr})); // invalid uid
|
||||
REQUIRE_THROWS(s.parse({"", "-p", "500"})); // invalid port
|
||||
|
||||
auto opts = s.parse({"", "-p", "1234", "-u", uidStr});
|
||||
std::visit([&](const auto& o){
|
||||
for (auto app : {AppType::SingleReceiver, AppType::MultiReceiver,
|
||||
AppType::FrameSynchronizer}) {
|
||||
CommandLineOptions s(app);
|
||||
REQUIRE_THROWS(
|
||||
s.parse({"", "-p", "1234", "-u", invalidUidStr})); // invalid uid
|
||||
REQUIRE_THROWS(s.parse({"", "-p", "500"})); // invalid port
|
||||
|
||||
auto opts = s.parse({"", "-p", "1234", "-u", uidStr});
|
||||
std::visit(
|
||||
[&](const auto &o) {
|
||||
REQUIRE(o.port == 1234);
|
||||
REQUIRE(o.userid == uid);
|
||||
}, opts);
|
||||
},
|
||||
opts);
|
||||
|
||||
opts = s.parse({"", "-p", "5678"});
|
||||
std::visit([](const auto& o) {
|
||||
opts = s.parse({"", "-p", "5678"});
|
||||
std::visit(
|
||||
[](const auto &o) {
|
||||
REQUIRE(o.port == 5678);
|
||||
REQUIRE(o.userid == static_cast<uid_t>(-1)); // default
|
||||
}, opts);
|
||||
},
|
||||
opts);
|
||||
|
||||
|
||||
opts = s.parse({});
|
||||
std::visit([](const auto& o) {
|
||||
REQUIRE(o.port == 1954); // default
|
||||
opts = s.parse({});
|
||||
std::visit(
|
||||
[](const auto &o) {
|
||||
REQUIRE(o.port == 1954); // default
|
||||
REQUIRE(o.userid == static_cast<uid_t>(-1)); // default
|
||||
}, opts);
|
||||
}
|
||||
},
|
||||
opts);
|
||||
}
|
||||
}
|
||||
|
||||
TEST_CASE("Parse num receivers and opt arg (Specific opt)", "[.rxcmdcall]") {
|
||||
for (auto app : {AppType::MultiReceiver, AppType::FrameSynchronizer}) {
|
||||
CommandLineOptions s(app);
|
||||
|
||||
REQUIRE_THROWS(s.parse({"", "-n", "0"})); // invalid number of receivers
|
||||
REQUIRE_THROWS(s.parse({"", "-n", "1001"})); // exceeds max receivers
|
||||
REQUIRE_NOTHROW(s.parse({"", "-n", "10"})); // valid
|
||||
TEST_CASE("Parse num receivers and opt arg (Specific opt)", "[.rxcmdcall]") {
|
||||
for (auto app : {AppType::MultiReceiver, AppType::FrameSynchronizer}) {
|
||||
CommandLineOptions s(app);
|
||||
|
||||
auto opts = s.parse({""});
|
||||
std::visit([](const auto& o) {
|
||||
REQUIRE_THROWS(s.parse({"", "-n", "0"})); // invalid number of receivers
|
||||
REQUIRE_THROWS(s.parse({"", "-n", "1001"})); // exceeds max receivers
|
||||
REQUIRE_NOTHROW(s.parse({"", "-n", "10"})); // valid
|
||||
|
||||
auto opts = s.parse({""});
|
||||
std::visit(
|
||||
[](const auto &o) {
|
||||
using T = decltype(o);
|
||||
if constexpr (is_type<MultiReceiverOptions, T>()) {
|
||||
REQUIRE(o.numReceivers == 1); // default
|
||||
REQUIRE(o.callbackEnabled == false);
|
||||
|
||||
} else if constexpr (is_type<FrameSyncOptions, T>()) {
|
||||
REQUIRE(o.numReceivers == 1); // default
|
||||
REQUIRE(o.printHeaders == false);
|
||||
}
|
||||
},
|
||||
opts);
|
||||
|
||||
opts = s.parse({"", "-n", "5"});
|
||||
std::visit(
|
||||
[](const auto &o) {
|
||||
using T = decltype(o);
|
||||
if constexpr (is_type<MultiReceiverOptions, T>()) {
|
||||
REQUIRE(o.numReceivers == 5);
|
||||
REQUIRE(o.callbackEnabled == false); // default
|
||||
|
||||
} else if constexpr (is_type<FrameSyncOptions, T>()) {
|
||||
REQUIRE(o.numReceivers == 5);
|
||||
REQUIRE(o.printHeaders == false); // default
|
||||
}
|
||||
},
|
||||
opts);
|
||||
|
||||
opts = s.parse({"", "-c", "-n", "3"});
|
||||
std::visit(
|
||||
[](const auto &o) {
|
||||
using T = decltype(o);
|
||||
if constexpr (is_type<MultiReceiverOptions, T>()) {
|
||||
REQUIRE(o.numReceivers == 3);
|
||||
REQUIRE(o.callbackEnabled == true);
|
||||
|
||||
} else if constexpr (is_type<FrameSyncOptions, T>()) {
|
||||
REQUIRE(o.numReceivers == 3);
|
||||
REQUIRE(o.printHeaders == true);
|
||||
}
|
||||
},
|
||||
opts);
|
||||
}
|
||||
}
|
||||
|
||||
TEST_CASE("Parse deprecated options", "[.rxcmdcall]") {
|
||||
for (auto app : {AppType::SingleReceiver, AppType::MultiReceiver,
|
||||
AppType::FrameSynchronizer}) {
|
||||
CommandLineOptions s(app);
|
||||
// argc 3 or 4, invalid
|
||||
REQUIRE_THROWS(s.parse({"", "1954"}));
|
||||
REQUIRE_THROWS(s.parse({
|
||||
"",
|
||||
"1954",
|
||||
}));
|
||||
// argc 3 or 4
|
||||
if (app == AppType::SingleReceiver) {
|
||||
REQUIRE_THROWS(
|
||||
s.parse({"", "1954", "1"})); // deprecated unsupported
|
||||
} else {
|
||||
REQUIRE_THROWS(s.parse({"", "1954", "1", "1", "-p",
|
||||
"1954"})); // mix deprecated and current
|
||||
REQUIRE_THROWS(
|
||||
s.parse({"", "1954", "1", "-c"})); // mix deprecated and current
|
||||
REQUIRE_THROWS(s.parse(
|
||||
{"", "1954", "1", "-n", "34"})); // mix deprecated and current
|
||||
REQUIRE_THROWS(s.parse({"", "110", "1954"})); // mix order
|
||||
REQUIRE_THROWS(s.parse({"", "1023", "10"})); // privileged port
|
||||
REQUIRE_THROWS(s.parse({"", "2000", "0"})); // invalid num receivers
|
||||
REQUIRE_THROWS(
|
||||
s.parse({"", "2000", "1001"})); // invalid num receivers
|
||||
REQUIRE_THROWS(s.parse({"", "1954", "1", "2"})); // invalid 3rd opt
|
||||
|
||||
REQUIRE_NOTHROW(s.parse({""}));
|
||||
REQUIRE_NOTHROW(s.parse({"", "1954", "1"}));
|
||||
REQUIRE_NOTHROW(s.parse({"", "1954", "1", "0"}));
|
||||
REQUIRE_NOTHROW(s.parse({"", "1954", "1", "1"}));
|
||||
|
||||
// default
|
||||
auto opts = s.parse({""});
|
||||
std::visit(
|
||||
[](const auto &o) {
|
||||
using T = decltype(o);
|
||||
if constexpr (is_type<MultiReceiverOptions, T>()) {
|
||||
REQUIRE(o.numReceivers == 1); // default
|
||||
REQUIRE(o.port == 1954);
|
||||
REQUIRE(o.numReceivers == 1);
|
||||
REQUIRE(o.callbackEnabled == false);
|
||||
|
||||
} else if constexpr (is_type<FrameSyncOptions, T>()) {
|
||||
REQUIRE(o.numReceivers == 1); // default
|
||||
REQUIRE(o.printHeaders == false);
|
||||
}
|
||||
}, opts);
|
||||
} else if constexpr (is_type<FrameSyncOptions, T>()) {
|
||||
REQUIRE(o.port == 1954);
|
||||
REQUIRE(o.numReceivers == 1);
|
||||
REQUIRE(o.printHeaders == false); // default
|
||||
}
|
||||
},
|
||||
opts);
|
||||
|
||||
opts = s.parse({"", "-n", "5"});
|
||||
std::visit([](const auto& o) {
|
||||
using T = decltype(o);
|
||||
opts = s.parse({"", "1958", "10"});
|
||||
std::visit(
|
||||
[](const auto &o) {
|
||||
using T = decltype(o);
|
||||
if constexpr (is_type<MultiReceiverOptions, T>()) {
|
||||
REQUIRE(o.numReceivers == 5);
|
||||
REQUIRE(o.port == 1958);
|
||||
REQUIRE(o.numReceivers == 10);
|
||||
REQUIRE(o.callbackEnabled == false); // default
|
||||
|
||||
} else if constexpr (is_type<FrameSyncOptions, T>()) {
|
||||
REQUIRE(o.numReceivers == 5);
|
||||
} else if constexpr (is_type<FrameSyncOptions, T>()) {
|
||||
REQUIRE(o.port == 1958);
|
||||
REQUIRE(o.numReceivers == 10);
|
||||
REQUIRE(o.printHeaders == false); // default
|
||||
}
|
||||
}, opts);
|
||||
}
|
||||
},
|
||||
opts);
|
||||
|
||||
|
||||
opts = s.parse({"", "-c", "-n", "3"});
|
||||
std::visit([](const auto& o) {
|
||||
using T = decltype(o);
|
||||
opts = s.parse({"", "1958", "10", "1"});
|
||||
std::visit(
|
||||
[](const auto &o) {
|
||||
using T = decltype(o);
|
||||
if constexpr (is_type<MultiReceiverOptions, T>()) {
|
||||
REQUIRE(o.numReceivers == 3);
|
||||
REQUIRE(o.callbackEnabled == true);
|
||||
REQUIRE(o.port == 1958);
|
||||
REQUIRE(o.numReceivers == 10);
|
||||
REQUIRE(o.callbackEnabled == true); // default
|
||||
|
||||
} else if constexpr (is_type<FrameSyncOptions, T>()) {
|
||||
REQUIRE(o.numReceivers == 3);
|
||||
REQUIRE(o.printHeaders == true);
|
||||
}
|
||||
}, opts);
|
||||
} else if constexpr (is_type<FrameSyncOptions, T>()) {
|
||||
REQUIRE(o.port == 1958);
|
||||
REQUIRE(o.numReceivers == 10);
|
||||
REQUIRE(o.printHeaders == true); // default
|
||||
}
|
||||
},
|
||||
opts);
|
||||
}
|
||||
}
|
||||
|
||||
TEST_CASE("Parse deprecated options", "[.rxcmdcall]") {
|
||||
for (auto app : {AppType::SingleReceiver, AppType::MultiReceiver, AppType::FrameSynchronizer}) {
|
||||
CommandLineOptions s(app);
|
||||
// argc 3 or 4, invalid
|
||||
REQUIRE_THROWS(s.parse({"", "1954"}));
|
||||
REQUIRE_THROWS(s.parse({"", "1954", }));
|
||||
// argc 3 or 4
|
||||
if (app == AppType::SingleReceiver) {
|
||||
REQUIRE_THROWS(s.parse({"", "1954", "1"})); // deprecated unsupported
|
||||
} else {
|
||||
REQUIRE_THROWS(s.parse({"", "1954", "1", "1", "-p", "1954"}));// mix deprecated and current
|
||||
REQUIRE_THROWS(s.parse({"", "1954", "1", "-c"}));// mix deprecated and current
|
||||
REQUIRE_THROWS(s.parse({"", "1954", "1", "-n", "34"}));// mix deprecated and current
|
||||
REQUIRE_THROWS(s.parse({"", "110", "1954"}));// mix order
|
||||
REQUIRE_THROWS(s.parse({"", "1023", "10"}));// privileged port
|
||||
REQUIRE_THROWS(s.parse({"", "2000", "0"}));// invalid num receivers
|
||||
REQUIRE_THROWS(s.parse({"", "2000", "1001"}));// invalid num receivers
|
||||
REQUIRE_THROWS(s.parse({"", "1954", "1", "2"}));// invalid 3rd opt
|
||||
// test function directly
|
||||
// nargs can be 1, 3 or 4
|
||||
REQUIRE_THROWS(CommandLineOptions::ParseDeprecated({"", ""}));
|
||||
REQUIRE_THROWS(CommandLineOptions::ParseDeprecated({"", "", "", "", ""}));
|
||||
|
||||
REQUIRE_NOTHROW(s.parse({""}));
|
||||
REQUIRE_NOTHROW(s.parse({"", "1954", "1"}));
|
||||
REQUIRE_NOTHROW(s.parse({"", "1954", "1", "0"}));
|
||||
REQUIRE_NOTHROW(s.parse({"", "1954", "1", "1"}));
|
||||
// default
|
||||
auto [p, n, o] = CommandLineOptions::ParseDeprecated({""});
|
||||
REQUIRE(p == 1954);
|
||||
REQUIRE(n == 1);
|
||||
REQUIRE(o == false);
|
||||
|
||||
// default
|
||||
auto opts = s.parse({""});
|
||||
std::visit([](const auto& o) {
|
||||
using T = decltype(o);
|
||||
if constexpr (is_type<MultiReceiverOptions, T>()) {
|
||||
REQUIRE(o.port == 1954);
|
||||
REQUIRE(o.numReceivers == 1);
|
||||
REQUIRE(o.callbackEnabled == false);
|
||||
std::tie(p, n, o) = CommandLineOptions::ParseDeprecated({"", "1955", "6"});
|
||||
REQUIRE(p == 1955);
|
||||
REQUIRE(n == 6);
|
||||
REQUIRE(o == false);
|
||||
|
||||
} else if constexpr (is_type<FrameSyncOptions, T>()) {
|
||||
REQUIRE(o.port == 1954);
|
||||
REQUIRE(o.numReceivers == 1);
|
||||
REQUIRE(o.printHeaders == false); // default
|
||||
}
|
||||
}, opts);
|
||||
|
||||
opts = s.parse({"", "1958", "10"});
|
||||
std::visit([](const auto& o) {
|
||||
using T = decltype(o);
|
||||
if constexpr (is_type<MultiReceiverOptions, T>()) {
|
||||
REQUIRE(o.port == 1958);
|
||||
REQUIRE(o.numReceivers == 10);
|
||||
REQUIRE(o.callbackEnabled == false); // default
|
||||
|
||||
} else if constexpr (is_type<FrameSyncOptions, T>()) {
|
||||
REQUIRE(o.port == 1958);
|
||||
REQUIRE(o.numReceivers == 10);
|
||||
REQUIRE(o.printHeaders == false); // default
|
||||
}
|
||||
}, opts);
|
||||
|
||||
opts = s.parse({"", "1958", "10", "1"});
|
||||
std::visit([](const auto& o) {
|
||||
using T = decltype(o);
|
||||
if constexpr (is_type<MultiReceiverOptions, T>()) {
|
||||
REQUIRE(o.port == 1958);
|
||||
REQUIRE(o.numReceivers == 10);
|
||||
REQUIRE(o.callbackEnabled == true); // default
|
||||
|
||||
} else if constexpr (is_type<FrameSyncOptions, T>()) {
|
||||
REQUIRE(o.port == 1958);
|
||||
REQUIRE(o.numReceivers == 10);
|
||||
REQUIRE(o.printHeaders == true); // default
|
||||
}
|
||||
}, opts);
|
||||
}
|
||||
}
|
||||
|
||||
// test function directly
|
||||
// nargs can be 1, 3 or 4
|
||||
REQUIRE_THROWS(CommandLineOptions::ParseDeprecated({"",""}));
|
||||
REQUIRE_THROWS(CommandLineOptions::ParseDeprecated({"","", "", "", ""}));
|
||||
|
||||
// default
|
||||
auto [p, n, o] = CommandLineOptions::ParseDeprecated({""});
|
||||
REQUIRE(p == 1954);
|
||||
REQUIRE(n == 1);
|
||||
REQUIRE(o == false);
|
||||
|
||||
std::tie(p, n, o) = CommandLineOptions::ParseDeprecated({"", "1955", "6"});
|
||||
REQUIRE(p == 1955);
|
||||
REQUIRE(n == 6);
|
||||
REQUIRE(o == false);
|
||||
|
||||
std::tie(p, n, o) = CommandLineOptions::ParseDeprecated({"", "1955", "6", "1"});
|
||||
REQUIRE(p == 1955);
|
||||
REQUIRE(n == 6);
|
||||
REQUIRE(o == true);
|
||||
}
|
||||
}
|
||||
std::tie(p, n, o) =
|
||||
CommandLineOptions::ParseDeprecated({"", "1955", "6", "1"});
|
||||
REQUIRE(p == 1955);
|
||||
REQUIRE(n == 6);
|
||||
REQUIRE(o == true);
|
||||
}
|
||||
} // namespace sls
|
||||
Reference in New Issue
Block a user