// Custom includes
#include "Traits.hh"
+#include "ParsedCommand.hh"
+#include "Executor.hh"
+#include "Parse.hh"
+#include "ScopedDirectory.hh"
#include "../Utils/auto_unit_test.hh"
#include <boost/test/test_tools.hpp>
#define prefix_
///////////////////////////////cc.p////////////////////////////////////////
-BOOST_AUTO_UNIT_TEST(parseParameter)
-{}
+namespace {
+ enum TestEnum { Foo, Bar };
+ SENF_CONSOLE_REGISTER_ENUM( TestEnum, (Foo)(Bar) );
+
+ TestEnum test (TestEnum value) { return value; }
+
+ struct TestClass {
+ enum MemberEnum { MemberFoo, MemberBar };
+ 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(boolTraits)
+{
+ senf::console::Executor executor;
+ senf::console::CommandParser parser;
+ senf::console::ScopedDirectory<> dir;
+ senf::console::root().add("test", dir);
+
+ dir.add("test", &boolTest);
+
+ std::stringstream ss;
+ BOOST_CHECK_NO_THROW(
+ parser.parse("test/test true; test/test false",
+ boost::bind<void>( boost::ref(executor), boost::ref(ss), _1 )) );
+ BOOST_CHECK_EQUAL( ss.str(), "true\n" "false\n" );
+
+ ss.str("");
+ BOOST_CHECK_NO_THROW(
+ parser.parse("test/test enabled; test/test disabled",
+ boost::bind<void>( boost::ref(executor), boost::ref(ss), _1 )) );
+ BOOST_CHECK_EQUAL( ss.str(), "true\n" "false\n" );
+
+ ss.str("");
+ BOOST_CHECK_NO_THROW(
+ parser.parse("test/test yes; test/test no",
+ boost::bind<void>( boost::ref(executor), boost::ref(ss), _1 )) );
+ BOOST_CHECK_EQUAL( ss.str(), "true\n" "false\n" );
+
+ ss.str("");
+ BOOST_CHECK_NO_THROW(
+ parser.parse("test/test Y; test/test enA",
+ boost::bind<void>( boost::ref(executor), boost::ref(ss), _1 )) );
+ BOOST_CHECK_EQUAL( ss.str(), "true\n" "true\n" );
+
+ dir.add("test2", &boolTest).formatter( senf::console::formatEnabledDisabled );
+ ss.str("");
+ BOOST_CHECK_NO_THROW(
+ parser.parse("test/test2 0; test/test2 -1",
+ boost::bind<void>( boost::ref(executor), boost::ref(ss), _1 )) );
+ BOOST_CHECK_EQUAL( ss.str(), "disabled\n" "enabled\n" );
+}
+
+BOOST_AUTO_UNIT_TEST(enumSupport)
+{
+ senf::console::Executor executor;
+ senf::console::CommandParser parser;
+ senf::console::ScopedDirectory<> dir;
+ senf::console::root().add("test", dir);
+
+ dir.add("test",&test);
+
+ std::stringstream ss;
+ BOOST_CHECK_NO_THROW(
+ parser.parse("test/test Foo",
+ boost::bind<void>( boost::ref(executor), boost::ref(ss), _1 )) );
+ BOOST_CHECK_EQUAL( ss.str(), "Foo\n" );
+
+ ss.str("");
+ BOOST_CHECK_NO_THROW(
+ parser.parse("test/test Bar",
+ boost::bind<void>( boost::ref(executor), boost::ref(ss), _1 )) );
+ BOOST_CHECK_EQUAL( ss.str(), "Bar\n" );
+
+ BOOST_CHECK_THROW(
+ parser.parse("test/test (Foo Bar)",
+ boost::bind<void>( boost::ref(executor), boost::ref(ss), _1 )),
+ senf::console::SyntaxErrorException );
+
+ BOOST_CHECK_THROW(
+ parser.parse("test/test Baz",
+ boost::bind<void>( boost::ref(executor), boost::ref(ss), _1 )),
+ senf::console::SyntaxErrorException );
+
+ dir.add("member", &TestClass::test);
+
+ ss.str("");
+ BOOST_CHECK_NO_THROW(
+ parser.parse("test/member MemberFoo",
+ boost::bind<void>( boost::ref(executor), boost::ref(ss), _1 )) );
+ BOOST_CHECK_EQUAL( ss.str(), "MemberFoo\n" );
+
+ ss.str("");
+ BOOST_CHECK_NO_THROW(
+ parser.parse("test/member MemberBar",
+ boost::bind<void>( boost::ref(executor), boost::ref(ss), _1 )) );
+ BOOST_CHECK_EQUAL( ss.str(), "MemberBar\n" );
+}
+
///////////////////////////////cc.e////////////////////////////////////////
#undef prefix_