| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119 | 
							- #include "XmlRpcRequestProcessor.h"
 
- #include <cppunit/extensions/HelperMacros.h>
 
- #include "XmlRpcRequestParserStateMachine.h"
 
- #include "RecoverableException.h"
 
- namespace aria2 {
 
- namespace xmlrpc {
 
- class XmlRpcRequestProcessorTest:public CppUnit::TestFixture {
 
-   CPPUNIT_TEST_SUITE(XmlRpcRequestProcessorTest);
 
-   CPPUNIT_TEST(testParseMemory);
 
-   CPPUNIT_TEST(testParseMemory_shouldFail);
 
-   CPPUNIT_TEST_SUITE_END();
 
- public:
 
-   void setUp() {}
 
-   void tearDown() {}
 
-   void testParseMemory();
 
-   void testParseMemory_shouldFail();
 
- };
 
- CPPUNIT_TEST_SUITE_REGISTRATION(XmlRpcRequestProcessorTest);
 
- void XmlRpcRequestProcessorTest::testParseMemory()
 
- {
 
-   XmlRpcRequestProcessor proc;
 
-   XmlRpcRequest req =
 
-     proc.parseMemory("<?xml version=\"1.0\"?>"
 
-                      "<methodCall>"
 
-                      "  <methodName>aria2.addURI</methodName>"
 
-                      "    <params>"
 
-                      "      <param>"
 
-                      "        <value><i4>100</i4></value>"
 
-                      "      </param>"
 
-                      "      <param>"
 
-                      "       <value>"
 
-                      "         <struct>"
 
-                      "           <member>"
 
-                      "             <name>max-count</name>"
 
-                      "             <value><i4>65535</i4></value>"
 
-                      "           </member>"
 
-                      "           <member>"
 
-                      "             <name>seed-ratio</name>"
 
-                      "             <value><double>0.99</double></value>"
 
-                      "           </member>"
 
-                      "         </struct>"
 
-                      "       </value>"
 
-                      "     </param>"
 
-                      "     <param>"
 
-                      "       <value>"
 
-                      "         <array>"
 
-                      "           <data>"
 
-                      "             <value><string>pudding</string></value>"
 
-                      "             <value><base64>aGVsbG8gd29ybGQ=</base64></value>"
 
-                      "           </data>"                    
 
-                      "         </array>"
 
-                      "       </value>"
 
-                      "     </param>"
 
-                      "   </params>"
 
-                      "</methodCall>");
 
-   CPPUNIT_ASSERT_EQUAL(std::string("aria2.addURI"), req.methodName);
 
-   CPPUNIT_ASSERT_EQUAL((size_t)3, req.params->size());
 
-   CPPUNIT_ASSERT_EQUAL((Integer::ValueType)100,
 
-                        asInteger(req.params->get(0))->i());
 
-   const Dict* dict = asDict(req.params->get(1));
 
-   CPPUNIT_ASSERT_EQUAL((Integer::ValueType)65535,
 
-                        asInteger(dict->get("max-count"))->i());
 
-   // Current implementation handles double as string.
 
-   CPPUNIT_ASSERT_EQUAL(std::string("0.99"),
 
-                        asString(dict->get("seed-ratio"))->s());
 
-   const List* list = asList(req.params->get(2));
 
-   CPPUNIT_ASSERT_EQUAL(std::string("pudding"), asString(list->get(0))->s());
 
-   CPPUNIT_ASSERT_EQUAL(std::string("hello world"), asString(list->get(1))->s());
 
- }
 
- void XmlRpcRequestProcessorTest::testParseMemory_shouldFail()
 
- {
 
-   XmlRpcRequestProcessor proc;
 
-   try {
 
-     proc.parseMemory("<methodCall>"
 
-                      "  <methodName>aria2.addURI</methodName>"
 
-                      "    <params>"
 
-                      "      <param>"
 
-                      "        <value><i4>100</i4></value>"
 
-                      "      </param>");
 
-     CPPUNIT_FAIL("exception must be thrown.");
 
-   } catch(RecoverableException& e) {
 
-     // success
 
-   }
 
-   {
 
-     XmlRpcRequest req =
 
-       proc.parseMemory("<methodCall>"
 
-                        "  <methodName>aria2.addURI</methodName>"
 
-                      "    <params>"
 
-                      "    </params>"
 
-                        "</methodCall>");
 
-     CPPUNIT_ASSERT(!req.params.isNull());
 
-   }
 
-   try {
 
-     XmlRpcRequest req =
 
-     proc.parseMemory("<methodCall>"
 
-                      "  <methodName>aria2.addURI</methodName>"
 
-                      "</methodCall>");
 
-     CPPUNIT_FAIL("exception must be thrown.");
 
-   } catch(RecoverableException& e) {
 
-     // success
 
-   }
 
- }
 
- } // namespace xmlrpc
 
- } // namespace aria2
 
 
  |