| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374 | 
							- #include "OptionHandlerImpl.h"
 
- #include "prefs.h"
 
- #include "Exception.h"
 
- #include <cppunit/extensions/HelperMacros.h>
 
- class OptionHandlerTest:public CppUnit::TestFixture {
 
-   CPPUNIT_TEST_SUITE(OptionHandlerTest);
 
-   CPPUNIT_TEST(testNullOptionHandler);
 
-   CPPUNIT_TEST(testBooleanOptionHandler);
 
-   CPPUNIT_TEST(testNumberOptionHandler);
 
-   CPPUNIT_TEST(testNumberOptionHandler_min);
 
-   CPPUNIT_TEST(testNumberOptionHandler_max);
 
-   CPPUNIT_TEST(testNumberOptionHandler_min_max);
 
-   CPPUNIT_TEST(testUnitNumberOptionHandler);
 
-   CPPUNIT_TEST(testParameterOptionHandler_1argInit);
 
-   CPPUNIT_TEST(testParameterOptionHandler_2argsInit);
 
-   CPPUNIT_TEST(testParameterOptionHandler_listInit);
 
-   CPPUNIT_TEST(testDefaultOptionHandler);
 
-   CPPUNIT_TEST(testFloatNumberOptionHandler);
 
-   CPPUNIT_TEST(testFloatNumberOptionHandler_min);
 
-   CPPUNIT_TEST(testFloatNumberOptionHandler_max);
 
-   CPPUNIT_TEST(testFloatNumberOptionHandler_min_max);
 
-   CPPUNIT_TEST(testLogOptionHandler);
 
-   CPPUNIT_TEST(testHttpProxyOptionHandler);
 
-   CPPUNIT_TEST_SUITE_END();
 
-   
 
- public:
 
-   void testNullOptionHandler();
 
-   void testBooleanOptionHandler();
 
-   void testNumberOptionHandler();
 
-   void testNumberOptionHandler_min();
 
-   void testNumberOptionHandler_max();
 
-   void testNumberOptionHandler_min_max();
 
-   void testUnitNumberOptionHandler();
 
-   void testParameterOptionHandler_1argInit();
 
-   void testParameterOptionHandler_2argsInit();
 
-   void testParameterOptionHandler_listInit();
 
-   void testDefaultOptionHandler();
 
-   void testFloatNumberOptionHandler();
 
-   void testFloatNumberOptionHandler_min();
 
-   void testFloatNumberOptionHandler_max();
 
-   void testFloatNumberOptionHandler_min_max();
 
-   void testLogOptionHandler();
 
-   void testHttpProxyOptionHandler();
 
- };
 
- CPPUNIT_TEST_SUITE_REGISTRATION( OptionHandlerTest );
 
- void OptionHandlerTest::testNullOptionHandler()
 
- {
 
-   NullOptionHandler handler;
 
-   CPPUNIT_ASSERT(handler.canHandle("foo"));
 
-   handler.parse(0, "bar");
 
- }
 
- void OptionHandlerTest::testBooleanOptionHandler()
 
- {
 
-   BooleanOptionHandler handler("foo");
 
-   CPPUNIT_ASSERT(handler.canHandle("foo"));
 
-   CPPUNIT_ASSERT(!handler.canHandle("foobar"));
 
-   Option option;
 
-   handler.parse(&option, V_TRUE);
 
-   CPPUNIT_ASSERT_EQUAL(string(V_TRUE), option.get("foo"));
 
-   handler.parse(&option, V_FALSE);
 
-   CPPUNIT_ASSERT_EQUAL(string(V_FALSE), option.get("foo"));
 
-   try {
 
-     handler.parse(&option, "hello");
 
-     CPPUNIT_FAIL("exception must be thrown.");
 
-   } catch(Exception* e) {
 
-     cerr << e->getMsg() << endl;
 
-     delete e;
 
-   }
 
- }
 
- void OptionHandlerTest::testNumberOptionHandler()
 
- {
 
-   NumberOptionHandler handler("foo");
 
-   CPPUNIT_ASSERT(handler.canHandle("foo"));
 
-   CPPUNIT_ASSERT(!handler.canHandle("foobar"));
 
-   Option option;
 
-   handler.parse(&option, "0");
 
-   CPPUNIT_ASSERT_EQUAL(string("0"), option.get("foo"));
 
- }
 
