X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=senf%2FUtils%2FConsole%2FTraits.test.cc;fp=senf%2FUtils%2FConsole%2FTraits.test.cc;h=85b9f35437ca13021646cbf2fbba7c25c7e5a1e6;hb=a30f975608bae2dcee151af15dc7f40602627615;hp=b8d1d1f313736c66e0bc3599e043305b59bde503;hpb=a46724f6a51d4b14a2170976405530d0f5aef590;p=senf.git diff --git a/senf/Utils/Console/Traits.test.cc b/senf/Utils/Console/Traits.test.cc index b8d1d1f..85b9f35 100644 --- a/senf/Utils/Console/Traits.test.cc +++ b/senf/Utils/Console/Traits.test.cc @@ -28,6 +28,7 @@ // Custom includes #include "Traits.hh" +#include "Utility.hh" #include "ParsedCommand.hh" #include "Executor.hh" #include "Parse.hh" @@ -40,6 +41,12 @@ ///////////////////////////////cc.p//////////////////////////////////////// namespace { + char charTest(char value) { return value; } + signed char scharTest(signed char value) { return value; } + unsigned char ucharTest(unsigned char value) { return value; } + + bool boolTest(bool value) { return value; } + enum TestEnum { Foo=1, Bar=2, FooBar=4 }; SENF_CONSOLE_REGISTER_ENUM( TestEnum, (Foo)(Bar)(FooBar) ); @@ -50,11 +57,37 @@ namespace { static MemberEnum test (MemberEnum value) { return value; } }; SENF_CONSOLE_REGISTER_ENUM_MEMBER( TestClass, MemberEnum, (MemberFoo)(MemberBar) ); +} - bool boolTest(bool value) { return value; } +BOOST_AUTO_UNIT_TEST(charTraits) +{ + senf::console::Executor executor; + senf::console::CommandParser parser; + senf::console::ScopedDirectory<> dir; + senf::console::root().add("test", dir); + std::stringstream ss; + + dir.add("test",&charTest); + dir.add("stest",&scharTest); + dir.add("utest",&ucharTest); - senf::console::FlagCollection collectionTest( - senf::console::FlagCollection flags) { return flags; } + SENF_CHECK_NO_THROW( + parser.parse("test/test 10; test/test 20", + boost::bind( boost::ref(executor), boost::ref(ss), _1 )) ); + BOOST_CHECK_EQUAL( ss.str(), "10\n" "20\n" ); + ss.str(""); + + SENF_CHECK_NO_THROW( + parser.parse("test/stest 10; test/stest -20", + boost::bind( boost::ref(executor), boost::ref(ss), _1 )) ); + BOOST_CHECK_EQUAL( ss.str(), "10\n" "-20\n" ); + ss.str(""); + + SENF_CHECK_NO_THROW( + parser.parse("test/utest 10; test/utest 20", + boost::bind( boost::ref(executor), boost::ref(ss), _1 )) ); + BOOST_CHECK_EQUAL( ss.str(), "10\n" "20\n" ); + ss.str(""); } BOOST_AUTO_UNIT_TEST(boolTraits) @@ -162,35 +195,6 @@ BOOST_AUTO_UNIT_TEST(enumSupport) BOOST_CHECK_EQUAL( ss.str(), "Foo\n" ); } -BOOST_AUTO_UNIT_TEST(flagCollection) -{ - senf::console::Executor executor; - senf::console::CommandParser parser; - senf::console::ScopedDirectory<> dir; - senf::console::root().add("test", dir); - std::stringstream ss; - - dir.add("test",&collectionTest); - - ss.str(""); - SENF_CHECK_NO_THROW( - parser.parse("test/test foo", - boost::bind( boost::ref(executor), boost::ref(ss), _1 )) ); - BOOST_CHECK_EQUAL( ss.str(), "Foo\n" ); - - ss.str(""); - SENF_CHECK_NO_THROW( - parser.parse("test/test (foo bar)", - boost::bind( boost::ref(executor), boost::ref(ss), _1 )) ); - BOOST_CHECK_EQUAL( ss.str(), "(Foo Bar)\n" ); - - ss.str(""); - SENF_CHECK_NO_THROW( - parser.parse("test/test ()", - boost::bind( boost::ref(executor), boost::ref(ss), _1 )) ); - BOOST_CHECK_EQUAL( ss.str(), "()\n" ); -} - BOOST_AUTO_UNIT_TEST(singleToken) { BOOST_CHECK( senf::console::ArgumentTraits::singleToken );