X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=senf%2FUtils%2FConsole%2FTraits.test.cc;h=871037ef777d673be36c165537bdf01715312471;hb=fc1569e67cfda71bc8c406617a5e0b05f28f1b47;hp=85b9f35437ca13021646cbf2fbba7c25c7e5a1e6;hpb=a30f975608bae2dcee151af15dc7f40602627615;p=senf.git diff --git a/senf/Utils/Console/Traits.test.cc b/senf/Utils/Console/Traits.test.cc index 85b9f35..871037e 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 @@ -27,12 +27,7 @@ //#include "Traits.test.ih" // Custom includes -#include "Traits.hh" -#include "Utility.hh" -#include "ParsedCommand.hh" -#include "Executor.hh" -#include "Parse.hh" -#include "ScopedDirectory.hh" +#include "Console.hh" #include #include @@ -59,17 +54,19 @@ namespace { SENF_CONSOLE_REGISTER_ENUM_MEMBER( TestClass, MemberEnum, (MemberFoo)(MemberBar) ); } -BOOST_AUTO_UNIT_TEST(charTraits) +SENF_AUTO_UNIT_TEST(charTraits) { + namespace fty = senf::console::factory; + 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); + dir.add("test",fty::Command(&charTest)); + dir.add("stest",fty::Command(&scharTest)); + dir.add("utest",fty::Command(&ucharTest)); SENF_CHECK_NO_THROW( parser.parse("test/test 10; test/test 20", @@ -90,14 +87,16 @@ BOOST_AUTO_UNIT_TEST(charTraits) ss.str(""); } -BOOST_AUTO_UNIT_TEST(boolTraits) +SENF_AUTO_UNIT_TEST(boolTraits) { + namespace fty = senf::console::factory; + senf::console::Executor executor; senf::console::CommandParser parser; senf::console::ScopedDirectory<> dir; senf::console::root().add("test", dir); - dir.add("test", &boolTest); + dir.add("test", fty::Command(&boolTest)); std::stringstream ss; SENF_CHECK_NO_THROW( @@ -123,7 +122,7 @@ BOOST_AUTO_UNIT_TEST(boolTraits) boost::bind( boost::ref(executor), boost::ref(ss), _1 )) ); BOOST_CHECK_EQUAL( ss.str(), "true\n" "true\n" ); - dir.add("test2", &boolTest).formatter( senf::console::formatEnabledDisabled ); + dir.add("test2", fty::Command(&boolTest).formatter( senf::console::formatEnabledDisabled )); ss.str(""); SENF_CHECK_NO_THROW( parser.parse("test/test2 0; test/test2 -1", @@ -131,15 +130,24 @@ BOOST_AUTO_UNIT_TEST(boolTraits) BOOST_CHECK_EQUAL( ss.str(), "disabled\n" "enabled\n" ); } -BOOST_AUTO_UNIT_TEST(enumSupport) +SENF_AUTO_UNIT_TEST(stringTraits) { + BOOST_CHECK_EQUAL( + senf::console::ArgumentTraits::str("Test\nOf\nA \"String\"\x01\x7f\xa0\xff"), + "\"Test\\x0aOf\\x0aA \\\"String\\\"\\x01\\x7f\\xa0\\xff\"" ); +} + +SENF_AUTO_UNIT_TEST(enumSupport) +{ + namespace fty = senf::console::factory; + senf::console::Executor executor; senf::console::CommandParser parser; senf::console::ScopedDirectory<> dir; senf::console::root().add("test", dir); - dir.add("test",&test); - + dir.add("test",fty::Command(&test)); + std::stringstream ss; SENF_CHECK_NO_THROW( parser.parse("test/test Foo", @@ -162,7 +170,7 @@ BOOST_AUTO_UNIT_TEST(enumSupport) boost::bind( boost::ref(executor), boost::ref(ss), _1 )), senf::console::SyntaxErrorException ); - dir.add("member", &TestClass::test); + dir.add("member", fty::Command(&TestClass::test)); ss.str(""); SENF_CHECK_NO_THROW( @@ -195,11 +203,11 @@ BOOST_AUTO_UNIT_TEST(enumSupport) BOOST_CHECK_EQUAL( ss.str(), "Foo\n" ); } -BOOST_AUTO_UNIT_TEST(singleToken) +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 ); }