mirror of https://github.com/aria2/aria2
If no data type tag is used in XML-RPC, treat the data as string.
parent
6ee58e2872
commit
211c4ea9f4
|
@ -168,7 +168,20 @@ void ValueXmlRpcRequestParserState::beginElement
|
||||||
stm->pushUnknownElementState();
|
stm->pushUnknownElementState();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void ValueXmlRpcRequestParserState::endElement
|
||||||
|
(XmlRpcRequestParserStateMachine* stm,
|
||||||
|
const std::string& name,
|
||||||
|
const std::string& characters)
|
||||||
|
{
|
||||||
|
// XML-RPC specification says that if no data type tag is used, the
|
||||||
|
// data must be treated as string. To prevent from overwriting
|
||||||
|
// current frame value, we first check it is still null.
|
||||||
|
if(!stm->getCurrentFrameValue() && !characters.empty()) {
|
||||||
|
stm->setCurrentFrameValue(String::g(characters));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// IntXmlRpcRequestParserState
|
// IntXmlRpcRequestParserState
|
||||||
|
|
||||||
void IntXmlRpcRequestParserState::beginElement
|
void IntXmlRpcRequestParserState::beginElement
|
||||||
|
@ -321,6 +334,7 @@ void ArrayValueXmlRpcRequestParserState::endElement
|
||||||
const std::string& name,
|
const std::string& name,
|
||||||
const std::string& characters)
|
const std::string& characters)
|
||||||
{
|
{
|
||||||
|
ValueXmlRpcRequestParserState::endElement(stm, name, characters);
|
||||||
stm->popArrayFrame();
|
stm->popArrayFrame();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -121,12 +121,12 @@ class ValueXmlRpcRequestParserState:public XmlRpcRequestParserState {
|
||||||
virtual void beginElement(XmlRpcRequestParserStateMachine* stm,
|
virtual void beginElement(XmlRpcRequestParserStateMachine* stm,
|
||||||
const std::string& name,
|
const std::string& name,
|
||||||
const std::map<std::string, std::string>& attrs);
|
const std::map<std::string, std::string>& attrs);
|
||||||
|
protected:
|
||||||
virtual void endElement(XmlRpcRequestParserStateMachine* stm,
|
virtual void endElement(XmlRpcRequestParserStateMachine* stm,
|
||||||
const std::string& name,
|
const std::string& name,
|
||||||
const std::string& characters) {}
|
const std::string& characters);
|
||||||
|
|
||||||
virtual bool needsCharactersBuffering() const { return false; }
|
virtual bool needsCharactersBuffering() const { return true; }
|
||||||
};
|
};
|
||||||
|
|
||||||
class IntXmlRpcRequestParserState:public XmlRpcRequestParserState {
|
class IntXmlRpcRequestParserState:public XmlRpcRequestParserState {
|
||||||
|
|
|
@ -14,6 +14,7 @@ class XmlRpcRequestProcessorTest:public CppUnit::TestFixture {
|
||||||
CPPUNIT_TEST_SUITE(XmlRpcRequestProcessorTest);
|
CPPUNIT_TEST_SUITE(XmlRpcRequestProcessorTest);
|
||||||
CPPUNIT_TEST(testParseMemory);
|
CPPUNIT_TEST(testParseMemory);
|
||||||
CPPUNIT_TEST(testParseMemory_shouldFail);
|
CPPUNIT_TEST(testParseMemory_shouldFail);
|
||||||
|
CPPUNIT_TEST(testParseMemory_withoutStringTag);
|
||||||
CPPUNIT_TEST_SUITE_END();
|
CPPUNIT_TEST_SUITE_END();
|
||||||
public:
|
public:
|
||||||
void setUp() {}
|
void setUp() {}
|
||||||
|
@ -22,6 +23,7 @@ public:
|
||||||
|
|
||||||
void testParseMemory();
|
void testParseMemory();
|
||||||
void testParseMemory_shouldFail();
|
void testParseMemory_shouldFail();
|
||||||
|
void testParseMemory_withoutStringTag();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
@ -114,6 +116,58 @@ void XmlRpcRequestProcessorTest::testParseMemory_shouldFail()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void XmlRpcRequestProcessorTest::testParseMemory_withoutStringTag()
|
||||||
|
{
|
||||||
|
XmlRpcRequestProcessor proc;
|
||||||
|
RpcRequest req =
|
||||||
|
proc.parseMemory("<?xml version=\"1.0\"?>"
|
||||||
|
"<methodCall>"
|
||||||
|
" <methodName>aria2.addUri</methodName>"
|
||||||
|
" <params>"
|
||||||
|
" <param>"
|
||||||
|
" <value>http://aria2.sourceforge.net</value>"
|
||||||
|
" </param>"
|
||||||
|
" <param>"
|
||||||
|
" <value>http://aria2.<foo/>sourceforge.net</value>"
|
||||||
|
" </param>"
|
||||||
|
" <param>"
|
||||||
|
" <value>"
|
||||||
|
" <struct>"
|
||||||
|
" <member>"
|
||||||
|
" <name>hello</name>"
|
||||||
|
" <value>world</value>"
|
||||||
|
" </member>"
|
||||||
|
" </struct>"
|
||||||
|
" </value>"
|
||||||
|
" </param>"
|
||||||
|
" <param>"
|
||||||
|
" <value>"
|
||||||
|
" <array>"
|
||||||
|
" <data>"
|
||||||
|
" <value>apple</value>"
|
||||||
|
" <value>banana</value>"
|
||||||
|
" <value><string>lemon</string>peanuts</value>"
|
||||||
|
" </data>"
|
||||||
|
" </array>"
|
||||||
|
" </value>"
|
||||||
|
" </param>"
|
||||||
|
" </params>"
|
||||||
|
"</methodCall>");
|
||||||
|
|
||||||
|
CPPUNIT_ASSERT_EQUAL((size_t)4, req.params->size());
|
||||||
|
CPPUNIT_ASSERT_EQUAL(std::string("http://aria2.sourceforge.net"),
|
||||||
|
asString(req.params->get(0))->s());
|
||||||
|
CPPUNIT_ASSERT_EQUAL(std::string("http://aria2.sourceforge.net"),
|
||||||
|
asString(req.params->get(1))->s());
|
||||||
|
const Dict* dict = asDict(req.params->get(2));
|
||||||
|
CPPUNIT_ASSERT_EQUAL(std::string("world"),
|
||||||
|
asString(dict->get("hello"))->s());
|
||||||
|
const List* list = asList(req.params->get(3));
|
||||||
|
CPPUNIT_ASSERT_EQUAL(std::string("apple"), asString(list->get(0))->s());
|
||||||
|
CPPUNIT_ASSERT_EQUAL(std::string("banana"), asString(list->get(1))->s());
|
||||||
|
CPPUNIT_ASSERT_EQUAL(std::string("lemon"), asString(list->get(2))->s());
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace rpc
|
} // namespace rpc
|
||||||
|
|
||||||
} // namespace aria2
|
} // namespace aria2
|
||||||
|
|
Loading…
Reference in New Issue