- void OptionHandlerTest::testNumberOptionHandler_min()
 
- {
 
-   NumberOptionHandler handler("foo", 1);
 
-   Option option;
 
-   handler.parse(&option, "1");
 
-   CPPUNIT_ASSERT_EQUAL(string("1"), option.get("foo"));
 
-   try {
 
-     handler.parse(&option, "0");
 
-     CPPUNIT_FAIL("exception must be thrown.");
 
-   } catch(Exception* e) {
 
-     cerr << e->getMsg() << endl;
 
-     delete e;
 
-   }
 
- }
 
- void OptionHandlerTest::testNumberOptionHandler_max()
 
- {
 
-   NumberOptionHandler handler("foo", -1, 100);
 
-   Option option;
 
-   handler.parse(&option, "100");
 
-   CPPUNIT_ASSERT_EQUAL(string("100"), option.get("foo"));
 
-   try {
 
-     handler.parse(&option, "101");
 
-     CPPUNIT_FAIL("exception must be thrown.");
 
-   } catch(Exception* e) {
 
-     cerr << e->getMsg() << endl;
 
-     delete e;
 
-   }
 
- }
 
- void OptionHandlerTest::testNumberOptionHandler_min_max()
 
- {
 
-   NumberOptionHandler handler("foo", 1, 100);
 
-   Option option;
 
-   handler.parse(&option, "1");
 
-   CPPUNIT_ASSERT_EQUAL(string("1"), option.get("foo"));
 
-   handler.parse(&option, "100");
 
-   CPPUNIT_ASSERT_EQUAL(string("100"), option.get("foo"));
 
-   try {
 
-     handler.parse(&option, "0");
 
-     CPPUNIT_FAIL("exception must be thrown.");
 
-   } catch(Exception* e) {
 
-     cerr << e->getMsg() << endl;
 
-     delete e;
 
-   }
 
-   try {
 
-     handler.parse(&option, "101");
 
-     CPPUNIT_FAIL("exception must be thrown.");
 
-   } catch(Exception* e) {
 
-     cerr << e->getMsg() << endl;
 
-     delete e;
 
-   }
 
- }
 
- void OptionHandlerTest::testUnitNumberOptionHandler()
 
- {
 
-   UnitNumberOptionHandler handler("foo");
 
-   CPPUNIT_ASSERT(handler.canHandle("foo"));
 
-   CPPUNIT_ASSERT(!handler.canHandle("foobar"));
 
-   Option option;
 
-   handler.parse(&option, "4294967296");
 
-   CPPUNIT_ASSERT_EQUAL(string("4294967296"), option.get("foo"));
 
-   handler.parse(&option, "4096M");
 
-   CPPUNIT_ASSERT_EQUAL(string("4294967296"), option.get("foo"));
 
-   handler.parse(&option, "4096K");
 
-   CPPUNIT_ASSERT_EQUAL(string("4194304"), option.get("foo"));
 
-   try {
 
-     handler.parse(&option, "K");
 
-     CPPUNIT_FAIL("exception must be thrown.");
 
-   } catch(Exception* e) {
 
-     cerr << *e;
 
-     delete e;
 
-   }
 
-   try {
 
-     handler.parse(&option, "M");
 
-   } catch(Exception* e) {
 
-     cerr << *e;
 
-     delete e;
 
-   }
 
-   try {
 
-     handler.parse(&option, "");
 
-     CPPUNIT_FAIL("exception must be thrown.");
 
-   } catch(Exception* e) {
 
-     cerr << *e;
 
-     delete e;
 
-   }
 
- }
 
- void OptionHandlerTest::testParameterOptionHandler_1argInit()
 
- {
 
-   ParameterOptionHandler handler("foo", "value1");
 
-   CPPUNIT_ASSERT(handler.canHandle("foo"));
 
-   CPPUNIT_ASSERT(!handler.canHandle("foobar"));
 
-   Option option;
 
-   handler.parse(&option, "value1");
 
-   CPPUNIT_ASSERT_EQUAL(string("value1"), option.get("foo"));
 
-   try {
 
-     handler.parse(&option, "value3");
 
-     CPPUNIT_FAIL("exception must be thrown.");
 
-   } catch(Exception* e) {
 
-     cerr << e->getMsg() << endl;
 
-     delete e;
 
-   }
 
- }
 
