tools: alias 'nfdc cs' to 'nfdc cs info'
Change-Id: Ied1d34a84110ee0b6488d35d56fb1caecaf14117 Refs: #4498
This commit is contained in:
@@ -1,6 +1,6 @@
|
||||
/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
|
||||
/**
|
||||
* Copyright (c) 2014-2017, Regents of the University of California,
|
||||
/*
|
||||
* Copyright (c) 2014-2018, Regents of the University of California,
|
||||
* Arizona Board of Regents,
|
||||
* Colorado State University,
|
||||
* University Pierre & Marie Curie, Sorbonne University,
|
||||
@@ -144,6 +144,8 @@ BOOST_AUTO_TEST_SUITE(ParseValue)
|
||||
|
||||
BOOST_AUTO_TEST_CASE(NoneType)
|
||||
{
|
||||
BOOST_CHECK_EQUAL(boost::lexical_cast<std::string>(ArgValueType::NONE), "none");
|
||||
|
||||
CommandDefinition cs("noun", "verb");
|
||||
cs.addArg("a", ArgValueType::NONE, Required::YES, Positional::NO);
|
||||
|
||||
@@ -159,6 +161,8 @@ BOOST_AUTO_TEST_CASE(NoneType)
|
||||
|
||||
BOOST_AUTO_TEST_CASE(AnyType)
|
||||
{
|
||||
BOOST_CHECK_EQUAL(boost::lexical_cast<std::string>(ArgValueType::ANY), "any");
|
||||
|
||||
CommandDefinition cs("noun", "verb");
|
||||
cs.addArg("a", ArgValueType::ANY, Required::NO, Positional::YES);
|
||||
|
||||
@@ -183,8 +187,42 @@ BOOST_AUTO_TEST_CASE(AnyType)
|
||||
BOOST_CHECK_EQUAL(values.at(1), "c");
|
||||
}
|
||||
|
||||
BOOST_AUTO_TEST_CASE(BooleanType)
|
||||
{
|
||||
BOOST_CHECK_EQUAL(boost::lexical_cast<std::string>(ArgValueType::BOOLEAN), "boolean");
|
||||
|
||||
CommandDefinition cs("noun", "verb");
|
||||
cs.addArg("a", ArgValueType::BOOLEAN, Required::YES);
|
||||
|
||||
CommandArguments ca;
|
||||
|
||||
ca = cs.parse({"a", "on"});
|
||||
BOOST_CHECK_EQUAL(ca.size(), 1);
|
||||
BOOST_CHECK(ca.at("a").type() == typeid(bool));
|
||||
BOOST_CHECK_EQUAL(ca.get<bool>("a"), true);
|
||||
|
||||
ca = cs.parse({"a", "off"});
|
||||
BOOST_CHECK_EQUAL(ca.size(), 1);
|
||||
BOOST_CHECK(ca.at("a").type() == typeid(bool));
|
||||
BOOST_CHECK_EQUAL(ca.get<bool>("a"), false);
|
||||
|
||||
BOOST_CHECK_EQUAL(cs.parse({"a", "true"}).get<bool>("a"), true);
|
||||
BOOST_CHECK_EQUAL(cs.parse({"a", "enabled"}).get<bool>("a"), true);
|
||||
BOOST_CHECK_EQUAL(cs.parse({"a", "yes"}).get<bool>("a"), true);
|
||||
BOOST_CHECK_EQUAL(cs.parse({"a", "1"}).get<bool>("a"), true);
|
||||
BOOST_CHECK_EQUAL(cs.parse({"a", "false"}).get<bool>("a"), false);
|
||||
BOOST_CHECK_EQUAL(cs.parse({"a", "disabled"}).get<bool>("a"), false);
|
||||
BOOST_CHECK_EQUAL(cs.parse({"a", "no"}).get<bool>("a"), false);
|
||||
BOOST_CHECK_EQUAL(cs.parse({"a", "0"}).get<bool>("a"), false);
|
||||
|
||||
BOOST_CHECK_THROW(cs.parse({"a", "42"}), CommandDefinition::Error);
|
||||
BOOST_CHECK_THROW(cs.parse({"a", "not-bool"}), CommandDefinition::Error);
|
||||
}
|
||||
|
||||
BOOST_AUTO_TEST_CASE(UnsignedType)
|
||||
{
|
||||
BOOST_CHECK_EQUAL(boost::lexical_cast<std::string>(ArgValueType::UNSIGNED), "non-negative integer");
|
||||
|
||||
CommandDefinition cs("noun", "verb");
|
||||
cs.addArg("a", ArgValueType::UNSIGNED, Required::YES);
|
||||
|
||||
@@ -206,6 +244,8 @@ BOOST_AUTO_TEST_CASE(UnsignedType)
|
||||
|
||||
BOOST_AUTO_TEST_CASE(StringType)
|
||||
{
|
||||
BOOST_CHECK_EQUAL(boost::lexical_cast<std::string>(ArgValueType::STRING), "string");
|
||||
|
||||
CommandDefinition cs("noun", "verb");
|
||||
cs.addArg("a", ArgValueType::STRING, Required::YES);
|
||||
|
||||
@@ -219,6 +259,8 @@ BOOST_AUTO_TEST_CASE(StringType)
|
||||
|
||||
BOOST_AUTO_TEST_CASE(ReportFormatType)
|
||||
{
|
||||
BOOST_CHECK_EQUAL(boost::lexical_cast<std::string>(ArgValueType::REPORT_FORMAT), "ReportFormat");
|
||||
|
||||
CommandDefinition cs("noun", "verb");
|
||||
cs.addArg("a", ArgValueType::REPORT_FORMAT, Required::YES);
|
||||
|
||||
@@ -239,6 +281,8 @@ BOOST_AUTO_TEST_CASE(ReportFormatType)
|
||||
|
||||
BOOST_AUTO_TEST_CASE(NameType)
|
||||
{
|
||||
BOOST_CHECK_EQUAL(boost::lexical_cast<std::string>(ArgValueType::NAME), "Name");
|
||||
|
||||
CommandDefinition cs("noun", "verb");
|
||||
cs.addArg("a", ArgValueType::NAME, Required::YES);
|
||||
|
||||
@@ -252,6 +296,8 @@ BOOST_AUTO_TEST_CASE(NameType)
|
||||
|
||||
BOOST_AUTO_TEST_CASE(FaceUriType)
|
||||
{
|
||||
BOOST_CHECK_EQUAL(boost::lexical_cast<std::string>(ArgValueType::FACE_URI), "FaceUri");
|
||||
|
||||
CommandDefinition cs("noun", "verb");
|
||||
cs.addArg("a", ArgValueType::FACE_URI, Required::YES);
|
||||
|
||||
@@ -268,6 +314,8 @@ BOOST_AUTO_TEST_CASE(FaceUriType)
|
||||
|
||||
BOOST_AUTO_TEST_CASE(FaceIdOrUriType)
|
||||
{
|
||||
BOOST_CHECK_EQUAL(boost::lexical_cast<std::string>(ArgValueType::FACE_ID_OR_URI), "FaceId or FaceUri");
|
||||
|
||||
CommandDefinition cs("noun", "verb");
|
||||
cs.addArg("a", ArgValueType::FACE_ID_OR_URI, Required::YES);
|
||||
|
||||
@@ -288,6 +336,8 @@ BOOST_AUTO_TEST_CASE(FaceIdOrUriType)
|
||||
|
||||
BOOST_AUTO_TEST_CASE(FacePersistencyType)
|
||||
{
|
||||
BOOST_CHECK_EQUAL(boost::lexical_cast<std::string>(ArgValueType::FACE_PERSISTENCY), "FacePersistency");
|
||||
|
||||
CommandDefinition cs("noun", "verb");
|
||||
cs.addArg("a", ArgValueType::FACE_PERSISTENCY, Required::YES);
|
||||
|
||||
@@ -296,14 +346,12 @@ BOOST_AUTO_TEST_CASE(FacePersistencyType)
|
||||
ca = cs.parse(std::vector<std::string>{"a", "persistent"});
|
||||
BOOST_CHECK_EQUAL(ca.size(), 1);
|
||||
BOOST_CHECK(ca.at("a").type() == typeid(FacePersistency));
|
||||
BOOST_CHECK_EQUAL(ca.get<FacePersistency>("a"),
|
||||
FacePersistency::FACE_PERSISTENCY_PERSISTENT);
|
||||
BOOST_CHECK_EQUAL(ca.get<FacePersistency>("a"), FacePersistency::FACE_PERSISTENCY_PERSISTENT);
|
||||
|
||||
ca = cs.parse(std::vector<std::string>{"a", "permanent"});
|
||||
BOOST_CHECK_EQUAL(ca.size(), 1);
|
||||
BOOST_CHECK(ca.at("a").type() == typeid(FacePersistency));
|
||||
BOOST_CHECK_EQUAL(ca.get<FacePersistency>("a"),
|
||||
FacePersistency::FACE_PERSISTENCY_PERMANENT);
|
||||
BOOST_CHECK_EQUAL(ca.get<FacePersistency>("a"), FacePersistency::FACE_PERSISTENCY_PERMANENT);
|
||||
|
||||
// nfdc does not accept "on-demand"
|
||||
BOOST_CHECK_THROW(cs.parse(std::vector<std::string>{"a", "on-demand"}), CommandDefinition::Error);
|
||||
@@ -311,6 +359,8 @@ BOOST_AUTO_TEST_CASE(FacePersistencyType)
|
||||
|
||||
BOOST_AUTO_TEST_CASE(RouteOriginType)
|
||||
{
|
||||
BOOST_CHECK_EQUAL(boost::lexical_cast<std::string>(ArgValueType::ROUTE_ORIGIN), "RouteOrigin");
|
||||
|
||||
CommandDefinition cs("noun", "verb");
|
||||
cs.addArg("a", ArgValueType::ROUTE_ORIGIN, Required::YES);
|
||||
|
||||
@@ -319,14 +369,12 @@ BOOST_AUTO_TEST_CASE(RouteOriginType)
|
||||
ca = cs.parse(std::vector<std::string>{"a", "Nlsr"});
|
||||
BOOST_CHECK_EQUAL(ca.size(), 1);
|
||||
BOOST_CHECK(ca.at("a").type() == typeid(RouteOrigin));
|
||||
BOOST_CHECK_EQUAL(ca.get<RouteOrigin>("a"),
|
||||
RouteOrigin::ROUTE_ORIGIN_NLSR);
|
||||
BOOST_CHECK_EQUAL(ca.get<RouteOrigin>("a"), RouteOrigin::ROUTE_ORIGIN_NLSR);
|
||||
|
||||
ca = cs.parse(std::vector<std::string>{"a", "27"});
|
||||
BOOST_CHECK_EQUAL(ca.size(), 1);
|
||||
BOOST_CHECK(ca.at("a").type() == typeid(RouteOrigin));
|
||||
BOOST_CHECK_EQUAL(ca.get<RouteOrigin>("a"),
|
||||
static_cast<RouteOrigin>(27));
|
||||
BOOST_CHECK_EQUAL(ca.get<RouteOrigin>("a"), static_cast<RouteOrigin>(27));
|
||||
|
||||
BOOST_CHECK_THROW(cs.parse(std::vector<std::string>{"a", "not-RouteOrigin"}), CommandDefinition::Error);
|
||||
}
|
||||
|
||||
@@ -60,14 +60,12 @@ BOOST_AUTO_TEST_CASE(Basic)
|
||||
|
||||
BOOST_CHECK(parser.listCommands("", ParseMode::ONE_SHOT).empty());
|
||||
|
||||
CommandDefinition defHelp("help", "");
|
||||
defHelp
|
||||
.addArg("noun", ArgValueType::STRING, Required::NO, Positional::YES)
|
||||
.addArg("verb", ArgValueType::STRING, Required::NO, Positional::YES);
|
||||
parser.addCommand(defHelp, dummyExecute, AVAILABLE_IN_ONE_SHOT | AVAILABLE_IN_HELP);
|
||||
CommandDefinition defFoo("foo", "");
|
||||
parser.addCommand(defFoo, dummyExecute, AVAILABLE_IN_ONE_SHOT | AVAILABLE_IN_HELP);
|
||||
|
||||
CommandDefinition defStatusShow("status", "show");
|
||||
parser.addCommand(defStatusShow, dummyExecute);
|
||||
parser.addAlias("status", "show", "");
|
||||
parser.addAlias("status", "show", "list");
|
||||
BOOST_CHECK_THROW(parser.addAlias("status", "show2", "list"), std::out_of_range);
|
||||
|
||||
@@ -75,6 +73,7 @@ BOOST_AUTO_TEST_CASE(Basic)
|
||||
defRouteList
|
||||
.addArg("nexthop", ArgValueType::FACE_ID_OR_URI, Required::NO, Positional::YES);
|
||||
parser.addCommand(defRouteList, dummyExecute);
|
||||
parser.addAlias("route", "list", "");
|
||||
|
||||
CommandDefinition defRouteAdd("route", "add");
|
||||
defRouteAdd
|
||||
@@ -95,18 +94,18 @@ BOOST_AUTO_TEST_CASE(Basic)
|
||||
CommandArguments ca;
|
||||
ExecuteCommand execute;
|
||||
|
||||
std::tie(noun, verb, ca, execute) = parser.parse({"help"}, ParseMode::ONE_SHOT);
|
||||
BOOST_CHECK_EQUAL(noun, "help");
|
||||
BOOST_CHECK_EQUAL(verb, "");
|
||||
|
||||
std::tie(noun, verb, ca, execute) = parser.parse({"help", "foo"}, ParseMode::ONE_SHOT);
|
||||
BOOST_CHECK_EQUAL(noun, "help");
|
||||
std::tie(noun, verb, ca, execute) = parser.parse({"foo"}, ParseMode::ONE_SHOT);
|
||||
BOOST_CHECK_EQUAL(noun, "foo");
|
||||
BOOST_CHECK_EQUAL(verb, "");
|
||||
|
||||
std::tie(noun, verb, ca, execute) = parser.parse({"status"}, ParseMode::ONE_SHOT);
|
||||
BOOST_CHECK_EQUAL(noun, "status");
|
||||
BOOST_CHECK_EQUAL(verb, "show");
|
||||
|
||||
std::tie(noun, verb, ca, execute) = parser.parse({"status", "list"}, ParseMode::ONE_SHOT);
|
||||
BOOST_CHECK_EQUAL(noun, "status");
|
||||
BOOST_CHECK_EQUAL(verb, "show");
|
||||
|
||||
std::tie(noun, verb, ca, execute) = parser.parse({"route", "add", "/n", "300"}, ParseMode::ONE_SHOT);
|
||||
BOOST_CHECK_EQUAL(noun, "route");
|
||||
BOOST_CHECK_EQUAL(verb, "add");
|
||||
@@ -124,10 +123,12 @@ BOOST_AUTO_TEST_CASE(Basic)
|
||||
|
||||
BOOST_CHECK_THROW(parser.parse({}, ParseMode::ONE_SHOT),
|
||||
CommandParser::NoSuchCommandError);
|
||||
BOOST_CHECK_THROW(parser.parse({"cant-help"}, ParseMode::ONE_SHOT),
|
||||
BOOST_CHECK_THROW(parser.parse({"bar"}, ParseMode::ONE_SHOT),
|
||||
CommandParser::NoSuchCommandError);
|
||||
BOOST_CHECK_THROW(parser.parse({"status", "hide"}, ParseMode::ONE_SHOT),
|
||||
CommandParser::NoSuchCommandError);
|
||||
BOOST_CHECK_THROW(parser.parse({"status", "show", "something"}, ParseMode::ONE_SHOT),
|
||||
CommandDefinition::Error);
|
||||
BOOST_CHECK_THROW(parser.parse({"route", "66"}, ParseMode::ONE_SHOT),
|
||||
CommandParser::NoSuchCommandError);
|
||||
BOOST_CHECK_THROW(parser.parse({"route", "add"}, ParseMode::ONE_SHOT),
|
||||
|
||||
Reference in New Issue
Block a user