X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=senf%2FUtils%2FConsole%2FTraits.test.cc;h=f242f1d3514e71d162f64c0b3fb402f13ba2056c;hb=93d9568d448749dc187e7622b733a4a3caa319df;hp=cc5697f4c02a233cf0445ade70aafe6f68dd7a5f;hpb=f13780e9e4da7df981d6f6542fbdc714beb34765;p=senf.git diff --git a/senf/Utils/Console/Traits.test.cc b/senf/Utils/Console/Traits.test.cc index cc5697f..f242f1d 100644 --- a/senf/Utils/Console/Traits.test.cc +++ b/senf/Utils/Console/Traits.test.cc @@ -1,6 +1,6 @@ // $Id$ // -// Copyright (C) 2008 +// Copyright (C) 2008 // Fraunhofer Institute for Open Communication Systems (FOKUS) // Competence Center NETwork research (NET), St. Augustin, GERMANY // Stefan Bund @@ -33,7 +33,7 @@ #include #define prefix_ -///////////////////////////////cc.p//////////////////////////////////////// +//-///////////////////////////////////////////////////////////////////////////////////////////////// namespace { char charTest(char value) { return value; } @@ -52,6 +52,11 @@ namespace { static MemberEnum test (MemberEnum value) { return value; } }; SENF_CONSOLE_REGISTER_ENUM_MEMBER( TestClass, MemberEnum, (MemberFoo)(MemberBar) ); + + enum TestEnumKey { ONE, TWO, THREE }; + SENF_CONSOLE_REGISTER_ENUM( TestEnumKey, (key("1s",ONE))(key("2",TWO))(key("three",THREE)) ); + + TestEnumKey testKey (TestEnumKey value) { return value; } } SENF_AUTO_UNIT_TEST(charTraits) @@ -132,7 +137,7 @@ SENF_AUTO_UNIT_TEST(boolTraits) SENF_AUTO_UNIT_TEST(stringTraits) { - BOOST_CHECK_EQUAL( + BOOST_CHECK_EQUAL( senf::console::ArgumentTraits::str("Test\nOf\nA \"String\"\x01\x7f\xa0\xff"), "\"Test\\x0aOf\\x0aA \\\"String\\\"\\x01\\x7f\\xa0\\xff\"" ); } @@ -147,7 +152,8 @@ SENF_AUTO_UNIT_TEST(enumSupport) senf::console::root().add("test", dir); dir.add("test",fty::Command(&test)); - + dir.add("testKey",fty::Command(&testKey)); + std::stringstream ss; SENF_CHECK_NO_THROW( parser.parse("test/test Foo", @@ -201,17 +207,35 @@ SENF_AUTO_UNIT_TEST(enumSupport) 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/testKey 1S", + boost::bind( boost::ref(executor), boost::ref(ss), _1 )) ); + BOOST_CHECK_EQUAL( ss.str(), "1s\n" ); + + ss.str(""); + SENF_CHECK_NO_THROW( + parser.parse("test/testKey 2", + boost::bind( boost::ref(executor), boost::ref(ss), _1 )) ); + BOOST_CHECK_EQUAL( ss.str(), "2\n" ); + + ss.str(""); + SENF_CHECK_NO_THROW( + parser.parse("test/testKey ThrEE", + boost::bind( boost::ref(executor), boost::ref(ss), _1 )) ); + BOOST_CHECK_EQUAL( ss.str(), "three\n" ); } SENF_AUTO_UNIT_TEST(singleToken) { BOOST_CHECK( senf::console::ArgumentTraits::singleToken ); BOOST_CHECK( senf::console::ArgumentTraits::singleToken ); - BOOST_CHECK( ! senf::console::ArgumentTraits< + BOOST_CHECK( ! senf::console::ArgumentTraits< senf::console::FlagCollection >::singleToken ); } -///////////////////////////////cc.e//////////////////////////////////////// +//-///////////////////////////////////////////////////////////////////////////////////////////////// #undef prefix_