2009-05-08 07:58:50 +00:00
|
|
|
#include "XmlRpcMethod.h"
|
|
|
|
|
|
|
|
#include <cppunit/extensions/HelperMacros.h>
|
|
|
|
|
|
|
|
#include "DownloadEngine.h"
|
|
|
|
#include "SelectEventPoll.h"
|
|
|
|
#include "Option.h"
|
|
|
|
#include "RequestGroupMan.h"
|
|
|
|
#include "ServerStatMan.h"
|
|
|
|
#include "RequestGroup.h"
|
|
|
|
#include "XmlRpcMethodImpl.h"
|
|
|
|
#include "BDE.h"
|
|
|
|
#include "OptionParser.h"
|
|
|
|
#include "OptionHandler.h"
|
|
|
|
#include "XmlRpcRequest.h"
|
2009-05-14 12:59:52 +00:00
|
|
|
#include "XmlRpcResponse.h"
|
2009-05-14 15:23:50 +00:00
|
|
|
#include "prefs.h"
|
2009-05-15 05:20:11 +00:00
|
|
|
#include "TestUtil.h"
|
2009-05-22 12:28:32 +00:00
|
|
|
#include "DownloadContext.h"
|
2009-07-10 15:55:42 +00:00
|
|
|
#include "FeatureConfig.h"
|
2009-05-08 07:58:50 +00:00
|
|
|
|
|
|
|
namespace aria2 {
|
|
|
|
|
|
|
|
namespace xmlrpc {
|
|
|
|
|
|
|
|
class XmlRpcMethodTest:public CppUnit::TestFixture {
|
|
|
|
|
|
|
|
CPPUNIT_TEST_SUITE(XmlRpcMethodTest);
|
2009-05-10 14:51:20 +00:00
|
|
|
CPPUNIT_TEST(testAddUri);
|
2009-05-22 12:28:32 +00:00
|
|
|
CPPUNIT_TEST(testAddUri_withoutUri);
|
|
|
|
CPPUNIT_TEST(testAddUri_notUri);
|
|
|
|
CPPUNIT_TEST(testAddUri_withBadOption);
|
2009-05-30 13:55:14 +00:00
|
|
|
CPPUNIT_TEST(testAddUri_withPosition);
|
2009-06-14 11:29:46 +00:00
|
|
|
CPPUNIT_TEST(testAddUri_withBadPosition);
|
2009-05-27 17:27:05 +00:00
|
|
|
#ifdef ENABLE_BITTORRENT
|
2009-05-15 05:20:11 +00:00
|
|
|
CPPUNIT_TEST(testAddTorrent);
|
2009-05-22 12:28:32 +00:00
|
|
|
CPPUNIT_TEST(testAddTorrent_withoutTorrent);
|
|
|
|
CPPUNIT_TEST(testAddTorrent_notBase64Torrent);
|
2009-05-30 13:55:14 +00:00
|
|
|
CPPUNIT_TEST(testAddTorrent_withPosition);
|
2009-05-27 17:27:05 +00:00
|
|
|
#endif // ENABLE_BITTORRENT
|
|
|
|
#ifdef ENABLE_METALINK
|
2009-05-15 05:20:11 +00:00
|
|
|
CPPUNIT_TEST(testAddMetalink);
|
2009-05-22 12:28:32 +00:00
|
|
|
CPPUNIT_TEST(testAddMetalink_withoutMetalink);
|
|
|
|
CPPUNIT_TEST(testAddMetalink_notBase64Metalink);
|
2009-05-30 13:55:14 +00:00
|
|
|
CPPUNIT_TEST(testAddMetalink_withPosition);
|
2009-05-27 17:27:05 +00:00
|
|
|
#endif // ENABLE_METALINK
|
2009-05-14 15:23:50 +00:00
|
|
|
CPPUNIT_TEST(testChangeOption);
|
2009-05-22 12:28:32 +00:00
|
|
|
CPPUNIT_TEST(testChangeOption_withBadOption);
|
2009-10-04 09:01:11 +00:00
|
|
|
CPPUNIT_TEST(testChangeOption_withNotAllowedOption);
|
2009-05-22 12:28:32 +00:00
|
|
|
CPPUNIT_TEST(testChangeOption_withoutGid);
|
2009-05-14 15:44:59 +00:00
|
|
|
CPPUNIT_TEST(testChangeGlobalOption);
|
2009-05-22 12:28:32 +00:00
|
|
|
CPPUNIT_TEST(testChangeGlobalOption_withBadOption);
|
2009-10-04 09:01:11 +00:00
|
|
|
CPPUNIT_TEST(testChangeGlobalOption_withNotAllowedOption);
|
2009-05-22 12:28:32 +00:00
|
|
|
CPPUNIT_TEST(testTellStatus_withoutGid);
|
2009-06-23 15:14:24 +00:00
|
|
|
CPPUNIT_TEST(testTellWaiting);
|
|
|
|
CPPUNIT_TEST(testTellWaiting_fail);
|
2009-07-10 15:55:42 +00:00
|
|
|
CPPUNIT_TEST(testGetVersion);
|
2009-05-09 04:55:53 +00:00
|
|
|
CPPUNIT_TEST(testNoSuchMethod);
|
2009-05-08 07:58:50 +00:00
|
|
|
CPPUNIT_TEST_SUITE_END();
|
|
|
|
private:
|
|
|
|
SharedHandle<DownloadEngine> _e;
|
|
|
|
SharedHandle<Option> _option;
|
|
|
|
public:
|
|
|
|
void setUp()
|
|
|
|
{
|
2009-05-14 15:23:50 +00:00
|
|
|
RequestGroup::resetGIDCounter();
|
2009-05-08 07:58:50 +00:00
|
|
|
_option.reset(new Option());
|
2009-05-15 05:20:11 +00:00
|
|
|
_option->put(PREF_DIR, "/tmp");
|
2009-06-23 15:14:24 +00:00
|
|
|
_option->put(PREF_SEGMENT_SIZE, "1048576");
|
2009-05-08 07:58:50 +00:00
|
|
|
_e.reset(new DownloadEngine(SharedHandle<EventPoll>(new SelectEventPoll())));
|
|
|
|
_e->option = _option.get();
|
|
|
|
_e->_requestGroupMan.reset
|
|
|
|
(new RequestGroupMan(std::deque<SharedHandle<RequestGroup> >(),
|
|
|
|
1, _option.get()));
|
|
|
|
}
|
|
|
|
|
|
|
|
void tearDown() {}
|
|
|
|
|
2009-05-10 14:51:20 +00:00
|
|
|
void testAddUri();
|
2009-05-22 12:28:32 +00:00
|
|
|
void testAddUri_withoutUri();
|
|
|
|
void testAddUri_notUri();
|
|
|
|
void testAddUri_withBadOption();
|
2009-05-30 13:55:14 +00:00
|
|
|
void testAddUri_withPosition();
|
2009-06-14 11:29:46 +00:00
|
|
|
void testAddUri_withBadPosition();
|
2009-05-27 17:27:05 +00:00
|
|
|
#ifdef ENABLE_BITTORRENT
|
2009-05-15 05:20:11 +00:00
|
|
|
void testAddTorrent();
|
2009-05-22 12:28:32 +00:00
|
|
|
void testAddTorrent_withoutTorrent();
|
|
|
|
void testAddTorrent_notBase64Torrent();
|
2009-05-30 13:55:14 +00:00
|
|
|
void testAddTorrent_withPosition();
|
2009-05-27 17:27:05 +00:00
|
|
|
#endif // ENABLE_BITTORRENT
|
|
|
|
#ifdef ENABLE_METALINK
|
2009-05-15 05:20:11 +00:00
|
|
|
void testAddMetalink();
|
2009-05-22 12:28:32 +00:00
|
|
|
void testAddMetalink_withoutMetalink();
|
|
|
|
void testAddMetalink_notBase64Metalink();
|
2009-05-30 13:55:14 +00:00
|
|
|
void testAddMetalink_withPosition();
|
2009-05-27 17:27:05 +00:00
|
|
|
#endif // ENABLE_METALINK
|
2009-05-14 15:23:50 +00:00
|
|
|
void testChangeOption();
|
2009-05-22 12:28:32 +00:00
|
|
|
void testChangeOption_withBadOption();
|
2009-10-04 09:01:11 +00:00
|
|
|
void testChangeOption_withNotAllowedOption();
|
2009-05-22 12:28:32 +00:00
|
|
|
void testChangeOption_withoutGid();
|
2009-05-14 15:44:59 +00:00
|
|
|
void testChangeGlobalOption();
|
2009-05-22 12:28:32 +00:00
|
|
|
void testChangeGlobalOption_withBadOption();
|
2009-10-04 09:01:11 +00:00
|
|
|
void testChangeGlobalOption_withNotAllowedOption();
|
2009-05-22 12:28:32 +00:00
|
|
|
void testTellStatus_withoutGid();
|
2009-06-23 15:14:24 +00:00
|
|
|
void testTellWaiting();
|
|
|
|
void testTellWaiting_fail();
|
2009-07-10 15:55:42 +00:00
|
|
|
void testGetVersion();
|
2009-05-09 04:55:53 +00:00
|
|
|
void testNoSuchMethod();
|
2009-05-08 07:58:50 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
CPPUNIT_TEST_SUITE_REGISTRATION(XmlRpcMethodTest);
|
|
|
|
|
2009-05-10 14:51:20 +00:00
|
|
|
void XmlRpcMethodTest::testAddUri()
|
2009-05-08 07:58:50 +00:00
|
|
|
{
|
2009-05-10 14:51:20 +00:00
|
|
|
AddUriXmlRpcMethod m;
|
|
|
|
XmlRpcRequest req("aria2.addUri", BDE::list());
|
2009-05-08 07:58:50 +00:00
|
|
|
req._params << BDE::list();
|
|
|
|
req._params[0] << BDE("http://localhost/");
|
2009-05-22 12:28:32 +00:00
|
|
|
{
|
|
|
|
XmlRpcResponse res = m.execute(req, _e.get());
|
|
|
|
CPPUNIT_ASSERT_EQUAL(0, res._code);
|
|
|
|
const std::deque<SharedHandle<RequestGroup> > rgs =
|
|
|
|
_e->_requestGroupMan->getReservedGroups();
|
|
|
|
CPPUNIT_ASSERT_EQUAL((size_t)1, rgs.size());
|
|
|
|
CPPUNIT_ASSERT_EQUAL(std::string("http://localhost/"),
|
2009-06-29 08:42:58 +00:00
|
|
|
rgs.front()->getDownloadContext()->getFirstFileEntry()->getRemainingUris().front());
|
2009-05-22 12:28:32 +00:00
|
|
|
}
|
|
|
|
// with options
|
|
|
|
BDE opt = BDE::dict();
|
|
|
|
opt[PREF_DIR] = BDE("/sink");
|
|
|
|
req._params << opt;
|
|
|
|
{
|
|
|
|
XmlRpcResponse res = m.execute(req, _e.get());
|
|
|
|
CPPUNIT_ASSERT_EQUAL(0, res._code);
|
|
|
|
CPPUNIT_ASSERT_EQUAL(std::string("/sink"),
|
|
|
|
_e->_requestGroupMan->findReservedGroup(2)->
|
|
|
|
getDownloadContext()->getDir());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void XmlRpcMethodTest::testAddUri_withoutUri()
|
|
|
|
{
|
|
|
|
AddUriXmlRpcMethod m;
|
|
|
|
XmlRpcRequest req("aria2.addUri", BDE::list());
|
2009-05-14 12:59:52 +00:00
|
|
|
XmlRpcResponse res = m.execute(req, _e.get());
|
2009-05-22 12:28:32 +00:00
|
|
|
CPPUNIT_ASSERT_EQUAL(1, res._code);
|
|
|
|
}
|
|
|
|
|
|
|
|
void XmlRpcMethodTest::testAddUri_notUri()
|
|
|
|
{
|
|
|
|
AddUriXmlRpcMethod m;
|
|
|
|
XmlRpcRequest req("aria2.addUri", BDE::list());
|
|
|
|
req._params << BDE::list();
|
|
|
|
req._params[0] << BDE("not uri");
|
|
|
|
XmlRpcResponse res = m.execute(req, _e.get());
|
|
|
|
CPPUNIT_ASSERT_EQUAL(1, res._code);
|
|
|
|
}
|
|
|
|
|
|
|
|
void XmlRpcMethodTest::testAddUri_withBadOption()
|
|
|
|
{
|
|
|
|
AddUriXmlRpcMethod m;
|
|
|
|
XmlRpcRequest req("aria2.addUri", BDE::list());
|
|
|
|
req._params << BDE::list();
|
|
|
|
req._params[0] << BDE("http://localhost");
|
|
|
|
BDE opt = BDE::dict();
|
|
|
|
opt[PREF_FILE_ALLOCATION] = BDE("badvalue");
|
|
|
|
req._params << opt;
|
|
|
|
XmlRpcResponse res = m.execute(req, _e.get());
|
|
|
|
CPPUNIT_ASSERT_EQUAL(1, res._code);
|
2009-05-09 04:55:53 +00:00
|
|
|
}
|
|
|
|
|
2009-05-30 13:55:14 +00:00
|
|
|
void XmlRpcMethodTest::testAddUri_withPosition()
|
|
|
|
{
|
|
|
|
AddUriXmlRpcMethod m;
|
|
|
|
XmlRpcRequest req1("aria2.addUri", BDE::list());
|
|
|
|
req1._params << BDE::list();
|
|
|
|
req1._params[0] << BDE("http://uri1");
|
|
|
|
XmlRpcResponse res1 = m.execute(req1, _e.get());
|
|
|
|
CPPUNIT_ASSERT_EQUAL(0, res1._code);
|
|
|
|
|
|
|
|
XmlRpcRequest req2("aria2.addUri", BDE::list());
|
|
|
|
req2._params << BDE::list();
|
|
|
|
req2._params[0] << BDE("http://uri2");
|
|
|
|
req2._params << BDE::dict();
|
|
|
|
req2._params << BDE((int64_t)0);
|
|
|
|
m.execute(req2, _e.get());
|
|
|
|
|
|
|
|
std::string uri =
|
2009-06-29 08:42:58 +00:00
|
|
|
_e->_requestGroupMan->getReservedGroups()[0]->getDownloadContext()->getFirstFileEntry()->getRemainingUris()[0];
|
2009-05-30 13:55:14 +00:00
|
|
|
|
|
|
|
CPPUNIT_ASSERT_EQUAL(std::string("http://uri2"), uri);
|
|
|
|
}
|
|
|
|
|
2009-06-14 11:29:46 +00:00
|
|
|
void XmlRpcMethodTest::testAddUri_withBadPosition()
|
|
|
|
{
|
|
|
|
AddUriXmlRpcMethod m;
|
|
|
|
XmlRpcRequest req("aria2.addUri", BDE::list());
|
|
|
|
req._params << BDE::list();
|
|
|
|
req._params[0] << BDE("http://localhost/");
|
|
|
|
req._params << BDE::dict();
|
|
|
|
req._params << BDE((int64_t)-1);
|
|
|
|
XmlRpcResponse res = m.execute(req, _e.get());
|
|
|
|
CPPUNIT_ASSERT_EQUAL(1, res._code);
|
|
|
|
}
|
|
|
|
|
2009-05-27 17:27:05 +00:00
|
|
|
#ifdef ENABLE_BITTORRENT
|
2009-05-15 05:20:11 +00:00
|
|
|
void XmlRpcMethodTest::testAddTorrent()
|
|
|
|
{
|
|
|
|
AddTorrentXmlRpcMethod m;
|
|
|
|
XmlRpcRequest req("aria2.addTorrent", BDE::list());
|
|
|
|
req._params << BDE(readFile("single.torrent"));
|
|
|
|
BDE uris = BDE::list();
|
|
|
|
uris << BDE("http://localhost/aria2-0.8.2.tar.bz2");
|
|
|
|
req._params << uris;
|
|
|
|
{
|
|
|
|
XmlRpcResponse res = m.execute(req, _e.get());
|
|
|
|
CPPUNIT_ASSERT_EQUAL(0, res._code);
|
|
|
|
CPPUNIT_ASSERT_EQUAL(std::string("1"), res._param.s());
|
|
|
|
|
|
|
|
SharedHandle<RequestGroup> group = _e->_requestGroupMan->findReservedGroup(1);
|
|
|
|
CPPUNIT_ASSERT(!group.isNull());
|
|
|
|
CPPUNIT_ASSERT_EQUAL(std::string("/tmp/aria2-0.8.2.tar.bz2"),
|
2009-06-28 10:37:15 +00:00
|
|
|
group->getFirstFilePath());
|
2009-06-29 08:42:58 +00:00
|
|
|
CPPUNIT_ASSERT_EQUAL((size_t)1, group->getDownloadContext()->getFirstFileEntry()->getRemainingUris().size());
|
2009-05-15 05:20:11 +00:00
|
|
|
CPPUNIT_ASSERT_EQUAL(std::string("http://localhost/aria2-0.8.2.tar.bz2"),
|
2009-06-29 08:42:58 +00:00
|
|
|
group->getDownloadContext()->getFirstFileEntry()->getRemainingUris()[0]);
|
2009-05-15 05:20:11 +00:00
|
|
|
}
|
|
|
|
// with options
|
|
|
|
BDE opt = BDE::dict();
|
|
|
|
opt[PREF_DIR] = BDE("/sink");
|
|
|
|
req._params << opt;
|
|
|
|
{
|
|
|
|
XmlRpcResponse res = m.execute(req, _e.get());
|
|
|
|
CPPUNIT_ASSERT_EQUAL(0, res._code);
|
|
|
|
CPPUNIT_ASSERT_EQUAL(std::string("/sink/aria2-0.8.2.tar.bz2"),
|
2009-06-28 10:37:15 +00:00
|
|
|
_e->_requestGroupMan->findReservedGroup(2)->getFirstFilePath());
|
2009-05-15 05:20:11 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2009-05-22 12:28:32 +00:00
|
|
|
void XmlRpcMethodTest::testAddTorrent_withoutTorrent()
|
|
|
|
{
|
|
|
|
AddTorrentXmlRpcMethod m;
|
|
|
|
XmlRpcRequest req("aria2.addTorrent", BDE::list());
|
|
|
|
XmlRpcResponse res = m.execute(req, _e.get());
|
|
|
|
CPPUNIT_ASSERT_EQUAL(1, res._code);
|
|
|
|
}
|
|
|
|
|
|
|
|
void XmlRpcMethodTest::testAddTorrent_notBase64Torrent()
|
|
|
|
{
|
|
|
|
AddTorrentXmlRpcMethod m;
|
|
|
|
XmlRpcRequest req("aria2.addTorrent", BDE::list());
|
|
|
|
req._params << BDE("not torrent");
|
|
|
|
XmlRpcResponse res = m.execute(req, _e.get());
|
|
|
|
CPPUNIT_ASSERT_EQUAL(1, res._code);
|
|
|
|
}
|
2009-05-30 13:55:14 +00:00
|
|
|
|
|
|
|
void XmlRpcMethodTest::testAddTorrent_withPosition()
|
|
|
|
{
|
|
|
|
AddTorrentXmlRpcMethod m;
|
|
|
|
XmlRpcRequest req1("aria2.addTorrent", BDE::list());
|
|
|
|
req1._params << BDE(readFile("test.torrent"));
|
|
|
|
req1._params << BDE::list();
|
|
|
|
req1._params << BDE::dict();
|
|
|
|
XmlRpcResponse res1 = m.execute(req1, _e.get());
|
|
|
|
CPPUNIT_ASSERT_EQUAL(0, res1._code);
|
|
|
|
|
|
|
|
XmlRpcRequest req2("aria2.addTorrent", BDE::list());
|
|
|
|
req2._params << BDE(readFile("single.torrent"));
|
|
|
|
req2._params << BDE::list();
|
|
|
|
req2._params << BDE::dict();
|
|
|
|
req2._params << BDE((int64_t)0);
|
|
|
|
m.execute(req2, _e.get());
|
|
|
|
|
|
|
|
CPPUNIT_ASSERT_EQUAL((size_t)1,
|
|
|
|
_e->_requestGroupMan->getReservedGroups()[0]->
|
|
|
|
getDownloadContext()->getFileEntries().size());
|
|
|
|
}
|
|
|
|
|
2009-05-27 17:27:05 +00:00
|
|
|
#endif // ENABLE_BITTORRENT
|
2009-05-22 12:28:32 +00:00
|
|
|
|
2009-05-27 17:27:05 +00:00
|
|
|
#ifdef ENABLE_METALINK
|
2009-05-15 05:20:11 +00:00
|
|
|
void XmlRpcMethodTest::testAddMetalink()
|
|
|
|
{
|
|
|
|
AddMetalinkXmlRpcMethod m;
|
|
|
|
XmlRpcRequest req("aria2.addMetalink", BDE::list());
|
|
|
|
req._params << BDE(readFile("2files.metalink"));
|
|
|
|
{
|
|
|
|
XmlRpcResponse res = m.execute(req, _e.get());
|
|
|
|
CPPUNIT_ASSERT_EQUAL(0, res._code);
|
|
|
|
CPPUNIT_ASSERT_EQUAL((size_t)2, res._param.size());
|
|
|
|
CPPUNIT_ASSERT_EQUAL(std::string("1"), res._param[0].s());
|
|
|
|
CPPUNIT_ASSERT_EQUAL(std::string("2"), res._param[1].s());
|
|
|
|
|
|
|
|
SharedHandle<RequestGroup> tar = _e->_requestGroupMan->findReservedGroup(1);
|
|
|
|
CPPUNIT_ASSERT(!tar.isNull());
|
|
|
|
CPPUNIT_ASSERT_EQUAL(std::string("/tmp/aria2-5.0.0.tar.bz2"),
|
2009-06-28 10:37:15 +00:00
|
|
|
tar->getFirstFilePath());
|
2009-05-15 05:20:11 +00:00
|
|
|
SharedHandle<RequestGroup> deb = _e->_requestGroupMan->findReservedGroup(2);
|
|
|
|
CPPUNIT_ASSERT(!deb.isNull());
|
|
|
|
CPPUNIT_ASSERT_EQUAL(std::string("/tmp/aria2-5.0.0.deb"),
|
2009-06-28 10:37:15 +00:00
|
|
|
deb->getFirstFilePath());
|
2009-05-15 05:20:11 +00:00
|
|
|
}
|
|
|
|
// with options
|
|
|
|
BDE opt = BDE::dict();
|
|
|
|
opt[PREF_DIR] = BDE("/sink");
|
|
|
|
req._params << opt;
|
|
|
|
{
|
|
|
|
XmlRpcResponse res = m.execute(req, _e.get());
|
|
|
|
CPPUNIT_ASSERT_EQUAL(0, res._code);
|
|
|
|
CPPUNIT_ASSERT_EQUAL(std::string("/sink/aria2-5.0.0.tar.bz2"),
|
2009-06-28 10:37:15 +00:00
|
|
|
_e->_requestGroupMan->findReservedGroup(3)->getFirstFilePath());
|
2009-05-15 05:20:11 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2009-05-22 12:28:32 +00:00
|
|
|
void XmlRpcMethodTest::testAddMetalink_withoutMetalink()
|
|
|
|
{
|
|
|
|
AddMetalinkXmlRpcMethod m;
|
|
|
|
XmlRpcRequest req("aria2.addMetalink", BDE::list());
|
|
|
|
XmlRpcResponse res = m.execute(req, _e.get());
|
|
|
|
CPPUNIT_ASSERT_EQUAL(1, res._code);
|
|
|
|
}
|
|
|
|
|
|
|
|
void XmlRpcMethodTest::testAddMetalink_notBase64Metalink()
|
|
|
|
{
|
|
|
|
AddMetalinkXmlRpcMethod m;
|
|
|
|
XmlRpcRequest req("aria2.addMetalink", BDE::list());
|
|
|
|
req._params << BDE("not metalink");
|
|
|
|
XmlRpcResponse res = m.execute(req, _e.get());
|
|
|
|
CPPUNIT_ASSERT_EQUAL(1, res._code);
|
|
|
|
}
|
2009-05-30 13:55:14 +00:00
|
|
|
|
|
|
|
void XmlRpcMethodTest::testAddMetalink_withPosition()
|
|
|
|
{
|
|
|
|
AddUriXmlRpcMethod m1;
|
|
|
|
XmlRpcRequest req1("aria2.addUri", BDE::list());
|
|
|
|
req1._params << BDE::list();
|
|
|
|
req1._params[0] << BDE("http://uri");
|
|
|
|
XmlRpcResponse res1 = m1.execute(req1, _e.get());
|
|
|
|
CPPUNIT_ASSERT_EQUAL(0, res1._code);
|
|
|
|
|
|
|
|
AddMetalinkXmlRpcMethod m2;
|
|
|
|
XmlRpcRequest req2("ari2.addMetalink", BDE::list());
|
|
|
|
req2._params << BDE(readFile("2files.metalink"));
|
|
|
|
req2._params << BDE::dict();
|
|
|
|
req2._params << BDE((int64_t)0);
|
|
|
|
XmlRpcResponse res2 = m2.execute(req2, _e.get());
|
|
|
|
CPPUNIT_ASSERT_EQUAL(0, res2._code);
|
|
|
|
|
|
|
|
CPPUNIT_ASSERT_EQUAL(std::string("/tmp/aria2-5.0.0.tar.bz2"),
|
|
|
|
_e->_requestGroupMan->getReservedGroups()[0]->
|
2009-06-28 10:37:15 +00:00
|
|
|
getFirstFilePath());
|
2009-05-30 13:55:14 +00:00
|
|
|
}
|
|
|
|
|
2009-05-27 17:27:05 +00:00
|
|
|
#endif // ENABLE_METALINK
|
2009-05-22 12:28:32 +00:00
|
|
|
|
2009-05-14 15:23:50 +00:00
|
|
|
void XmlRpcMethodTest::testChangeOption()
|
|
|
|
{
|
2009-06-29 08:42:58 +00:00
|
|
|
SharedHandle<RequestGroup> group(new RequestGroup(_option));
|
2009-05-14 15:23:50 +00:00
|
|
|
_e->_requestGroupMan->addReservedGroup(group);
|
|
|
|
|
|
|
|
ChangeOptionXmlRpcMethod m;
|
|
|
|
XmlRpcRequest req("aria2.changeOption", BDE::list());
|
|
|
|
req._params << BDE("1");
|
|
|
|
BDE opt = BDE::dict();
|
|
|
|
opt[PREF_MAX_DOWNLOAD_LIMIT] = BDE("100K");
|
2009-05-27 17:27:05 +00:00
|
|
|
#ifdef ENABLE_BITTORRENT
|
2009-05-14 15:23:50 +00:00
|
|
|
opt[PREF_MAX_UPLOAD_LIMIT] = BDE("50K");
|
2009-05-27 17:27:05 +00:00
|
|
|
#endif // ENABLE_BITTORRENT
|
2009-05-14 15:23:50 +00:00
|
|
|
req._params << opt;
|
|
|
|
XmlRpcResponse res = m.execute(req, _e.get());
|
|
|
|
|
|
|
|
CPPUNIT_ASSERT_EQUAL(0, res._code);
|
|
|
|
CPPUNIT_ASSERT_EQUAL((unsigned int)100*1024,
|
|
|
|
group->getMaxDownloadSpeedLimit());
|
2009-10-04 09:01:11 +00:00
|
|
|
CPPUNIT_ASSERT_EQUAL(std::string("102400"),
|
|
|
|
group->getOption()->get(PREF_MAX_DOWNLOAD_LIMIT));
|
2009-05-27 17:27:05 +00:00
|
|
|
#ifdef ENABLE_BITTORRENT
|
|
|
|
CPPUNIT_ASSERT_EQUAL((unsigned int)50*1024, group->getMaxUploadSpeedLimit());
|
2009-10-04 09:01:11 +00:00
|
|
|
CPPUNIT_ASSERT_EQUAL(std::string("51200"),
|
|
|
|
group->getOption()->get(PREF_MAX_UPLOAD_LIMIT));
|
2009-05-27 17:27:05 +00:00
|
|
|
#endif // ENABLE_BITTORRENT
|
2009-05-14 15:23:50 +00:00
|
|
|
}
|
|
|
|
|
2009-05-22 12:28:32 +00:00
|
|
|
void XmlRpcMethodTest::testChangeOption_withBadOption()
|
|
|
|
{
|
2009-06-29 08:42:58 +00:00
|
|
|
SharedHandle<RequestGroup> group(new RequestGroup(_option));
|
2009-05-22 12:28:32 +00:00
|
|
|
_e->_requestGroupMan->addReservedGroup(group);
|
|
|
|
|
|
|
|
ChangeOptionXmlRpcMethod m;
|
|
|
|
XmlRpcRequest req("aria2.changeOption", BDE::list());
|
|
|
|
req._params << BDE("1");
|
|
|
|
BDE opt = BDE::dict();
|
|
|
|
opt[PREF_MAX_DOWNLOAD_LIMIT] = BDE("badvalue");
|
|
|
|
req._params << opt;
|
|
|
|
XmlRpcResponse res = m.execute(req, _e.get());
|
|
|
|
CPPUNIT_ASSERT_EQUAL(1, res._code);
|
|
|
|
}
|
|
|
|
|
2009-10-04 09:01:11 +00:00
|
|
|
void XmlRpcMethodTest::testChangeOption_withNotAllowedOption()
|
|
|
|
{
|
|
|
|
SharedHandle<RequestGroup> group(new RequestGroup(_option));
|
|
|
|
_e->_requestGroupMan->addReservedGroup(group);
|
|
|
|
|
|
|
|
ChangeOptionXmlRpcMethod m;
|
|
|
|
XmlRpcRequest req("aria2.changeOption", BDE::list());
|
|
|
|
req._params << BDE("1");
|
|
|
|
BDE opt = BDE::dict();
|
|
|
|
opt[PREF_MAX_OVERALL_DOWNLOAD_LIMIT] = BDE("100K");
|
|
|
|
req._params << opt;
|
|
|
|
XmlRpcResponse res = m.execute(req, _e.get());
|
|
|
|
CPPUNIT_ASSERT_EQUAL(1, res._code);
|
|
|
|
}
|
|
|
|
|
2009-05-22 12:28:32 +00:00
|
|
|
void XmlRpcMethodTest::testChangeOption_withoutGid()
|
|
|
|
{
|
|
|
|
ChangeOptionXmlRpcMethod m;
|
|
|
|
XmlRpcRequest req("aria2.changeOption", BDE::list());
|
|
|
|
XmlRpcResponse res = m.execute(req, _e.get());
|
|
|
|
CPPUNIT_ASSERT_EQUAL(1, res._code);
|
|
|
|
}
|
|
|
|
|
2009-05-14 15:44:59 +00:00
|
|
|
void XmlRpcMethodTest::testChangeGlobalOption()
|
|
|
|
{
|
|
|
|
ChangeGlobalOptionXmlRpcMethod m;
|
|
|
|
XmlRpcRequest req("aria2.changeGlobalOption", BDE::list());
|
|
|
|
BDE opt = BDE::dict();
|
|
|
|
opt[PREF_MAX_OVERALL_DOWNLOAD_LIMIT] = BDE("100K");
|
2009-05-27 17:27:05 +00:00
|
|
|
#ifdef ENABLE_BITTORRENT
|
2009-05-14 15:44:59 +00:00
|
|
|
opt[PREF_MAX_OVERALL_UPLOAD_LIMIT] = BDE("50K");
|
2009-05-27 17:27:05 +00:00
|
|
|
#endif // ENABLE_BITTORRENT
|
2009-05-14 15:44:59 +00:00
|
|
|
req._params << opt;
|
|
|
|
XmlRpcResponse res = m.execute(req, _e.get());
|
|
|
|
|
|
|
|
CPPUNIT_ASSERT_EQUAL(0, res._code);
|
|
|
|
CPPUNIT_ASSERT_EQUAL((unsigned int)100*1024,
|
|
|
|
_e->_requestGroupMan->getMaxOverallDownloadSpeedLimit());
|
2009-10-04 09:01:11 +00:00
|
|
|
CPPUNIT_ASSERT_EQUAL(std::string("102400"),
|
|
|
|
_e->option->get(PREF_MAX_OVERALL_DOWNLOAD_LIMIT));
|
2009-05-27 17:27:05 +00:00
|
|
|
#ifdef ENABLE_BITTORRENT
|
2009-05-14 15:44:59 +00:00
|
|
|
CPPUNIT_ASSERT_EQUAL((unsigned int)50*1024,
|
|
|
|
_e->_requestGroupMan->getMaxOverallUploadSpeedLimit());
|
2009-10-04 09:01:11 +00:00
|
|
|
CPPUNIT_ASSERT_EQUAL(std::string("51200"),
|
|
|
|
_e->option->get(PREF_MAX_OVERALL_UPLOAD_LIMIT));
|
2009-05-27 17:27:05 +00:00
|
|
|
#endif // ENABLE_BITTORRENT
|
2009-05-14 15:44:59 +00:00
|
|
|
}
|
|
|
|
|
2009-05-22 12:28:32 +00:00
|
|
|
void XmlRpcMethodTest::testChangeGlobalOption_withBadOption()
|
|
|
|
{
|
|
|
|
ChangeGlobalOptionXmlRpcMethod m;
|
|
|
|
XmlRpcRequest req("aria2.changeGlobalOption", BDE::list());
|
|
|
|
BDE opt = BDE::dict();
|
|
|
|
opt[PREF_MAX_OVERALL_DOWNLOAD_LIMIT] = BDE("badvalue");
|
|
|
|
req._params << opt;
|
|
|
|
XmlRpcResponse res = m.execute(req, _e.get());
|
|
|
|
CPPUNIT_ASSERT_EQUAL(1, res._code);
|
|
|
|
}
|
|
|
|
|
2009-10-04 09:01:11 +00:00
|
|
|
void XmlRpcMethodTest::testChangeGlobalOption_withNotAllowedOption()
|
|
|
|
{
|
|
|
|
ChangeGlobalOptionXmlRpcMethod m;
|
|
|
|
XmlRpcRequest req("aria2.changeGlobalOption", BDE::list());
|
|
|
|
BDE opt = BDE::dict();
|
|
|
|
opt[PREF_MAX_DOWNLOAD_LIMIT] = BDE("100K");
|
|
|
|
req._params << opt;
|
|
|
|
XmlRpcResponse res = m.execute(req, _e.get());
|
|
|
|
CPPUNIT_ASSERT_EQUAL(1, res._code);
|
|
|
|
}
|
|
|
|
|
2009-05-09 04:55:53 +00:00
|
|
|
void XmlRpcMethodTest::testNoSuchMethod()
|
|
|
|
{
|
|
|
|
NoSuchMethodXmlRpcMethod m;
|
|
|
|
XmlRpcRequest req("make.hamburger", BDE::none);
|
2009-05-14 12:59:52 +00:00
|
|
|
XmlRpcResponse res = m.execute(req, 0);
|
|
|
|
CPPUNIT_ASSERT_EQUAL(1, res._code);
|
|
|
|
CPPUNIT_ASSERT_EQUAL(std::string("No such method: make.hamburger"),
|
|
|
|
res._param["faultString"].s());
|
2009-05-09 04:55:53 +00:00
|
|
|
CPPUNIT_ASSERT_EQUAL
|
|
|
|
(std::string("<?xml version=\"1.0\"?>"
|
|
|
|
"<methodResponse>"
|
|
|
|
"<fault>"
|
|
|
|
"<value>"
|
|
|
|
"<struct>"
|
|
|
|
"<member>"
|
|
|
|
"<name>faultCode</name><value><int>1</int></value>"
|
|
|
|
"</member>"
|
|
|
|
"<member>"
|
|
|
|
"<name>faultString</name>"
|
|
|
|
"<value>"
|
|
|
|
"<string>No such method: make.hamburger</string>"
|
|
|
|
"</value>"
|
|
|
|
"</member>"
|
|
|
|
"</struct>"
|
|
|
|
"</value>"
|
|
|
|
"</fault>"
|
|
|
|
"</methodResponse>"),
|
2009-05-14 12:59:52 +00:00
|
|
|
res.toXml());
|
2009-05-08 07:58:50 +00:00
|
|
|
}
|
|
|
|
|
2009-05-22 12:28:32 +00:00
|
|
|
void XmlRpcMethodTest::testTellStatus_withoutGid()
|
|
|
|
{
|
|
|
|
TellStatusXmlRpcMethod m;
|
|
|
|
XmlRpcRequest req("aria2.tellStatus", BDE::list());
|
|
|
|
XmlRpcResponse res = m.execute(req, _e.get());
|
|
|
|
CPPUNIT_ASSERT_EQUAL(1, res._code);
|
|
|
|
}
|
|
|
|
|
2009-06-23 15:14:24 +00:00
|
|
|
static void addUri(const std::string& uri,
|
|
|
|
const SharedHandle<DownloadEngine>& e)
|
|
|
|
{
|
|
|
|
AddUriXmlRpcMethod m;
|
|
|
|
XmlRpcRequest req("aria2.addUri", BDE::list());
|
|
|
|
req._params << BDE::list();
|
|
|
|
req._params[0] << BDE(uri);
|
|
|
|
CPPUNIT_ASSERT_EQUAL(0, m.execute(req, e.get())._code);
|
|
|
|
}
|
|
|
|
|
|
|
|
void XmlRpcMethodTest::testTellWaiting()
|
|
|
|
{
|
|
|
|
addUri("http://1/", _e);
|
|
|
|
addUri("http://2/", _e);
|
|
|
|
addUri("http://3/", _e);
|
|
|
|
addUri("http://4/", _e);
|
|
|
|
|
|
|
|
TellWaitingXmlRpcMethod m;
|
|
|
|
XmlRpcRequest req("aria2.tellWaiting", BDE::list());
|
|
|
|
req._params << BDE((int64_t)1);
|
|
|
|
req._params << BDE((int64_t)2);
|
|
|
|
XmlRpcResponse res = m.execute(req, _e.get());
|
|
|
|
CPPUNIT_ASSERT_EQUAL(0, res._code);
|
|
|
|
CPPUNIT_ASSERT_EQUAL((size_t)2, res._param.size());
|
|
|
|
CPPUNIT_ASSERT_EQUAL(std::string("2"), res._param[0]["gid"].s());
|
|
|
|
CPPUNIT_ASSERT_EQUAL(std::string("3"), res._param[1]["gid"].s());
|
|
|
|
// waiting.size() == offset+num
|
|
|
|
req = XmlRpcRequest("aria2.tellWaiting", BDE::list());
|
|
|
|
req._params << BDE((int64_t)1);
|
|
|
|
req._params << BDE((int64_t)3);
|
|
|
|
res = m.execute(req, _e.get());
|
|
|
|
CPPUNIT_ASSERT_EQUAL(0, res._code);
|
|
|
|
CPPUNIT_ASSERT_EQUAL((size_t)3, res._param.size());
|
|
|
|
// waiting.size() < offset+num
|
|
|
|
req = XmlRpcRequest("aria2.tellWaiting", BDE::list());
|
|
|
|
req._params << BDE((int64_t)1);
|
|
|
|
req._params << BDE((int64_t)4);
|
|
|
|
res = m.execute(req, _e.get());
|
|
|
|
CPPUNIT_ASSERT_EQUAL(0, res._code);
|
|
|
|
CPPUNIT_ASSERT_EQUAL((size_t)3, res._param.size());
|
|
|
|
}
|
|
|
|
|
|
|
|
void XmlRpcMethodTest::testTellWaiting_fail()
|
|
|
|
{
|
|
|
|
TellWaitingXmlRpcMethod m;
|
|
|
|
XmlRpcRequest req("aria2.tellWaiting", BDE::list());
|
|
|
|
XmlRpcResponse res = m.execute(req, _e.get());
|
|
|
|
CPPUNIT_ASSERT_EQUAL(1, res._code);
|
|
|
|
}
|
|
|
|
|
2009-07-10 15:55:42 +00:00
|
|
|
void XmlRpcMethodTest::testGetVersion()
|
|
|
|
{
|
|
|
|
GetVersionXmlRpcMethod m;
|
|
|
|
XmlRpcRequest req("aria2.getVersion", BDE::none);
|
|
|
|
XmlRpcResponse res = m.execute(req, _e.get());
|
|
|
|
CPPUNIT_ASSERT_EQUAL(0, res._code);
|
|
|
|
CPPUNIT_ASSERT_EQUAL(std::string(PACKAGE_VERSION), res._param["version"].s());
|
|
|
|
const BDE& featureList = res._param["enabledFeatures"];
|
|
|
|
std::string features;
|
|
|
|
for(BDE::List::const_iterator i = featureList.listBegin();
|
|
|
|
i != featureList.listEnd(); ++i) {
|
|
|
|
features += (*i).s();
|
|
|
|
features += ", ";
|
|
|
|
}
|
|
|
|
|
|
|
|
CPPUNIT_ASSERT_EQUAL(FeatureConfig::getInstance()->featureSummary()+", ",
|
|
|
|
features);
|
|
|
|
}
|
|
|
|
|
2009-05-08 07:58:50 +00:00
|
|
|
} // namespace xmlrpc
|
|
|
|
|
|
|
|
} // namespace aria2
|