- void OptionHandlerTest::testParameterOptionHandler_2argsInit()
 
- {
 
-   ParameterOptionHandler handler("foo", "value1", "value2");
 
-   CPPUNIT_ASSERT(handler.canHandle("foo"));
 
-   CPPUNIT_ASSERT(!handler.canHandle("foobar"));
 
-   Option option;
 
-   handler.parse(&option, "value1");
 
-   CPPUNIT_ASSERT_EQUAL(string("value1"), option.get("foo"));
 
-   handler.parse(&option, "value2");
 
-   CPPUNIT_ASSERT_EQUAL(string("value2"), option.get("foo"));
 
-   try {
 
-     handler.parse(&option, "value3");
 
-     CPPUNIT_FAIL("exception must be thrown.");
 
-   } catch(Exception* e) {
 
-     cerr << e->getMsg() << endl;
 
-     delete e;
 
-   }
 
- }
 
- void OptionHandlerTest::testParameterOptionHandler_listInit()
 
- {
 
-   Strings validValues;
 
-   validValues.push_back("value1");
 
-   validValues.push_back("value2");
 
-   ParameterOptionHandler handler("foo", validValues);
 
-   CPPUNIT_ASSERT(handler.canHandle("foo"));
 
-   CPPUNIT_ASSERT(!handler.canHandle("foobar"));
 
-   Option option;
 
-   handler.parse(&option, "value1");
 
-   CPPUNIT_ASSERT_EQUAL(string("value1"), option.get("foo"));
 
-   handler.parse(&option, "value2");
 
-   CPPUNIT_ASSERT_EQUAL(string("value2"), option.get("foo"));
 
-   try {
 
-     handler.parse(&option, "value3");
 
-     CPPUNIT_FAIL("exception must be thrown.");
 
-   } catch(Exception* e) {
 
-     cerr << e->getMsg() << endl;
 
-     delete e;
 
-   }
 
- }
 
- void OptionHandlerTest::testDefaultOptionHandler()
 
- {
 
-   DefaultOptionHandler handler("foo");
 
-   CPPUNIT_ASSERT(handler.canHandle("foo"));
 
-   CPPUNIT_ASSERT(!handler.canHandle("foobar"));
 
-   Option option;
 
-   handler.parse(&option, "bar");
 
-   CPPUNIT_ASSERT_EQUAL(string("bar"), option.get("foo"));
 
-   handler.parse(&option, "");
 
-   CPPUNIT_ASSERT_EQUAL(string(""), option.get("foo"));
 
- }
 
- void OptionHandlerTest::testFloatNumberOptionHandler()
 
- {
 
-   FloatNumberOptionHandler handler("foo");
 
-   CPPUNIT_ASSERT(handler.canHandle("foo"));
 
-   CPPUNIT_ASSERT(!handler.canHandle("foobar"));
 
-   Option option;
 
-   handler.parse(&option, "1.0");
 
-   CPPUNIT_ASSERT_EQUAL(string("1.0"), option.get("foo"));
 
- }
 
- void OptionHandlerTest::testFloatNumberOptionHandler_min()
 
- {
 
-   FloatNumberOptionHandler handler("foo", 0.0);
 
-   Option option;
 
-   handler.parse(&option, "0.0");
 
-   CPPUNIT_ASSERT_EQUAL(string("0.0"), option.get("foo"));
 
-   try {
 
-     handler.parse(&option, "-0.1");
 
-     CPPUNIT_FAIL("exception must be thrown.");
 
-   } catch(Exception* e) {
 
-     cerr << e->getMsg() << endl;
 
-     delete e;
 
-   }
 
- }
 
- void OptionHandlerTest::testFloatNumberOptionHandler_max()
 
- {
 
-   FloatNumberOptionHandler handler("foo", -1, 10.0);
 
-   Option option;
 
-   handler.parse(&option, "10.0");
 
-   CPPUNIT_ASSERT_EQUAL(string("10.0"), option.get("foo"));
 
-   try {
 
-     handler.parse(&option, "10.1");
 
-     CPPUNIT_FAIL("exception must be thrown.");
 
-   } catch(Exception* e) {
 
-     cerr << e->getMsg() << endl;
 
-     delete e;
 
-   }
 
- }
 
