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);
- }
- 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
|