From a86c29be5bb206420aa7520633782c7fc6c1b4db Mon Sep 17 00:00:00 2001 From: Pavel Belikov Date: Sun, 12 Nov 2017 16:45:02 +0300 Subject: add Matcher validation tests --- test.cxx | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) (limited to 'test.cxx') diff --git a/test.cxx b/test.cxx index 3376059..71f1fb7 100644 --- a/test.cxx +++ b/test.cxx @@ -958,6 +958,12 @@ TEST_CASE("GetProgramLine works as expected", "[args]") REQUIRE(line(b) == "b -f [positional]"); } +TEST_CASE("Matcher validation works as expected", "[args]") +{ + args::ArgumentParser parser("Test command"); + REQUIRE_THROWS_AS(args::ValueFlag(parser, "", "", {}), args::UsageError); +} + #undef ARGS_HXX #define ARGS_TESTNAMESPACE #define ARGS_NOEXCEPT @@ -1088,6 +1094,17 @@ TEST_CASE("Nargs work as expected in noexcept mode", "[args]") argstest::ArgumentParser parser("Test command"); argstest::NargsValueFlag a(parser, "", "", {'a'}, {3, 2}); + REQUIRE(parser.GetError() == argstest::Error::Usage); + parser.ParseArgs(std::vector{"-a", "1", "2"}); + REQUIRE(parser.GetError() == argstest::Error::Usage); +} + +TEST_CASE("Matcher validation works as expected in noexcept mode", "[args]") +{ + argstest::ArgumentParser parser("Test command"); + argstest::ValueFlag a(parser, "", "", {}); + + REQUIRE(parser.GetError() == argstest::Error::Usage); parser.ParseArgs(std::vector{"-a", "1", "2"}); REQUIRE(parser.GetError() == argstest::Error::Usage); } -- cgit v1.2.1