- void OptionHandlerTest::testFloatNumberOptionHandler_min_max()
 
- {
 
-   FloatNumberOptionHandler handler("foo", 0.0, 10.0);
 
-   Option option;
 
-   handler.parse(&option, "0.0");
 
-   CPPUNIT_ASSERT_EQUAL(string("0.0"), option.get("foo"));
 
-   handler.parse(&option, "10.0");
 
-   CPPUNIT_ASSERT_EQUAL(string("10.0"), option.get("foo"));
 
-   try {
 
-     handler.parse(&option, "-0.1");
 
-     CPPUNIT_FAIL("exception must be thrown.");
 
-   } catch(Exception* e) {
 
-     cerr << e->getMsg() << endl;
 
-     delete e;
 
-   }
 
-   try {
 
-     handler.parse(&option, "10.1");
 
-     CPPUNIT_FAIL("exception must be thrown.");
 
-   } catch(Exception* e) {
 
-     cerr << e->getMsg() << endl;
 
-     delete e;
 
-   }
 
- }
 
- void OptionHandlerTest::testLogOptionHandler()
 
- {
 
-   LogOptionHandler handler("foo");
 
-   CPPUNIT_ASSERT(handler.canHandle("foo"));
 
-   CPPUNIT_ASSERT(!handler.canHandle("foobar"));
 
-   Option option;
 
-   handler.parse(&option, "/tmp/log.txt");
 
-   CPPUNIT_ASSERT_EQUAL(string("/tmp/log.txt"), option.get(PREF_LOG));
 
-   CPPUNIT_ASSERT_EQUAL(string(""), option.get(PREF_STDOUT_LOG));
 
-   option.clear();
 
-   handler.parse(&option, "-");
 
-   CPPUNIT_ASSERT_EQUAL(string(""), option.get(PREF_LOG));
 
-   CPPUNIT_ASSERT_EQUAL(string(V_TRUE), option.get(PREF_STDOUT_LOG));
 
- }
 
- void OptionHandlerTest::testHttpProxyOptionHandler()
 
- {
 
-   HttpProxyOptionHandler handler("foo");
 
-   CPPUNIT_ASSERT(handler.canHandle("foo"));
 
-   CPPUNIT_ASSERT(!handler.canHandle("foobar"));
 
-   Option option;
 
-   handler.parse(&option, "bar:80");
 
-   CPPUNIT_ASSERT_EQUAL(string("bar:80"), option.get(PREF_HTTP_PROXY));
 
-   CPPUNIT_ASSERT_EQUAL(string("bar"), option.get(PREF_HTTP_PROXY_HOST));
 
-   CPPUNIT_ASSERT_EQUAL(string("80"), option.get(PREF_HTTP_PROXY_PORT));
 
-   CPPUNIT_ASSERT_EQUAL(string(V_TRUE), option.get(PREF_HTTP_PROXY_ENABLED));
 
-   try {
 
-     handler.parse(&option, "bar");
 
-     CPPUNIT_FAIL("exception must be thrown.");
 
-   } catch(Exception* e) {
 
-     cerr << e->getMsg() << endl;
 
-     delete e;
 
-   }
 
-   try {
 
-     handler.parse(&option, "bar:");
 
-     CPPUNIT_FAIL("exception must be thrown.");
 
-   } catch(Exception* e) {
 
-     cerr << e->getMsg() << endl;
 
-     delete e;
 
-   }
 
-   try {
 
-     handler.parse(&option, ":");
 
-     CPPUNIT_FAIL("exception must be thrown.");
 
-   } catch(Exception* e) {
 
-     cerr << e->getMsg() << endl;
 
-     delete e;
 
-   }
 
-   try {
 
-     handler.parse(&option, ":80");
 
-     CPPUNIT_FAIL("exception must be thrown.");
 
-   } catch(Exception* e) {
 
-     cerr << e->getMsg() << endl;
 
-     delete e;
 
-   }
 
-   try {
 
-     handler.parse(&option, "foo:bar");
 
-     CPPUNIT_FAIL("exception must be thrown.");
 
-   } catch(Exception* e) {
 
-     cerr << e->getMsg() << endl;
 
-     delete e;
 
-   }
 
- }
 
 
  |